| 
									
										
										
										
											2016-05-30 03:40:07 +02:00
										 |  |  | # NPMCI
 | 
					
						
							| 
									
										
										
										
											2016-06-04 00:35:43 +02:00
										 |  |  | npmci is your friend when it comes to handling npm packages during CI builds. It is optimized for GitLab CI | 
					
						
							| 
									
										
										
										
											2016-05-30 10:57:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | ## Status
 | 
					
						
							|  |  |  | [](https://gitlab.com/pushrocks/npmci/commits/master) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ## Usage
 | 
					
						
							|  |  |  | npmci is designed to work in docker CI environments. The following docker images come with npmci presinstalled: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Docker Hub: | 
					
						
							| 
									
										
										
										
											2016-05-30 11:05:28 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | * [hosttoday/ht-docker-node](https://hub.docker.com/r/hosttoday/ht-docker-node/)   | 
					
						
							|  |  |  | has LTS node version preinstalled. Change it with npmci | 
					
						
							|  |  |  | * [hosttoday/ht-docker-node-python-3](https://hub.docker.com/r/hosttoday/ht-docker-node-python3/)   | 
					
						
							|  |  |  | like ht-docker-node, but with python3 instead of python2.7 | 
					
						
							| 
									
										
										
										
											2016-06-04 00:59:17 +02:00
										 |  |  | * [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 conjuction with docker:dind | 
					
						
							| 
									
										
										
										
											2016-05-30 10:57:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | npmci can be called from commandline: | 
					
						
							|  |  |  | ```shell | 
					
						
							|  |  |  | # Install any node version:
 | 
					
						
							|  |  |  | npmci install lts # will install latest LTS node version and update PATH for node and npm versions | 
					
						
							| 
									
										
										
										
											2016-06-04 00:35:43 +02:00
										 |  |  | npmci install stable # will install latest stable node version and update PATH for node and npm | 
					
						
							|  |  |  | npmci install legacy # will install latest legacy node version and update PATH for node and npm | 
					
						
							| 
									
										
										
										
											2016-05-30 10:57:08 +02:00
										 |  |  | npmci install x.x.x #  will install any specific node version. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Install any node version, install dependencies and run test in cwd:
 | 
					
						
							| 
									
										
										
										
											2016-05-30 11:08:21 +02:00
										 |  |  | npmci test lts # will install latest lts node version and run "npm install" and "npm test". | 
					
						
							| 
									
										
										
										
											2016-06-04 00:35:43 +02:00
										 |  |  | npmci test stable # will install latest stable node version and run "npm install" and "npm test". | 
					
						
							|  |  |  | npmci test legacy # will install latest legacy node version and run "npm install" and "npm test". | 
					
						
							|  |  |  | npmci test x.x.x # will install any specific node version and run "npm install" and "npm test". | 
					
						
							| 
									
										
										
										
											2016-06-04 00:41:25 +02:00
										 |  |  | npmci test docker # will test any build image with tests defined in ./npmci/dockertest_1.sh to ./npmci/dockertest_100.sh | 
					
						
							| 
									
										
										
										
											2016-06-04 00:35:43 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | # prepare tools
 | 
					
						
							| 
									
										
										
										
											2016-06-04 00:41:25 +02:00
										 |  |  | 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 | 
					
						
							| 
									
										
										
										
											2016-06-04 00:35:43 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | # build containers
 | 
					
						
							|  |  |  | npmci build docker # will build container and tag it | 
					
						
							| 
									
										
										
										
											2016-05-30 10:57:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | # publish npm module
 | 
					
						
							| 
									
										
										
										
											2016-06-04 00:35:43 +02:00
										 |  |  | npmci publish npm # will look vor $NPMCI_TOKEN_NPM env var and push any module in cwd to npm | 
					
						
							|  |  |  | npmci publish docker | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # trigger webhooks
 | 
					
						
							| 
									
										
										
										
											2016-06-04 00:41:25 +02:00
										 |  |  | npmci trigger # will look for NPMCI_TRIGGER_1 to NPMCI_TRIGGER_100 in form domain|id|token|ref|name   | 
					
						
							| 
									
										
										
										
											2016-05-30 10:57:08 +02:00
										 |  |  | ``` | 
					
						
							|  |  |  | 
 |