2019-02-24 22:50:12 +01:00
|
|
|
# @shipzone/npmci
|
2017-07-19 16:40:24 +02:00
|
|
|
node and docker in gitlab ci on steroids
|
2016-05-30 10:57:08 +02:00
|
|
|
|
2019-02-24 22:50:12 +01:00
|
|
|
## Availabililty and Links
|
|
|
|
* [npmjs.org (npm package)](https://www.npmjs.com/package/@shipzone/npmci)
|
|
|
|
* [gitlab.com (source)](https://gitlab.com/shipzone/npmci)
|
|
|
|
* [github.com (source mirror)](https://github.com/shipzone/npmci)
|
|
|
|
* [docs (typedoc)](https://shipzone.gitlab.io/npmci/)
|
2016-09-04 13:42:22 +02:00
|
|
|
|
|
|
|
## Status for master
|
2019-02-24 22:50:12 +01:00
|
|
|
[](https://gitlab.com/shipzone/npmci/commits/master)
|
|
|
|
[](https://gitlab.com/shipzone/npmci/commits/master)
|
|
|
|
[](https://www.npmjs.com/package/@shipzone/npmci)
|
|
|
|
[](https://snyk.io/test/npm/@shipzone/npmci)
|
|
|
|
[](https://nodejs.org/dist/latest-v10.x/docs/api/)
|
|
|
|
[](https://nodejs.org/dist/latest-v10.x/docs/api/)
|
|
|
|
[](https://prettier.io/)
|
2016-05-30 10:57:08 +02:00
|
|
|
|
|
|
|
## Usage
|
2018-04-04 22:25:13 +02:00
|
|
|
|
2017-04-03 00:06:00 +02:00
|
|
|
Use TypeScript for best in class instellisense.
|
|
|
|
|
2018-05-04 15:58:11 +02:00
|
|
|
npmci is designed to work in docker CI environments. The following docker images come with npmci presinstalled:
|
|
|
|
|
|
|
|
Docker Hub:
|
|
|
|
|
2018-07-16 00:04:24 +02:00
|
|
|
- [hosttoday/ht-docker-node:npmci](https://hub.docker.com/r/hosttoday/ht-docker-node/)
|
2018-05-04 15:58:11 +02:00
|
|
|
has LTS node version and npmci preinstalled.
|
2018-07-16 00:04:24 +02:00
|
|
|
- [hosttoday/ht-docker-dbase](https://hub.docker.com/r/hosttoday/ht-docker-dbase/)
|
2018-05-04 15:58:11 +02:00
|
|
|
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
|
2018-07-16 00:04:24 +02:00
|
|
|
npmci trigger # will look for NPMCI_TRIGGER_1 to NPMCI_TRIGGER_100 in form domain|id|token|ref|name
|
2018-05-04 15:58:11 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
## 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.
|
|
|
|
|
2019-02-24 22:50:12 +01:00
|
|
|
For further information read the linked docs at the top of this readme.
|
2017-04-03 00:06:00 +02:00
|
|
|
|
|
|
|
> MIT licensed | **©** [Lossless GmbH](https://lossless.gmbh)
|
2019-08-23 16:48:52 +02:00
|
|
|
| By using this npm module you agree to our [privacy policy](https://lossless.gmbH/privacy)
|
2017-04-03 00:06:00 +02:00
|
|
|
|
2019-08-23 16:48:52 +02:00
|
|
|
[](https://maintainedby.lossless.com)
|