Compare commits
	
		
			14 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| e541159019 | |||
| b6c06e2b17 | |||
| 3505b2effc | |||
| 29df49addb | |||
| 3484575108 | |||
| 7c4890f57a | |||
| 308d969540 | |||
| 5065587275 | |||
| 8f0092b2ef | |||
| e81d001aeb | |||
| 993f6f691e | |||
| 64053de75a | |||
| 1edea1046b | |||
| 0f8a76ca02 | 
| @@ -1,4 +1,4 @@ | |||||||
| image: node:latest | image: hosttoday/ht-docker-node:stable | ||||||
|  |  | ||||||
| stages: | stages: | ||||||
| - test | - test | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								dist/cli.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								dist/cli.js
									
									
									
									
										vendored
									
									
								
							| @@ -1,2 +1,3 @@ | |||||||
| #!/usr/bin/env node | #!/usr/bin/env node | ||||||
|  | process.env.CLI_CALL = 'true' | ||||||
| var index = require("../dist/index.js"); | var index = require("../dist/index.js"); | ||||||
							
								
								
									
										4
									
								
								dist/npmci.bash.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								dist/npmci.bash.d.ts
									
									
									
									
										vendored
									
									
								
							| @@ -10,10 +10,6 @@ export declare let yarnAvailable: plugins.q.Deferred<boolean>; | |||||||
