| 
									
										
										
										
											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) |