Skip to content

Latest commit

 

History

History
65 lines (51 loc) · 2.19 KB

circleci-workflows.md

File metadata and controls

65 lines (51 loc) · 2.19 KB

Using semantic-release with CircleCI 2.0 workflows

Environment variables

The Authentication environment variables can be configured in CircleCi Project Settings..

Alternatively, the default NPM_TOKEN and GH_TOKEN can be easily setup with semantic-release-cli.

Multiple Node jobs configuration

.circleci/config.yml configuration for multiple Node jobs

This example is a minimal configuration for semantic-release with a build running Node 6 and 8. See CircleCI documentation for additional configuration options.

This example create the workflows test_node_4, test_node_6, test_node_8 and release. The release workflows will run semantic-release only after the all the test_node_* are successful.

version: 2
jobs:
  test_node_6:
    docker:
      - image: circleci/node:6
    steps:
      # Configure your test steps here (checkout, npm install, cache management, tests etc...)

  test_node_8:
    docker:
      - image: circleci/node:8
    steps:
      # Configure your test steps here (checkout, npm install, cache management, tests etc...)

  release:
    docker:
      - image: circleci/node:8
    steps:
      - checkout
      - run: npm install
      # Run optional required steps before releasing
      # - run: npm run build-script
      - run: npx semantic-release

workflows:
  version: 2
  test_and_release:
    # Run the test jobs first, then the release only when all the test jobs are successful
    jobs:
      - test_node_6
      - test_node_8
      - release:
          requires:
            - test_node_6
            - test_node_8

package.json configuration for multiple Node jobs

A package.json is required only for local semantic-release installation.

{
  "devDependencies": {
    "semantic-release": "^15.0.0"
  }
}