|  * @param retryArg - The retryArg: 0 to any positive number will retry, -1 will always succeed, -2 will return undefined |  * @param retryArg - The retryArg: 0 to any positive number will retry, -1 will always succeed, -2 will return undefined | ||||||
|  */ |  */ | ||||||
| export declare let bash: (commandArg: string, retryArg?: number, bareArg?: boolean) => Promise<string>; | export declare let bash: (commandArg: string, retryArg?: number, bareArg?: boolean) => Promise<string>; | ||||||
| /** |  | ||||||
|  * bashBare allows usage of bash without sourcing any files like nvm |  | ||||||
|  */ |  | ||||||
| export declare let bashBare: (commandArg: string, retryArg?: number) => Promise<string>; |  | ||||||
| /** | /** | ||||||
|  * bashNoError allows executing stuff without throwing an error |  * bashNoError allows executing stuff without throwing an error | ||||||
|  */ |  */ | ||||||
|   | |||||||
							
								
								
									
										16
									
								
								dist/npmci.bash.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										16
									
								
								dist/npmci.bash.js
									
									
									
									
										vendored
									
									
								
							| @@ -42,10 +42,10 @@ let checkToolsAvailable = () => __awaiter(this, void 0, void 0, function* () { | |||||||
|         } |         } | ||||||
|         ; |         ; | ||||||
|         // check for yarn |         // check for yarn | ||||||
|         yield plugins.smartshell.which('yarn').then(() => { |         yield plugins.smartshell.which('yarn').then(() => __awaiter(this, void 0, void 0, function* () { | ||||||
|             plugins.smartshell.exec(`yarn config set cache-folder ${plugins.path.join(paths.cwd, '.yarn')}`); |             yield plugins.smartshell.exec(`yarn config set cache-folder ${plugins.path.join(paths.cwd, '.yarn')}`); | ||||||
|             exports.yarnAvailable.resolve(true); |             exports.yarnAvailable.resolve(true); | ||||||
|         }, () => { exports.yarnAvailable.resolve(false); }); |         }), () => { exports.yarnAvailable.resolve(false); }); | ||||||
|     } |     } | ||||||
|     else { |     else { | ||||||
|         exports.nvmAvailable.resolve(true); |         exports.nvmAvailable.resolve(true); | ||||||
| @@ -73,7 +73,7 @@ exports.bash = (commandArg, retryArg = 2, bareArg = false) => __awaiter(this, vo | |||||||
|                 execResult = yield npmciSmartshell.exec(commandArg); |                 execResult = yield npmciSmartshell.exec(commandArg); | ||||||
|             } |             } | ||||||
|             else { |             else { | ||||||
|                 execResult = yield plugins.smartshell.exec(commandArg); |                 execResult = yield npmciSmartshell.exec(commandArg); | ||||||
|             } |             } | ||||||
|             // determine how bash reacts to error and success |             // determine how bash reacts to error and success | ||||||
|             if (execResult.exitCode !== 0 && i === retryArg) { |             if (execResult.exitCode !== 0 && i === retryArg) { | ||||||
| @@ -101,16 +101,10 @@ exports.bash = (commandArg, retryArg = 2, bareArg = false) => __awaiter(this, vo | |||||||
|     } |     } | ||||||
|     return execResult.stdout; |     return execResult.stdout; | ||||||
| }); | }); | ||||||
| /** |  | ||||||
|  * bashBare allows usage of bash without sourcing any files like nvm |  | ||||||
|  */ |  | ||||||
| exports.bashBare = (commandArg, retryArg = 2) => __awaiter(this, void 0, void 0, function* () { |  | ||||||
|     return yield exports.bash(commandArg, retryArg, true); |  | ||||||
| }); |  | ||||||
| /** | /** | ||||||
|  * bashNoError allows executing stuff without throwing an error |  * bashNoError allows executing stuff without throwing an error | ||||||
|  */ |  */ | ||||||
| exports.bashNoError = (commandArg) => __awaiter(this, void 0, void 0, function* () { | exports.bashNoError = (commandArg) => __awaiter(this, void 0, void 0, function* () { | ||||||
|     return yield exports.bash(commandArg, -1); |     return yield exports.bash(commandArg, -1); | ||||||
| }); | }); | ||||||
| //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kuYmFzaC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL25wbWNpLmJhc2gudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7OztBQUFBLDJDQUEwQztBQUMxQyx1Q0FBc0M7QUFFdEMsaUNBQWdDO0FBRWhDOztHQUVHO0FBQ1EsUUFBQSxZQUFZLEdBQUcsTUFBTSxDQUFDLEtBQUssRUFBVyxDQUFBO0FBQ3RDLFFBQUEsYUFBYSxHQUFHLE1BQU0sQ0FBQyxLQUFLLEVBQVcsQ0FBQTtBQUNsRDs7R0FFRztBQUNILElBQUksZUFBZSxHQUFHLElBQUksT0FBTyxDQUFDLFVBQVUsQ0FBQyxVQUFVLENBQUM7SUFDdEQsUUFBUSxFQUFFLE1BQU07SUFDaEIsZUFBZSxFQUFFLEVBQUU7Q0FDcEIsQ0FBQyxDQUFBO0FBRUY7O0dBRUc7QUFDSCxJQUFJLG1CQUFtQixHQUFHO0lBQ3hCLGdCQUFnQjtJQUNoQixFQUFFLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztRQUM1QixFQUFFLENBQUMsQ0FDRCxDQUFDLE1BQU0sT0FBTyxDQUFDLFVBQVUsQ0FBQyxVQUFVLENBQUMsd0NBQXdDLENBQUMsQ0FBQyxDQUFDLFFBQVEsS0FBSyxDQUMvRixDQUFDLENBQUMsQ0FBQztZQUNELGVBQWUsQ0FBQyxjQUFjLENBQUMsQ0FBRSx1QkFBdUIsQ0FBRSxDQUFDLENBQUE7WUFDM0Qsb0JBQVksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUE7UUFDNUIsQ0FBQztRQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FDUixDQUFDLE1BQU0sT0FBTyxDQUFDLFVBQVUsQ0FBQyxVQUFVLENBQUMsZ0NBQWdDLENBQUMsQ0FBQyxDQUFDLFFBQVEsS0FBSyxDQUN2RixDQUFDLENBQUMsQ0FBQztZQUNELGVBQWUsQ0FBQyxjQUFjLENBQUMsQ0FBRSxlQUFlLENBQUUsQ0FBQyxDQUFBO1lBQ25ELG9CQUFZ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 | //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtY2kuYmFzaC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL25wbWNpLmJhc2gudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7OztBQUFBLDJDQUEwQztBQUMxQyx1Q0FBc0M7QUFFdEMsaUNBQWdDO0FBRWhDOztHQUVHO0FBQ1EsUUFBQSxZQUFZLEdBQUcsTUFBTSxDQUFDLEtBQUssRUFBVyxDQUFBO0FBQ3RDLFFBQUEsYUFBYSxHQUFHLE1BQU0sQ0FBQyxLQUFLLEVBQVcsQ0FBQTtBQUNsRDs7R0FFRztBQUNILElBQUksZUFBZSxHQUFHLElBQUksT0FBTyxDQUFDLFVBQVUsQ0FBQyxVQUFVLENBQUM7SUFDdEQsUUFBUSxFQUFFLE1BQU07SUFDaEIsZUFBZSxFQUFFLEVBQUU7Q0FDcEIsQ0FBQyxDQUFBO0FBRUY7O0dBRUc7QUFDSCxJQUFJLG1CQUFtQixHQUFHO0lBQ3hCLGdCQUFnQjtJQUNoQixFQUFFLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztRQUM1QixFQUFFLENBQUMsQ0FDRCxDQUFDLE1BQU0sT0FBTyxDQUFDLFVBQVUsQ0FBQyxVQUFVLENBQUMsd0NBQXdDLENBQUMsQ0FBQyxDQUFDLFFBQVEsS0FBSyxDQUMvRixDQUFDLENBQUMsQ0FBQztZQUNELGVBQWUsQ0FBQyxjQUFjLENBQUMsQ0FBRSx1QkFBdUIsQ0FBRSxDQUFDLENBQUE7WUFDM0Qsb0JBQVksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUE7UUFDNUIsQ0FBQztRQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FDUixDQUFDLE1BQU0sT0FBTyxDQUFDLFVBQVUsQ0FBQyxVQUFVLENBQUMsZ0NBQWdDLENBQUMsQ0FBQyxDQUFDLFFBQVEsS0FBSyxDQUN2RixDQUFDLENBQUMsQ0FBQztZQUNELGVBQWUsQ0FBQyxjQUFjLENBQUMsQ0FBRSxlQUFlLENBQUUsQ0FBQyxDQUFBO1lBQ25ELG9CQUFZ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 | ||||||
							
								
								
									
										42
									
								
								dist/npmci.build.docker.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										42
									
								
								dist/npmci.build.docker.js
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										22
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										22
									
								
								package.json
									
									
									
									
									
								
							| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "npmci", |   "name": "npmci", | ||||||
