107 lines
5.0 KiB
Markdown
107 lines
5.0 KiB
Markdown
# npmci
|
|
|
|
node and docker in gitlab ci on steroids
|
|
|
|
## Availabililty
|
|
|
|
[](https://www.npmjs.com/package/@shipzone/npmci)
|
|
[](https://GitLab.com/shipzone/npmci)
|
|
[](https://github.com/shipzone/npmci)
|
|
[](https://shipzone.gitlab.io/npmci/)
|
|
|
|
## Status for master
|
|
|
|
[](https://GitLab.com/shipzone/npmci/commits/master)
|
|
[](https://GitLab.com/shipzone/npmci/commits/master)
|
|
[](https://www.npmjs.com/package/@shipzone/npmci)
|
|
[](https://david-dm.org/shipzone/npmci)
|
|
[](https://www.bithound.io/github/shipzone/npmci/master/dependencies/npm)
|
|
[](https://www.bithound.io/github/shipzone/npmci)
|
|
[](https://nodejs.org/dist/latest-v6.x/docs/api/)
|
|
[](https://nodejs.org/dist/latest-v6.x/docs/api/)
|
|
[](http://standardjs.com/)
|
|
|
|
## Usage
|
|
|
|
Use TypeScript for best in class instellisense.
|
|
|
|
npmci is designed to work in docker CI environments. The following docker images come with npmci presinstalled:
|
|
|
|
Docker Hub:
|
|
|
|
* [hosttoday/ht-docker-node:npmci](https://hub.docker.com/r/hosttoday/ht-docker-node/)
|
|
has LTS node version and npmci preinstalled.
|
|
* [hosttoday/ht-docker-dbase](https://hub.docker.com/r/hosttoday/ht-docker-dbase/)
|
|
based on docker:git, can be used to build docker images in conjunction with docker:dind
|
|
|
|
npmci can be called from commandline and handle a lot of tasks durug ci:
|
|
|
|
```shell
|
|
# Handle node versions
|
|
npmci node install stable # will install latest stable node version and update PATH for node and npm
|
|
npmci node install lts # will install latest LTS node version and update PATH for node and npm versions
|
|
npmci node install legacy # will install latest legacy node version and update PATH for node and npm
|
|
npmci node install x.x.x # will install any specific node version.
|
|
|
|
# Handle npm and yarn tasks
|
|
npmcu npm login # logs in npm using the auth key provided at env var "NPMCI_TOKEN_NPM"
|
|
npmci npm install # installs dependencies using npm or yarn dependending on availablity
|
|
npmci npm test # tests the package
|
|
npmci npm publish # builds a package and publishes it
|
|
|
|
# handle docker tasks
|
|
npmci docker prepare
|
|
## npmci test docker will look at all Dockerfiles and look for according tags on GitLab container registry
|
|
|
|
|
|
# prepare tools
|
|
npmci prepare npm # will look for $NPMCI_TOKEN_NPM env var and create .npmrc, so npm is authenticated
|
|
npmci prepare docker # will look for $NPMCI_LOGIN_DOCKER in form username|password and authenticate docker
|
|
npmci prepare docker-gitlab # will authenticate docker for gitlab container registry
|
|
|
|
# build containers
|
|
npmci docker build # will build containers
|
|
## all Dockerfiles named Dockerfile* are picked up.
|
|
## specify tags like this Dockerfile_[tag]
|
|
## uploads all built images as [username]/[reponame]:[tag]_test to GitLab
|
|
## then test in next step with "npmci test docker"
|
|
|
|
# publish npm module
|
|
npmci publish npm # will look vor $NPMCI_TOKEN_NPM env var and push any module in cwd to npm
|
|
npmci publish docker
|
|
|
|
# trigger webhooks
|
|
npmci trigger # will look for NPMCI_TRIGGER_1 to NPMCI_TRIGGER_100 in form domain|id|token|ref|name
|
|
```
|
|
|
|
## Configuration
|
|
|
|
npmci supports the use of npmextra.
|
|
|
|
To configure npmci create a `npmextra.json` file at the root of your project
|
|
|
|
```json
|
|
{
|
|
"npmci": {
|
|
"globalNpmTools": ["npm-check-updates", "protractor", "npmts", "gitzone"]
|
|
}
|
|
}
|
|
```
|
|
|
|
**Available options**
|
|
|
|
| setting | example | description |
|
|
| -------------- | ----------------------------- | ------------------------------------------------------------------------------------------------- |
|
|
| globalNpmTools | "globalNpmTools": ["gitbook"] | Will look for the specified package names locally and (if not yet present) install them from npm. |
|
|
|
|
For further information read the linked docs at the top of this README.
|
|
|
|
Use TypeScript for best in class instellisense.
|
|
|
|
For further information read the linked docs at the top of this README.
|
|
|
|
> MIT licensed | **©** [Lossless GmbH](https://lossless.gmbh)
|
|
> | By using this npm module you agree to our [privacy policy](https://lossless.gmbH/privacy.html)
|
|
|
|
[](https://push.rocks)
|