Skip to content

Latest commit

 

History

History
96 lines (78 loc) · 3.75 KB

README.md

File metadata and controls

96 lines (78 loc) · 3.75 KB

mojaloop/build

CircleCI Build Status CircleCI Orb Version GitHub License

mojaloop/build is a CircleCI orb for node.js build jobs in Mojaloop CI/CD pipelines

Usage

To use the mojaloop/build orb in your CircleCI configuration, turn on Enable dynamic config using setup workflows in the Advanced Settings of your project settings CircleCI. Then include the following in your .circleci/config.yml:

version: 2.1
setup: true
orbs:
  build: mojaloop/[email protected]
workflows:
  setup:
    jobs:
      - build/workflow:
          filters:
            tags:
              only: /v\d+(\.\d+){2}(-[a-zA-Z-][0-9a-zA-Z-]*\.\d+)?/
          # optionally supply the base image for the image scan
          # base_image: org/image

Conventions

  • If a Dockerfile is present in the root of the repository, it will be used to build and publish an image.
  • If a package.json is present in the root of the repository and it does not have private=true, the package will be published to npm for the applicable branches and tags.
  • The following scripts are expected in the package.json file:
    • lint
    • dep:check
    • audit:check
    • test:xunit
    • test:integration
    • test:functional
    • test:coverage-check

Publish conditions

The orb will trigger a publish when one of the following conditions is met:

  • A release tag (e.g. v#.#.#) is pushed to the repository.
  • A snapshot tag (e.g. v#.#.#-snapshot.#, v#.#.#-hotfix.#, , v#.#.#-perf.#) is pushed to the repository.
  • A commit to a pre-release branch (e.g. major/*, minor/*, patch/*) passed the tests.

Resources

CircleCI Orb Registry Page - The official registry page of this orb for all versions, executors, commands, and jobs described.

CircleCI Orb Docs - Docs for using, creating, and publishing CircleCI Orbs.

How to Contribute

We welcome issues to and pull requests against this repository!

How to Publish An Update

  1. Merge pull requests with desired changes to the main branch.
  2. Find the current version of the orb.
    • You can run circleci orb info mojaloop/build | grep "Latest" to see the current version.
  3. Create a new Release on GitHub.
    • Click "Choose a tag" and create a new semantically versioned tag. (ex: v1.0.0)
    • We will have an opportunity to change this before we publish if needed after the next step.
  4. Click "+ Auto-generate release notes".
    • This will create a summary of all of the merged pull requests since the previous release.
    • If you have used Conventional Commit Messages it will be easy to determine what types of changes were made, allowing you to ensure the correct version tag is being published.
  5. Now ensure the version tag selected is semantically accurate based on the changes included.
  6. Click "Publish Release".
    • This will push a new tag and trigger your publishing pipeline on CircleCI.