|   "version": "2.3.56", |   "version": "2.3.63", | ||||||
|   "description": "", |   "description": "", | ||||||
|   "main": "dist/index.js", |   "main": "dist/index.js", | ||||||
|   "typings": "dist/index.d.ts", |   "typings": "dist/index.d.ts", | ||||||
| @@ -22,26 +22,26 @@ | |||||||
|   }, |   }, | ||||||
|   "homepage": "https://gitlab.com/gitzone/npmci#README", |   "homepage": "https://gitlab.com/gitzone/npmci#README", | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "tapbundle": "^1.0.5", |     "tapbundle": "^1.0.12", | ||||||
|     "typings-test": "^1.0.3" |     "typings-test": "^1.0.3" | ||||||
|   }, |   }, | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@types/lodash": "^4.14.55", |     "@types/lodash": "^4.14.64", | ||||||
|     "@types/node": "^7.0.8", |     "@types/node": "^7.0.18", | ||||||
|     "@types/request": "0.x.x", |     "@types/request": "0.x.x", | ||||||
|     "@types/shelljs": "^0.7.0", |     "@types/shelljs": "^0.7.1", | ||||||
|     "@types/through2": "^2.0.32", |     "@types/through2": "^2.0.32", | ||||||
|     "beautylog": "^6.1.5", |     "beautylog": "^6.1.10", | ||||||
|     "gulp": "^3.9.1", |     "gulp": "^3.9.1", | ||||||
|     "gulp-function": "^2.2.3", |     "gulp-function": "^2.2.9", | ||||||
|     "lodash": "^4.17.4", |     "lodash": "^4.17.4", | ||||||
|     "npmextra": "^2.0.3", |     "npmextra": "^2.0.5", | ||||||
|     "projectinfo": "^3.0.2", |     "projectinfo": "^3.0.2", | ||||||
|     "request": "^2.81.0", |     "request": "^2.81.0", | ||||||
|     "shelljs": "^0.7.7", |     "shelljs": "^0.7.7", | ||||||
|     "smartcli": "^2.0.1", |     "smartcli": "^2.0.7", | ||||||
|     "smartdelay": "^1.0.1", |     "smartdelay": "^1.0.1", | ||||||
|     "smartfile": "^4.1.7", |     "smartfile": "^4.2.11", | ||||||
|     "smartparam": "^0.1.1", |     "smartparam": "^0.1.1", | ||||||
|     "smartq": "^1.1.1", |     "smartq": "^1.1.1", | ||||||
|     "smartshell": "^1.0.6", |     "smartshell": "^1.0.6", | ||||||
| @@ -49,6 +49,6 @@ | |||||||
|     "smartssh": "^1.2.1", |     "smartssh": "^1.2.1", | ||||||
|     "smartstring": "^2.0.24", |     "smartstring": "^2.0.24", | ||||||
|     "through2": "^2.0.3", |     "through2": "^2.0.3", | ||||||
|     "typings-global": "^1.0.14" |     "typings-global": "^1.0.16" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										89
									
								
								test/test.js
									
									
									
									
									
								
							
							
						
						
									
										89
									
								
								test/test.js
									
									
									
									
									
								
							| @@ -1,89 +0,0 @@ | |||||||
