Skip to content

Latest commit

 

History

History
74 lines (52 loc) · 2.7 KB

CONTRIBUTING.md

File metadata and controls

74 lines (52 loc) · 2.7 KB

Contributing

Usage

# Install dependencies
npm install

# Build 
npm run build

# Run development server with storybook
npm run storybook

# Run all tests with lint/jest
npm run test

# Run test in watch mode
npm run test:watch

# Update test snapshot
npm run test:update

# Run linter
npm run lint

# Run linter with auto fix
npm run lint:fix

# Commit files with commitizen (use this instead of git commit)
npm run cz

Workflow

  • Create a component in the src/components folder
  • Add tests in the src/components/__tests__ folder
  • Register this component in src/index.js
  • Write stories which use your component as a template in src/stories/index.stories.js
  • Run npm run storybook to author your components by having a development environment
  • Run lint and tests before commiting anything
  • Commit using Commit Convention and push to github
  • If deployment is setup correctly(see next section), your components will be available on npm and release on github :)

Deployment

This repository is intended to be used with travisCI for deployment. Semantic-release is used and setup to auto-generate changelog, auto-publish to npm and auto-release to github based on commit messages structure. For it to work properly you have to follow this Commit Convention.

You may need to install Semantic-release-cli to enable and pre-configure travisCI with npm and github tokens.

So to enjoy an automated continuous deployment, it is required to have a NPM account, to have this project hosted on github, and to have previously login to travisCI.

Warning: After setting up semantic-release, your library will be publish automatically to npm and release to github. If you are not ready to publish to npm or to release you can do this later.

# Login to npm from your command-line
npm login

# Your npm account must be protected by a two-factor authentification in auth-only mode
npm profile enable-2fa auth-only

# Create your token manually since semantic-release-cli is not working yet with npm in 2FA
npm token create

# Then activate travisCI for your repository and launch semantic-release-cli
npm install -g semantic-release-cli
cd thisRepository
semantic-release-cli setup --npm-token=YOUR_NPM_TOKEN

# Fill your github credentials, select travisCI and select to replace .travis.yml
# TravisCI will be automatically enabled for your github repository
# And tokens will be injected in your travisCI repository config as environment variables

If everything is setup properly, every commit on master will generate a release if needed automatically. For the win.