CI/CD image, scripts, and templates for @wondermonger projects.
The CI/CD scripts are made available as a docker image (wongermonger/ci-tools) that extends node:alpine.
Use it in a GitLab CI/CD Pipeline.
Example .gitlab-ci.yml
include:
- https://wondermonger.gitlab.io/ci-tools/v12.0.3/tpl/node/base.yml
- https://wondermonger.gitlab.io/ci-tools/v12.0.3/tpl/node/post-install/lint.yml
- https://wondermonger.gitlab.io/ci-tools/v12.0.3/tpl/node/test/simple.yml
- https://wondermonger.gitlab.io/ci-tools/v12.0.3/tpl/node/test/coverage.yml
- https://wondermonger.gitlab.io/ci-tools/v12.0.3/tpl/node/build/public.yml
- https://wondermonger.gitlab.io/ci-tools/v12.0.3/tpl/node/post-build/pages.yml
- https://wondermonger.gitlab.io/ci-tools/v12.0.3/tpl/node/deploy/publish.yml
Example docker run
docker run \
-e ACCESS_EMAIL \
-e ACCESS_NAME \
-e CI_COMMIT_REF_NAME \
-e CI_PROJECT_PATH \
-e SSH_PRIVATE_KEY \
-v "/var/run/docker.sock:/var/run/docker.sock" \
-v "$(pwd):/usr/local/my-project" \
-w "/usr/local/my-project" \
registry.gitlab.com/wondermonger/ci-tools:latest \
/bin/bash -c "ci-git-config && ci-git-release -t shell -a lib -a bin"
Available Images
Tag Pattern | Description | Examples |
---|---|---|
latest |
Latest Release | latest |
vX |
Latest Minor or Patch Release Within a Given Major Version | v12 v5 v4 |
vX.Y |
Latest Patch Release Within a Given Minor Version | v12.0 v5.1 v4.0 |
vX.Y.Z |
Specific Patch Release | v12.0.3 v5.1.2 v4.0.1 |
vX.Y.Z-A * |
Specific Prerelease | v12.0.3-0 v5.1.2-alpha v4.0.1-beta |
* if prereleases are published, they should not be used for anything other than development
- Docker
- Git
- Node
- Shell
Description: Builds and tags a docker image from the current working directory.
Prerequisites: None
Environment Variables: CI_COMMIT_TAG
CI_PROJECT_NAME
DOCKER_ORGANIZATION
Arguments: None
Description: Establishes a session with the Docker registry.
Prerequisites: None
Environment Variables: DOCKER_PASSWORD
DOCKER_REGISTRY
DOCKER_USERNAME
Arguments: None
Description: Publishes an image to the Docker registry.
Prerequisites: ci-docker-config
Environment Variables: CI_PROJECT_NAME
DOCKER_ORGANIZATION
Arguments: None
Description: Configures global user name and email for git.
Prerequisites: None
Environment Variables: GIT_USER_EMAIL
GIT_USER_NAME
Arguments: None
Description: Creates and pushes a tagged git release.
Prerequisites: ci-git-config
Environment Variables: CI_PROJECT_PATH
CI_COMMIT_REF_NAME
GIT_SSH_HOST
GIT_SSH_USER
SSH_PRIVATE_KEY
Arguments:
-a
: path to uncommitted artifact(s) that should be included in the release- use the
-a
flag multiple times to specify multiple artifacts - Example:
ci-git-release -a lib -a bin
- use the
-t
: type of release- either
node
for node projects, orshell
for everything else - default value is
node
- either
Description: Specifies an auth token to use for publishing packages to the default npm registry.
Prerequisites: None
Environment Variables: NPM_REGISTRY
NPM_TOKEN
Arguments: None
Description: Publishes a package to the default npm registry.
Prerequisites: ci-node-config
Environment Variables: None
Arguments: None
Description: Executes shellcheck
against all shell scripts in a given project.
Prerequisites: None
Environment Variables: None
Arguments: None
Variable | Description | Required By |
---|---|---|
CI_COMMIT_TAG * |
Version Tag | ci-docker-build |
CI_COMMIT_REF_NAME * |
Branch or Tag Name | ci-git-release |
CI_PROJECT_NAME * |
Name of Project | ci-docker-build ci-docker-release |
CI_PROJECT_PATH * |
Namespace and Project Name | ci-git-release |
DOCKER_ORGANIZATION |
Name of Docker Organization | ci-docker-build ci-docker-release |
DOCKER_PASSWORD |
Docker Password | ci-docker-config |
DOCKER_REGISTRY |
Docker Registry (default: hub.docker.com) | ci-docker-config |
DOCKER_USERNAME |
Docker Username | ci-docker-config |
GIT_SSH_HOST |
Git SSH Host (default: gitlab.com) | ci-git-release |
GIT_SSH_USER |
Git SSH User (default: git) | ci-git-release |
GIT_USER_EMAIL |
Git User Email | ci-git-config |
GIT_USER_NAME |
Git User Name | ci-git-config |
NPM_REGISTRY |
NPM Registry (default: registry.npmjs.org) | ci-node-config |
NPM_TOKEN |
NPM Token for Publishing Project Package | ci-node-config |
SSH_PRIVATE_KEY |
Private SSH Key for Pushing Git Commits | ci-git-release |
* these variables are predefined if you are using GitLab CI
Versioned templates should be preferred:
Versioned (preferred): https://wondermonger.gitlab.io/ci-tools/v12.0.3/tpl/node/base.yml
Master (latest): https://wondermonger.gitlab.io/ci-tools/tpl/node/base.yml
URL | Description |
---|---|
https://wondermonger.gitlab.io/ci-tools/v12.0.3/tpl/node/base.yml | Base template for Node.js projects that provides installation, dependency auditing, outdated dependency notification, patch versioning, and git release tagging. |
https://wondermonger.gitlab.io/ci-tools/v12.0.3/tpl/node/post-install/lint.yml | Invokes npm run lint during the post-install stage. |
https://wondermonger.gitlab.io/ci-tools/v12.0.3/tpl/node/test/simple.yml | Invokes npm test during the test stage. |
https://wondermonger.gitlab.io/ci-tools/v12.0.3/tpl/node/test/expanded.yml | Invokes npm run test:integration and npm run test:unit during the test stage. |
https://wondermonger.gitlab.io/ci-tools/v12.0.3/tpl/node/test/coverage.yml | Invokes npm run test:coverage and extracts coverage data during the test stage. This template will persist artifacts created in the ./public/coverage directory. |
https://wondermonger.gitlab.io/ci-tools/v12.0.3/tpl/node/build/dist.yml | Invokes npm run build during the build stage. This template will persist artifacts created in the ./dist directory. |
https://wondermonger.gitlab.io/ci-tools/v12.0.3/tpl/node/build/public.yml | Invokes npm run build during the build stage. This template will persist artifacts created in the ./public directory. |
https://wondermonger.gitlab.io/ci-tools/v12.0.3/tpl/node/post-build/pages.yml | A generic GitLab pages job executed during the post-build stage. |
https://wondermonger.gitlab.io/ci-tools/v12.0.3/tpl/node/deploy/publish.yml | Configures npm and invokes npm publish during the deploy stage. |
The MIT License (MIT)
Copyright (c) 2017-2020 Michael J. Bondra mjbondra@gmail.com
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.