| "use strict"; |  | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); |  | ||||||
| require("typings-test"); |  | ||||||
| const should = require("should"); |  | ||||||
| const path = require("path"); |  | ||||||
| // set up environment |  | ||||||
| process.env.CI_BUILD_REPO = 'https://yyyyyy:xxxxxxxx@gitlab.com/mygroup/myrepo.git'; |  | ||||||
| process.env.NPMCI_SSHKEY_1 = 'hostString|somePrivKey|##'; |  | ||||||
| process.env.NPMTS_TEST = 'true'; |  | ||||||
| process.cwd = () => { |  | ||||||
|     return path.join(__dirname, 'assets/'); |  | ||||||
| }; |  | ||||||
| const NpmciBuildDocker = require("../dist/npmci.build.docker"); |  | ||||||
| const NpmciPublish = require("../dist/npmci.publish"); |  | ||||||
| const NpmciTest = require("../dist/npmci.test"); |  | ||||||
| const NpmciSsh = require("../dist/npmci.ssh"); |  | ||||||
| let dockerfile1; |  | ||||||
| let dockerfile2; |  | ||||||
| let sortableArray; |  | ||||||
| describe('NPMCI', function () { |  | ||||||
|     describe('build.docker', function () { |  | ||||||
|         it('should return valid Dockerfiles', function () { |  | ||||||
|             dockerfile1 = new NpmciBuildDocker.Dockerfile({ filePath: './Dockerfile', read: true }); |  | ||||||
|             dockerfile2 = new NpmciBuildDocker.Dockerfile({ filePath: './Dockerfile_sometag1', read: true }); |  | ||||||
|             should(dockerfile1.version).equal('latest'); |  | ||||||
|             should(dockerfile2.version).equal('sometag1'); |  | ||||||
|         }); |  | ||||||
|         it('should read a directory of Dockerfiles', function (done) { |  | ||||||
|             NpmciBuildDocker.readDockerfiles() |  | ||||||
|                 .then(function (readDockerfilesArrayArg) { |  | ||||||
|                 should(readDockerfilesArrayArg[1].version).equal('sometag1'); |  | ||||||
|                 sortableArray = readDockerfilesArrayArg; |  | ||||||
|                 done(); |  | ||||||
|             }); |  | ||||||
|         }); |  | ||||||
|         it('should sort an array of Dockerfiles', function (done) { |  | ||||||
|             NpmciBuildDocker.sortDockerfiles(sortableArray) |  | ||||||
|                 .then(function (sortedArrayArg) { |  | ||||||
|                 console.log(sortedArrayArg); |  | ||||||
|                 done(); |  | ||||||
|             }); |  | ||||||
|         }); |  | ||||||
|         it('should correctly chain Dockerfile handling', function (done) { |  | ||||||
|             NpmciBuildDocker.build() |  | ||||||
|                 .then(() => { |  | ||||||
|                 done(); |  | ||||||
|             }); |  | ||||||
|         }); |  | ||||||
|     }); |  | ||||||
|     describe('.publish.docker', function () { |  | ||||||
|         it('should publish all built Dockerfiles', function (done) { |  | ||||||
|             NpmciPublish.publish('docker') |  | ||||||
|                 .then(() => { |  | ||||||
|                 done(); |  | ||||||
|             }); |  | ||||||
|         }); |  | ||||||
|     }); |  | ||||||
|     describe('.test.npm', function () { |  | ||||||
|         it('should source nvm using bash and install a specific node version, then test it', function (done) { |  | ||||||
|             NpmciTest.test('legacy') |  | ||||||
|                 .then(() => { |  | ||||||
|                 return NpmciTest.test('lts'); |  | ||||||
|             }) |  | ||||||
|                 .then(() => { |  | ||||||
|                 return NpmciTest.test('stable'); |  | ||||||
|             }) |  | ||||||
|                 .then(() => { |  | ||||||
|                 done(); |  | ||||||
|             }); |  | ||||||
|         }); |  | ||||||
|     }); |  | ||||||
|     describe('test.docker', function () { |  | ||||||
|         it('should test dockerfiles', function (done) { |  | ||||||
|             NpmciTest.test('docker') |  | ||||||
|                 .then(() => { |  | ||||||
|                 done(); |  | ||||||
|             }); |  | ||||||
|         }); |  | ||||||
|     }); |  | ||||||
|     describe('npmci prepare ssh', function () { |  | ||||||
|         it('should pick up SSH keys', function (done) { |  | ||||||
|             NpmciSsh.ssh() |  | ||||||
|                 .then(() => { |  | ||||||
|                 done(); |  | ||||||
|             }); |  | ||||||
|         }); |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSx3QkFBcUI7QUFDckIsaUNBQWdDO0FBQ2hDLDZCQUE0QjtBQUU1QixxQkFBcUI7QUFDckIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxhQUFhLEdBQUcsdURBQXVELENBQUE7QUFDbkYsT0FBTyxDQUFDLEdBQUcsQ0FBQyxjQUFjLEdBQUcsMkJBQTJCLENBQUE7QUFDeEQsT0FBTyxDQUFDLEdBQUcsQ0FBQyxVQUFVLEdBQUcsTUFBTSxDQUFBO0FBQy9CLE9BQU8sQ0FBQyxHQUFHLEdBQUc7SUFDVixNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUMsU0FBUyxDQUFDLENBQUE7QUFDekMsQ0FBQyxDQUFBO0FBSUQsK0RBQStEO0FBQy9ELHNEQUFzRDtBQUN0RCxnREFBZ0Q7QUFDaEQsOENBQThDO0FBRzlDLElBQUksV0FBd0MsQ0FBQTtBQUM1QyxJQUFJLFdBQXdDLENBQUE7QUFDNUMsSUFBSSxhQUE0QyxDQUFBO0FBRWhELFFBQVEsQ0FBQyxPQUFPLEVBQUM7SUFDYixRQUFRLENBQUMsY0FBYyxFQUFDO1FBQ3BCLEVBQUUsQ0FBQyxpQ0FBaUMsRUFBQztZQUNqQyxXQUFXLEdBQUcsSUFBSSxnQkFBZ0IsQ0FBQyxVQUFVLENBQUMsRUFBQyxRQUFRLEVBQUUsY0FBYyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUMsQ0FBQyxDQUFBO1lBQ3JGLFdBQVcsR0FBRyxJQUFJLGdCQUFnQixDQUFDLFVBQVUsQ0FBQyxFQUFDLFFBQVEsRUFBRSx1QkFBdUIsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFDLENBQUMsQ0FBQTtZQUM5RixNQUFNLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQTtZQUMzQyxNQUFNLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDLEtBQUssQ0FBQyxV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 |  | ||||||
							
								
								
									
										20
									
								
								test/test.ts
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								test/test.ts
									
									
									
									
									
								
							| @@ -27,7 +27,7 @@ tap.test('should return valid Dockerfiles', async () => { | |||||||
|   dockerfile2 = new NpmciBuildDocker.Dockerfile({ filePath: './Dockerfile_sometag1', read: true }) |   dockerfile2 = new NpmciBuildDocker.Dockerfile({ filePath: './Dockerfile_sometag1', read: true }) | ||||||
|   expect(dockerfile1.version).to.equal('latest') |   expect(dockerfile1.version).to.equal('latest') | ||||||
|   return expect(dockerfile2.version).to.equal('sometag1') |   return expect(dockerfile2.version).to.equal('sometag1') | ||||||
| }).catch(tap.threw) | }) | ||||||
|  |  | ||||||
| tap.test('should read a directory of Dockerfiles', async () => { | tap.test('should read a directory of Dockerfiles', async () => { | ||||||
|   return NpmciBuildDocker.readDockerfiles() |   return NpmciBuildDocker.readDockerfiles() | ||||||
| @@ -35,22 +35,22 @@ tap.test('should read a directory of Dockerfiles', async () => { | |||||||
|       sortableArray = readDockerfilesArrayArg |       sortableArray = readDockerfilesArrayArg | ||||||
|       return expect(readDockerfilesArrayArg[ 1 ].version).to.equal('sometag1') |       return expect(readDockerfilesArrayArg[ 1 ].version).to.equal('sometag1') | ||||||
|     }) |     }) | ||||||
| }).catch(tap.threw) | }) | ||||||
|  |  | ||||||
| tap.test('should sort an array of Dockerfiles', async () => { | tap.test('should sort an array of Dockerfiles', async () => { | ||||||
|   return NpmciBuildDocker.sortDockerfiles(sortableArray) |   return NpmciBuildDocker.sortDockerfiles(sortableArray) | ||||||
|     .then(async (sortedArrayArg: NpmciBuildDocker.Dockerfile[]) => { |     .then(async (sortedArrayArg: NpmciBuildDocker.Dockerfile[]) => { | ||||||
|       console.log(sortedArrayArg) |       console.log(sortedArrayArg) | ||||||
|     }) |     }) | ||||||
| }).catch(tap.threw) | }) | ||||||
|  |  | ||||||
| tap.test('should correctly chain Dockerfile handling', async () => { | tap.test('should correctly chain Dockerfile handling', async () => { | ||||||
|   return NpmciBuildDocker.build() |   return NpmciBuildDocker.build() | ||||||
| }).catch(tap.threw) | }) | ||||||
|  |  | ||||||
| tap.test('should publish all built Dockerfiles', async () => { | tap.test('should publish all built Dockerfiles', async () => { | ||||||
|   return NpmciPublish.publish('docker') |   return NpmciPublish.publish('docker') | ||||||
| }).catch(tap.threw) | }) | ||||||
|  |  | ||||||
| tap.test('should source nvm using bash and install a specific node version, then test it', async () => { | tap.test('should source nvm using bash and install a specific node version, then test it', async () => { | ||||||
|   return NpmciTest.test('legacy') |   return NpmciTest.test('legacy') | ||||||
| @@ -60,18 +60,20 @@ tap.test('should source nvm using bash and install a specific node version, then | |||||||
|     .then(() => { |     .then(() => { | ||||||
|       return NpmciTest.test('stable') |       return NpmciTest.test('stable') | ||||||
|     }) |     }) | ||||||
| }).catch(tap.threw) | }) | ||||||
|  |  | ||||||
| tap.test('should test dockerfiles', async () => { | tap.test('should test dockerfiles', async () => { | ||||||
|   return NpmciTest.test('docker') |   return NpmciTest.test('docker') | ||||||
| }).catch(tap.threw) | }) | ||||||
|  |  | ||||||
| tap.test('should pick up SSH keys', async () => { | tap.test('should pick up SSH keys', async () => { | ||||||
|   return NpmciSsh.ssh() |   return NpmciSsh.ssh() | ||||||
| }).catch(tap.threw) | }) | ||||||
|  |  | ||||||
| tap.test('reset paths', async () => { | tap.test('reset paths', async () => { | ||||||
|   process.cwd = () => { |   process.cwd = () => { | ||||||
|     return path.join(__dirname, '../') |     return path.join(__dirname, '../') | ||||||
|   } |   } | ||||||
| }).catch(tap.threw) | }) | ||||||
|  |  | ||||||
|  | tap.start() | ||||||
|   | |||||||
| @@ -38,8 +38,8 @@ let checkToolsAvailable = async () => { | |||||||
|  |  | ||||||
|     // check for yarn |     // check for yarn | ||||||
|     await plugins.smartshell.which('yarn').then( |     await plugins.smartshell.which('yarn').then( | ||||||
|       () => { |       async () => { | ||||||
|         plugins.smartshell.exec(`yarn config set cache-folder ${plugins.path.join(paths.cwd, '.yarn')}`) |         await plugins.smartshell.exec(`yarn config set cache-folder ${plugins.path.join(paths.cwd, '.yarn')}`) | ||||||
|         yarnAvailable.resolve(true) |         yarnAvailable.resolve(true) | ||||||
|       }, |       }, | ||||||
|       () => { yarnAvailable.resolve(false) } |       () => { yarnAvailable.resolve(false) } | ||||||
| @@ -72,7 +72,7 @@ export let bash = async (commandArg: string, retryArg: number = 2, bareArg: bool | |||||||
|       if (!bareArg) { |       if (!bareArg) { | ||||||
|         execResult = await npmciSmartshell.exec(commandArg) |         execResult = await npmciSmartshell.exec(commandArg) | ||||||
|       } else { |       } else { | ||||||
|         execResult = await plugins.smartshell.exec(commandArg) |         execResult = await npmciSmartshell.exec(commandArg) | ||||||
|       } |       } | ||||||
|  |  | ||||||
|       // determine how bash reacts to error and success |       // determine how bash reacts to error and success | ||||||
| @@ -99,13 +99,6 @@ export let bash = async (commandArg: string, retryArg: number = 2, bareArg: bool | |||||||
|   return execResult.stdout |   return execResult.stdout | ||||||
| } | } | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * bashBare allows usage of bash without sourcing any files like nvm |  | ||||||
|  */ |  | ||||||
| export let bashBare = async (commandArg: string, retryArg: number = 2): Promise<string> => { |  | ||||||
|   return await bash(commandArg, retryArg, true) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * bashNoError allows executing stuff without throwing an error |  * bashNoError allows executing stuff without throwing an error | ||||||
|  */ |  */ | ||||||
|   | |||||||
| @@ -1,12 +1,13 @@ | |||||||
| import * as plugins from './npmci.plugins' | import * as plugins from './npmci.plugins' | ||||||
| import * as paths from './npmci.paths' | import * as paths from './npmci.paths' | ||||||
| import * as NpmciEnv from './npmci.env' | import * as NpmciEnv from './npmci.env' | ||||||
| import { bashBare } from './npmci.bash' | import { bash } from './npmci.bash' | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * builds a cwd of Dockerfiles by triggering a promisechain |  * builds a cwd of Dockerfiles by triggering a promisechain | ||||||
|  */ |  */ | ||||||
| export let build = async () => { | export let build = async () => { | ||||||
|  |   plugins.beautylog.log('now building Dockerfiles...') | ||||||
|   await readDockerfiles() |   await readDockerfiles() | ||||||
|     .then(sortDockerfiles) |     .then(sortDockerfiles) | ||||||
|     .then(mapDockerfiles) |     .then(mapDockerfiles) | ||||||
| @@ -19,13 +20,15 @@ export let build = async () => { | |||||||
|  * @returns Promise<Dockerfile[]> |  * @returns Promise<Dockerfile[]> | ||||||
|  */ |  */ | ||||||
| export let readDockerfiles = async (): Promise<Dockerfile[]> => { | export let readDockerfiles = async (): Promise<Dockerfile[]> => { | ||||||
|   let fileTree = await plugins.smartfile.fs.listFileTree(paths.cwd, './Dockerfile*') |   let fileTree = await plugins.smartfile.fs.listFileTree(paths.cwd, 'Dockerfile*') | ||||||
|  |  | ||||||
|   // create the Dockerfile array |   // create the Dockerfile array | ||||||
|   let readDockerfilesArray: Dockerfile[] = [] |   let readDockerfilesArray: Dockerfile[] = [] | ||||||
|  |   plugins.beautylog.info(`found ${fileTree.length} Dockerfiles:`) | ||||||
|  |   console.log(fileTree) | ||||||
|   for (let dockerfilePath of fileTree) { |   for (let dockerfilePath of fileTree) { | ||||||
|     let myDockerfile = new Dockerfile({ |     let myDockerfile = new Dockerfile({ | ||||||
|       filePath: dockerfilePath, |       filePath: plugins.path.join(paths.cwd, dockerfilePath), | ||||||
|       read: true |       read: true | ||||||
|     }) |     }) | ||||||
|     readDockerfilesArray.push(myDockerfile) |     readDockerfilesArray.push(myDockerfile) | ||||||
| @@ -141,7 +144,7 @@ export class Dockerfile { | |||||||
|   baseImage: string |   baseImage: string | ||||||
|   localBaseImageDependent: boolean |   localBaseImageDependent: boolean | ||||||
|   localBaseDockerfile: Dockerfile |   localBaseDockerfile: Dockerfile | ||||||
|   constructor(options: { filePath?: string, fileContents?: string | Buffer, read?: boolean }) { |   constructor (options: { filePath?: string, fileContents?: string | Buffer, read?: boolean }) { | ||||||
|     this.filePath = options.filePath |     this.filePath = options.filePath | ||||||
|     this.repo = NpmciEnv.repo.user + '/' + NpmciEnv.repo.repo |     this.repo = NpmciEnv.repo.user + '/' + NpmciEnv.repo.repo | ||||||
|     this.version = dockerFileVersion(plugins.path.parse(options.filePath).base) |     this.version = dockerFileVersion(plugins.path.parse(options.filePath).base) | ||||||
| @@ -161,9 +164,10 @@ export class Dockerfile { | |||||||
|   /** |   /** | ||||||
|    * builds the Dockerfile |    * builds the Dockerfile | ||||||
|    */ |    */ | ||||||
|   async build() { |   async build () { | ||||||
|     plugins.beautylog.info('now building Dockerfile for ' + this.cleanTag) |     plugins.beautylog.info('now building Dockerfile for ' + this.cleanTag) | ||||||
|     await bashBare('docker build -t ' + this.buildTag + ' -f ' + this.filePath + ' .') |     let buildCommand = `docker build -t ${this.buildTag} -f ${this.filePath} .` | ||||||
|  |     await bash(buildCommand) | ||||||
|     NpmciEnv.dockerFilesBuilt.push(this) |     NpmciEnv.dockerFilesBuilt.push(this) | ||||||
|     return |     return | ||||||
|   }; |   }; | ||||||
| @@ -174,19 +178,19 @@ export class Dockerfile { | |||||||
|   async push(stageArg) { |   async push(stageArg) { | ||||||
|     switch (stageArg) { |     switch (stageArg) { | ||||||
|       case 'release': |       case 'release': | ||||||
|         await bashBare(`docker tag ${this.buildTag} ${this.releaseTag}`) |         await bash(`docker tag ${this.buildTag} ${this.releaseTag}`) | ||||||
|         await bashBare(`docker push ${this.releaseTag}`) |         await bash(`docker push ${this.releaseTag}`) | ||||||
|  |  | ||||||
|         // if release registry is different from gitlab |         // if release registry is different from gitlab | ||||||
|         if (NpmciEnv.dockerRegistry !== 'registry.gitlab.com') { |         if (NpmciEnv.dockerRegistry !== 'registry.gitlab.com') { | ||||||
|           await bashBare(`docker tag ${this.buildTag} ${this.gitlabReleaseTag}`) |           await bash(`docker tag ${this.buildTag} ${this.gitlabReleaseTag}`) | ||||||
|           await bashBare(`docker push ${this.gitlabReleaseTag}`) |           await bash(`docker push ${this.gitlabReleaseTag}`) | ||||||
|         } |         } | ||||||
|         break |         break | ||||||
|       case 'test': |       case 'test': | ||||||
|       default: |       default: | ||||||
|         await bashBare(`docker tag ${this.buildTag} ${this.gitlabTestTag}`) |         await bash(`docker tag ${this.buildTag} ${this.gitlabTestTag}`) | ||||||
|         await bashBare(`docker push ${this.gitlabTestTag}`) |         await bash(`docker push ${this.gitlabTestTag}`) | ||||||
|         break |         break | ||||||
|     } |     } | ||||||
|   }; |   }; | ||||||
| @@ -196,8 +200,8 @@ export class Dockerfile { | |||||||
|    */ |    */ | ||||||
|   async pull(registryArg: string) { |   async pull(registryArg: string) { | ||||||
|     let pullTag = this.gitlabTestTag |     let pullTag = this.gitlabTestTag | ||||||
|     await bashBare('docker pull ' + pullTag) |     await bash('docker pull ' + pullTag) | ||||||
|     await bashBare('docker tag ' + pullTag + ' ' + this.buildTag) |     await bash('docker tag ' + pullTag + ' ' + this.buildTag) | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   /** |   /** | ||||||
| @@ -208,12 +212,12 @@ export class Dockerfile { | |||||||
|     let testFileExists: boolean = plugins.smartfile.fs.fileExistsSync(testFile) |     let testFileExists: boolean = plugins.smartfile.fs.fileExistsSync(testFile) | ||||||
|     if (testFileExists) { |     if (testFileExists) { | ||||||
|       // run tests |       // run tests | ||||||
|       await bashBare('docker run --name npmci_test_container ' + this.buildTag + ' mkdir /npmci_test') |       await bash('docker run --name npmci_test_container ' + this.buildTag + ' mkdir /npmci_test') | ||||||
|       await bashBare('docker cp ' + testFile + ' npmci_test_container:/npmci_test/test.sh') |       await bash('docker cp ' + testFile + ' npmci_test_container:/npmci_test/test.sh') | ||||||
|       await bashBare('docker commit npmci_test_container npmci_test_image') |       await bash('docker commit npmci_test_container npmci_test_image') | ||||||
|       await bashBare('docker run npmci_test_image sh /npmci_test/test.sh') |       await bash('docker run npmci_test_image sh /npmci_test/test.sh') | ||||||
|       await bashBare('docker rm npmci_test_container') |       await bash('docker rm npmci_test_container') | ||||||
|       await bashBare('docker rmi --force npmci_test_image') |       await bash('docker rmi --force npmci_test_image') | ||||||
|     } else { |     } else { | ||||||
|       plugins.beautylog.warn('skipping tests for ' + this.cleanTag + ' because no testfile was found!') |       plugins.beautylog.warn('skipping tests for ' + this.cleanTag + ' because no testfile was found!') | ||||||
|     } |     } | ||||||
| @@ -223,7 +227,7 @@ export class Dockerfile { | |||||||
|    * gets the id of a Dockerfile |    * gets the id of a Dockerfile | ||||||
|    */ |    */ | ||||||
|   async getId() { |   async getId() { | ||||||
|     let containerId = await bashBare('docker inspect --type=image --format=\"{{.Id}}\" ' + this.buildTag) |     let containerId = await bash('docker inspect --type=image --format=\"{{.Id}}\" ' + this.buildTag) | ||||||
|     return containerId |     return containerId | ||||||
|   }; |   }; | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user