Compare commits
68 Commits
Author | SHA1 | Date | |
---|---|---|---|
ac386f01e0 | |||
08ead4258f | |||
f930f3a6a7 | |||
b6d4a76c70 | |||
9a7ecd27e5 | |||
11b70b0ddf | |||
79f8cb5e0e | |||
3e1286b9ac | |||
a8ae886959 | |||
da1c977a62 | |||
b99b55a05b | |||
133bf0abe5 | |||
df260bbab9 | |||
080bd2bc48 | |||
a0032b8168 | |||
a09efd1125 | |||
4ce28c7979 | |||
415eaea56e | |||
bde4597dd9 | |||
80946d4f0c | |||
2155e886ef | |||
8b61a90b5f | |||
f48eadc814 | |||
9bdaaa0c30 | |||
5f681ff237 | |||
889a3fdc5a | |||
565c002127 | |||
6fec1a00ea | |||
e1f2c28718 | |||
9efab07424 | |||
18d16feaa9 | |||
df09ff0f9b | |||
7b50ceb69f | |||
d1fd76e8d0 | |||
b71fa1bc36 | |||
068d28b95d | |||
ecb458f5cd | |||
9f6fb8aedd | |||
f21df13b7c | |||
9c56942739 | |||
5f4ab33069 | |||
14761a442e | |||
c4ee967ca9 | |||
551b8d0cde | |||
4f23b61e14 | |||
799320492a | |||
d2cd294b36 | |||
d3d3363e1b | |||
ccd2cb6cbd | |||
0b0642f9e3 | |||
34753a4ae0 | |||
977ecabb41 | |||
6d9d040a8d | |||
b2c08b7221 | |||
73b1a73719 | |||
449512e156 | |||
758e677bab | |||
42ffb4a8dd | |||
9176b56035 | |||
b3d78f8ce5 | |||
b6a6aac8e5 | |||
32f5ead4f4 | |||
c29a261cb6 | |||
de57d45947 | |||
00bf1532ca | |||
38fc672bf6 | |||
83771df11d | |||
822e480bdf |
29
.gitignore
vendored
29
.gitignore
vendored
@ -1,8 +1,23 @@
|
|||||||
node_modules/
|
|
||||||
coverage/
|
|
||||||
pages/
|
|
||||||
public/
|
|
||||||
|
|
||||||
test/
|
|
||||||
assets/
|
|
||||||
.nogit/
|
.nogit/
|
||||||
|
|
||||||
|
# artifacts
|
||||||
|
coverage/
|
||||||
|
public/
|
||||||
|
pages/
|
||||||
|
|
||||||
|
# installs
|
||||||
|
node_modules/
|
||||||
|
|
||||||
|
# caches
|
||||||
|
.yarn/
|
||||||
|
.cache/
|
||||||
|
.rpt2_cache
|
||||||
|
|
||||||
|
# builds
|
||||||
|
dist/
|
||||||
|
dist_web/
|
||||||
|
dist_serve/
|
||||||
|
dist_ts_web/
|
||||||
|
|
||||||
|
# custom
|
||||||
|
test
|
||||||
|
@ -3,14 +3,27 @@ services:
|
|||||||
- docker:dind
|
- docker:dind
|
||||||
|
|
||||||
stages:
|
stages:
|
||||||
|
- mirror
|
||||||
- test
|
- test
|
||||||
- release
|
- release
|
||||||
- trigger
|
- trigger
|
||||||
|
- pages
|
||||||
|
|
||||||
|
mirror:
|
||||||
|
image: hosttoday/ht-docker-node:npmci
|
||||||
|
stage: mirror
|
||||||
|
script:
|
||||||
|
- npmci git mirror
|
||||||
|
tags:
|
||||||
|
- docker
|
||||||
|
|
||||||
|
|
||||||
test:
|
test:
|
||||||
stage: test
|
stage: test
|
||||||
script:
|
script:
|
||||||
- npmci test stable
|
- npmci node install stable
|
||||||
|
- npmci npm install
|
||||||
|
- npmci npm test
|
||||||
tags:
|
tags:
|
||||||
- docker
|
- docker
|
||||||
- lossless
|
- lossless
|
||||||
@ -20,7 +33,8 @@ release:
|
|||||||
stage: release
|
stage: release
|
||||||
environment: npmjs-com_registry
|
environment: npmjs-com_registry
|
||||||
script:
|
script:
|
||||||
- npmci publish
|
- npmci npm prepare
|
||||||
|
- npmci npm publish
|
||||||
only:
|
only:
|
||||||
- tags
|
- tags
|
||||||
tags:
|
tags:
|
||||||
@ -38,3 +52,18 @@ trigger:
|
|||||||
- docker
|
- docker
|
||||||
- lossless
|
- lossless
|
||||||
- priv
|
- priv
|
||||||
|
|
||||||
|
pages:
|
||||||
|
image: hosttoday/ht-docker-node:npmci
|
||||||
|
stage: pages
|
||||||
|
script:
|
||||||
|
- npmci command npm install -g @gitzone/tsdoc
|
||||||
|
- npmci command tsdoc
|
||||||
|
only:
|
||||||
|
- tags
|
||||||
|
tags:
|
||||||
|
- docker
|
||||||
|
artifacts:
|
||||||
|
expire_in: 1 week
|
||||||
|
paths:
|
||||||
|
- public
|
||||||
|
3
.vscode/settings.json
vendored
Normal file
3
.vscode/settings.json
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
{
|
||||||
|
"typescript.tsdk": "node_modules/typescript/lib"
|
||||||
|
}
|
4
Dockerfile
Normal file
4
Dockerfile
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
FROM hosttoday/ht-docker-node:stable
|
||||||
|
LABEL author="Lossless GmbH <office@lossless.com>"
|
||||||
|
|
||||||
|
RUN yarn global add npmci npmdocker npmts ts-node
|
59
README.md
59
README.md
@ -1,59 +0,0 @@
|
|||||||
# npmdocker
|
|
||||||
develop npm modules cross platform with docker
|
|
||||||
|
|
||||||
## Availabililty
|
|
||||||
[](https://www.npmjs.com/package/npmdocker)
|
|
||||||
[](https://GitLab.com/gitzone/npmdocker)
|
|
||||||
[](https://github.com/gitzone/npmdocker)
|
|
||||||
[](https://gitzone.gitlab.io/npmdocker/)
|
|
||||||
|
|
||||||
## Status for master
|
|
||||||
[](https://GitLab.com/gitzone/npmdocker/commits/master)
|
|
||||||
[](https://GitLab.com/gitzone/npmdocker/commits/master)
|
|
||||||
[](https://www.npmjs.com/package/npmdocker)
|
|
||||||
[](https://david-dm.org/gitzonetools/npmdocker)
|
|
||||||
[](https://www.bithound.io/github/gitzonetools/npmdocker/master/dependencies/npm)
|
|
||||||
[](https://www.bithound.io/github/gitzonetools/npmdocker)
|
|
||||||
[](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.
|
|
||||||
|
|
||||||
### Why does this package exist?
|
|
||||||
Sometimes you want a clean and fresh linux environment everytime you test your package.
|
|
||||||
Usually this is the default i CI, but locally behaviour tends to defer.
|
|
||||||
|
|
||||||
### Where does it work
|
|
||||||
The npmdocker package works in everywhere where the docker cli is available. e.g.:
|
|
||||||
|
|
||||||
* docker toolbox
|
|
||||||
* native docker application
|
|
||||||
* docker in docker
|
|
||||||
* mounted docker.sock
|
|
||||||
|
|
||||||
### How do I use it?
|
|
||||||
create a npmextra.json in the project's root directory
|
|
||||||
|
|
||||||
```json
|
|
||||||
{
|
|
||||||
"npmdocker": {
|
|
||||||
"baseImage": "hosttoday/ht-docker-node:npmts",
|
|
||||||
"command": "npmci test stable",
|
|
||||||
"dockerSock": false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
option | description
|
|
||||||
--- | ---
|
|
||||||
baseImage | the base image that is the context for your project
|
|
||||||
command | the cli command to run within the the project's directory inside the docker container
|
|
||||||
dockersSock | wether or not the testcontainer will have access to the docker.sock of the host
|
|
||||||
|
|
||||||
For further information read the linked docs at the top of this README.
|
|
||||||
|
|
||||||
> MIT licensed | **©** [Lossless GmbH](https://lossless.gmbh)
|
|
||||||
|
|
||||||
[](https://git.zone)
|
|
@ -1,5 +1,6 @@
|
|||||||
FROM hosttoday/ht-docker-node:npmci
|
FROM hosttoday/ht-docker-node:npmci
|
||||||
COPY ./buildContextDir /workspace
|
RUN yarn global add @gitzone/tsdocker
|
||||||
|
COPY ./ /workspace
|
||||||
WORKDIR /workspace
|
WORKDIR /workspace
|
||||||
ENV CI=true
|
ENV CI=true
|
||||||
CMD ["npmci","test","stable"];
|
CMD ["tsdocker","runinside"];
|
||||||
|
3
cli.js
Normal file
3
cli.js
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
#!/usr/bin/env node
|
||||||
|
process.env.CLI_CALL = 'true';
|
||||||
|
require('./dist/index');
|
4
cli.ts.js
Normal file
4
cli.ts.js
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
#!/usr/bin/env node
|
||||||
|
process.env.CLI_CALL = 'true';
|
||||||
|
require('@gitzone/tsrun');
|
||||||
|
require('./ts/index');
|
2
dist/cli.js
vendored
2
dist/cli.js
vendored
@ -1,2 +0,0 @@
|
|||||||
#!/usr/bin/env node
|
|
||||||
var index = require("../dist/index.js");
|
|
0
dist/index.d.ts
vendored
0
dist/index.d.ts
vendored
5
dist/index.js
vendored
5
dist/index.js
vendored
@ -1,5 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
|
||||||
const cli = require("./npmdocker.cli");
|
|
||||||
cli.run();
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUNBLHVDQUFzQztBQUV0QyxHQUFHLENBQUMsR0FBRyxFQUFFLENBQUEifQ==
|
|
1
dist/npmdocker.cli.d.ts
vendored
1
dist/npmdocker.cli.d.ts
vendored
@ -1 +0,0 @@
|
|||||||
export declare let run: () => void;
|
|
51
dist/npmdocker.cli.js
vendored
51
dist/npmdocker.cli.js
vendored
@ -1,51 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
||||||
return new (P || (P = Promise))(function (resolve, reject) {
|
|
||||||
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
||||||
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
||||||
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
|
|
||||||
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
||||||
});
|
|
||||||
};
|
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
|
||||||
const plugins = require("./npmdocker.plugins");
|
|
||||||
// modules
|
|
||||||
const ConfigModule = require("./npmdocker.config");
|
|
||||||
const DockerModule = require("./npmdocker.docker");
|
|
||||||
let npmdockerCli = new plugins.smartcli.Smartcli();
|
|
||||||
exports.run = () => {
|
|
||||||
npmdockerCli.standardTask().then((argvArg) => __awaiter(this, void 0, void 0, function* () {
|
|
||||||
let configArg = yield ConfigModule.run()
|
|
||||||
.then(DockerModule.run);
|
|
||||||
if (configArg.exitCode === 0) {
|
|
||||||
plugins.beautylog.success('container ended all right!');
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
plugins.beautylog.error('container ended with error!');
|
|
||||||
process.exit(1);
|
|
||||||
}
|
|
||||||
}));
|
|
||||||
npmdockerCli.addCommand('clean').then((argvArg) => __awaiter(this, void 0, void 0, function* () {
|
|
||||||
plugins.beautylog.ora.start();
|
|
||||||
plugins.beautylog.ora.text('cleaning up docker env...');
|
|
||||||
if (argvArg.all) {
|
|
||||||
plugins.beautylog.ora.text('killing any running docker containers...');
|
|
||||||
yield plugins.smartshell.exec(`docker kill $(docker ps -q)`);
|
|
||||||
plugins.beautylog.ora.text('removing stopped containers...');
|
|
||||||
yield plugins.smartshell.exec(`docker rm $(docker ps -a -q)`);
|
|
||||||
plugins.beautylog.ora.text('removing images...');
|
|
||||||
yield plugins.smartshell.exec(`docker rmi $(docker images -q -f dangling=true)`);
|
|
||||||
plugins.beautylog.ora.text('removing all other images...');
|
|
||||||
yield plugins.smartshell.exec(`docker rmi $(docker images -a -q)`);
|
|
||||||
plugins.beautylog.ora.text('removing all volumes...');
|
|
||||||
yield plugins.smartshell.exec(`docker volume rm $(docker volume ls -f dangling=true -q)`);
|
|
||||||
}
|
|
||||||
plugins.beautylog.ora.endOk('docker environment now is clean!');
|
|
||||||
}));
|
|
||||||
npmdockerCli.addCommand('speedtest').then((argvArg) => __awaiter(this, void 0, void 0, function* () {
|
|
||||||
plugins.beautylog.ok('Starting speedtest');
|
|
||||||
yield plugins.smartshell.exec(`docker pull tianon/speedtest && docker run --rm tianon/speedtest`);
|
|
||||||
}));
|
|
||||||
npmdockerCli.startParse();
|
|
||||||
};
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtZG9ja2VyLmNsaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL25wbWRvY2tlci5jbGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7OztBQUFBLCtDQUE4QztBQUc5QyxVQUFVO0FBQ1YsbURBQWtEO0FBQ2xELG1EQUFrRDtBQUVsRCxJQUFJLFlBQVksR0FBRyxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLENBQUE7QUFFdkMsUUFBQSxHQUFHLEdBQUc7SUFDZixZQUFZLENBQUMsWUFBWSxFQUFFLENBQUMsSUFBSSxDQUFDLENBQU8sT0FBTztRQUM3QyxJQUFJLFNBQVMsR0FBRyxNQUFNLFlBQVksQ0FBQyxHQUFHLEVBQUU7YUFDckMsSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsQ0FBQTtRQUN6QixFQUFFLENBQUMsQ0FBQyxTQUFTLENBQUMsUUFBUSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDN0IsT0FBTyxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsNEJBQTRCLENBQUMsQ0FBQTtRQUN6RCxDQUFDO1FBQUMsSUFBSSxDQUFDLENBQUM7WUFDTixPQUFPLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyw2QkFBNkIsQ0FBQyxDQUFBO1lBQ3RELE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUE7UUFDakIsQ0FBQztJQUNILENBQUMsQ0FBQSxDQUFDLENBQUE7SUFFRixZQUFZLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFPLE9BQU87UUFDbEQsT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLENBQUE7UUFDN0IsT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLDJCQUEyQixDQUFDLENBQUE7UUFDdkQsRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7WUFDaEIsT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLDBDQUEwQyxDQUFDLENBQUE7WUFDdEUsTUFBTSxPQUFPLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyw2QkFBNkIsQ0FBQyxDQUFBO1lBRTVELE9BQU8sQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxnQ0FBZ0MsQ0FBQyxDQUFBO1lBQzVELE1BQU0sT0FBTyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsOEJBQThCLENBQUMsQ0FBQTtZQUU3RCxPQUFPLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsb0JBQW9CLENBQUMsQ0FBQTtZQUNoRCxNQUFNLE9BQU8sQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLGlEQUFpRCxDQUFDLENBQUE7WUFFaEYsT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLDhCQUE4QixDQUFDLENBQUE7WUFDMUQsTUFBTSxPQUFPLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxtQ0FBbUMsQ0FBQyxDQUFBO1lBRWxFLE9BQU8sQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyx5QkFBeUIsQ0FBQyxDQUFBO1lBQ3JELE1BQU0sT0FBTyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsMERBQTBELENBQUMsQ0FBQTtRQUMzRixDQUFDO1FBQ0QsT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLGtDQUFrQyxDQUFDLENBQUE7SUFDakUsQ0FBQyxDQUFBLENBQUMsQ0FBQTtJQUVGLFlBQVksQ0FBQyxVQUFVLENBQUMsV0FBVyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQU8sT0FBTztRQUN0RCxPQUFPLENBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQyxDQUFBO1FBQzFDLE1BQU0sT0FBTyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsa0VBQWtFLENBQUMsQ0FBQTtJQUNuRyxDQUFDLENBQUEsQ0FBQyxDQUFBO0lBRUYsWUFBWSxDQUFDLFVBQVUsRUFBRSxDQUFBO0FBQzNCLENBQUMsQ0FBQSJ9
|
|
9
dist/npmdocker.config.d.ts
vendored
9
dist/npmdocker.config.d.ts
vendored
@ -1,9 +0,0 @@
|
|||||||
import { IKeyValueObject } from 'qenv';
|
|
||||||
export interface IConfig {
|
|
||||||
baseImage: string;
|
|
||||||
command: string;
|
|
||||||
dockerSock: boolean;
|
|
||||||
exitCode?: number;
|
|
||||||
keyValueObjectArray: IKeyValueObject[];
|
|
||||||
}
|
|
||||||
export declare let run: () => Promise<IConfig>;
|
|
39
dist/npmdocker.config.js
vendored
39
dist/npmdocker.config.js
vendored
@ -1,39 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
||||||
return new (P || (P = Promise))(function (resolve, reject) {
|
|
||||||
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
||||||
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
||||||
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
|
|
||||||
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
||||||
});
|
|
||||||
};
|
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
|
||||||
const plugins = require("./npmdocker.plugins");
|
|
||||||
const paths = require("./npmdocker.paths");
|
|
||||||
;
|
|
||||||
let getQenvKeyValueObject = () => __awaiter(this, void 0, void 0, function* () {
|
|
||||||
let qenvKeyValueObjectArray;
|
|
||||||
if (plugins.smartfile.fs.fileExistsSync(plugins.path.join(paths.cwd, 'qenv.yml'))) {
|
|
||||||
qenvKeyValueObjectArray = new plugins.qenv.Qenv(paths.cwd, '.nogit/').keyValueObjectArray;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
qenvKeyValueObjectArray = [];
|
|
||||||
}
|
|
||||||
;
|
|
||||||
return qenvKeyValueObjectArray;
|
|
||||||
});
|
|
||||||
let buildConfig = (qenvKeyValueObjectArrayArg) => __awaiter(this, void 0, void 0, function* () {
|
|
||||||
let npmextra = new plugins.npmextra.Npmextra(paths.cwd);
|
|
||||||
let config = npmextra.dataFor('npmdocker', {
|
|
||||||
baseImage: 'hosttoday/ht-docker-node:npmts',
|
|
||||||
command: 'npm test',
|
|
||||||
dockerSock: false,
|
|
||||||
keyValueObjectArray: qenvKeyValueObjectArrayArg
|
|
||||||
});
|
|
||||||
return config;
|
|
||||||
});
|
|
||||||
exports.run = () => __awaiter(this, void 0, void 0, function* () {
|
|
||||||
let config = yield getQenvKeyValueObject().then(buildConfig);
|
|
||||||
return config;
|
|
||||||
});
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtZG9ja2VyLmNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL25wbWRvY2tlci5jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7OztBQUFBLCtDQUE4QztBQUM5QywyQ0FBMEM7QUFXekMsQ0FBQztBQUVGLElBQUkscUJBQXFCLEdBQUc7SUFDMUIsSUFBSSx1QkFBMEMsQ0FBQTtJQUM5QyxFQUFFLENBQUMsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQyxjQUFjLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsRUFBRSxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNsRix1QkFBdUIsR0FBRyxJQUFJLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLEVBQUUsU0FBUyxDQUFDLENBQUMsbUJBQW1CLENBQUE7SUFDM0YsQ0FBQztJQUFDLElBQUksQ0FBQyxDQUFDO1FBQ04sdUJBQXVCLEdBQUcsRUFBRSxDQUFBO0lBQzlCLENBQUM7SUFBQSxDQUFDO0lBQ0YsTUFBTSxDQUFDLHVCQUF1QixDQUFBO0FBQ2hDLENBQUMsQ0FBQSxDQUFBO0FBRUQsSUFBSSxXQUFXLEdBQUcsQ0FBTywwQkFBNkM7SUFDcEUsSUFBSSxRQUFRLEdBQUcsSUFBSSxPQUFPLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUE7SUFDdkQsSUFBSSxNQUFNLEdBQUcsUUFBUSxDQUFDLE9BQU8sQ0FDM0IsV0FBVyxFQUNYO1FBQ0UsU0FBUyxFQUFFLGdDQUFnQztRQUMzQyxPQUFPLEVBQUUsVUFBVTtRQUNuQixVQUFVLEVBQUUsS0FBSztRQUNqQixtQkFBbUIsRUFBRSwwQkFBMEI7S0FDaEQsQ0FDRixDQUFBO0lBQ0QsTUFBTSxDQUFDLE1BQU0sQ0FBQTtBQUNmLENBQUMsQ0FBQSxDQUFBO0FBRVUsUUFBQSxHQUFHLEdBQUc7SUFDZixJQUFJLE1BQU0sR0FBRyxNQUFNLHFCQUFxQixFQUFFLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFBO0lBQzVELE1BQU0sQ0FBQyxNQUFNLENBQUE7QUFDZixDQUFDLENBQUEsQ0FBQSJ9
|
|
2
dist/npmdocker.docker.d.ts
vendored
2
dist/npmdocker.docker.d.ts
vendored
@ -1,2 +0,0 @@
|
|||||||
import { IConfig } from './npmdocker.config';
|
|
||||||
export declare let run: (configArg: IConfig) => Promise<IConfig>;
|
|
156
dist/npmdocker.docker.js
vendored
156
dist/npmdocker.docker.js
vendored
File diff suppressed because one or more lines are too long
5
dist/npmdocker.paths.d.ts
vendored
5
dist/npmdocker.paths.d.ts
vendored
@ -1,5 +0,0 @@
|
|||||||
export declare let cwd: string;
|
|
||||||
export declare let packageBase: string;
|
|
||||||
export declare let assets: string;
|
|
||||||
export declare let buildContextDir: string;
|
|
||||||
export declare let dockerfile: string;
|
|
13
dist/npmdocker.paths.js
vendored
13
dist/npmdocker.paths.js
vendored
@ -1,13 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
|
||||||
const plugins = require("./npmdocker.plugins");
|
|
||||||
// directories
|
|
||||||
exports.cwd = process.cwd();
|
|
||||||
exports.packageBase = plugins.path.join(__dirname, "../");
|
|
||||||
exports.assets = plugins.path.join(exports.packageBase, "assets/");
|
|
||||||
plugins.smartfile.fs.ensureDirSync(exports.assets);
|
|
||||||
exports.buildContextDir = plugins.path.join(exports.assets, "buildContextDir");
|
|
||||||
plugins.smartfile.fs.ensureDirSync(exports.buildContextDir);
|
|
||||||
// files
|
|
||||||
exports.dockerfile = plugins.path.join(exports.assets, "Dockerfile");
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtZG9ja2VyLnBhdGhzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvbnBtZG9ja2VyLnBhdGhzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsK0NBQStDO0FBRS9DLGNBQWM7QUFDSCxRQUFBLEdBQUcsR0FBRyxPQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7QUFDcEIsUUFBQSxXQUFXLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLEtBQUssQ0FBQyxDQUFDO0FBQ2xELFFBQUEsTUFBTSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLG1CQUFXLEVBQUUsU0FBUyxDQUFDLENBQUM7QUFDOUQsT0FBTyxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLGNBQU0sQ0FBQyxDQUFDO0FBRWhDLFFBQUEsZUFBZSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGNBQU0sRUFBQyxpQkFBaUIsQ0FBQyxDQUFDO0FBQ3pFLE9BQU8sQ0FBQyxTQUFTLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyx1QkFBZSxDQUFDLENBQUM7QUFFcEQsUUFBUTtBQUNHLFFBQUEsVUFBVSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGNBQU0sRUFBRSxZQUFZLENBQUMsQ0FBQyJ9
|
|
12
dist/npmdocker.plugins.d.ts
vendored
12
dist/npmdocker.plugins.d.ts
vendored
@ -1,12 +0,0 @@
|
|||||||
import 'typings-global';
|
|
||||||
import * as beautylog from 'beautylog';
|
|
||||||
import * as npmextra from 'npmextra';
|
|
||||||
import * as path from 'path';
|
|
||||||
import * as projectinfo from 'projectinfo';
|
|
||||||
import * as q from 'smartq';
|
|
||||||
import * as qenv from 'qenv';
|
|
||||||
import * as smartcli from 'smartcli';
|
|
||||||
import * as smartfile from 'smartfile';
|
|
||||||
import * as smartshell from 'smartshell';
|
|
||||||
import * as smartstring from 'smartstring';
|
|
||||||
export { beautylog, npmextra, path, projectinfo, q, qenv, smartcli, smartfile, smartshell, smartstring };
|
|
24
dist/npmdocker.plugins.js
vendored
24
dist/npmdocker.plugins.js
vendored
@ -1,24 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
|
||||||
require("typings-global");
|
|
||||||
const beautylog = require("beautylog");
|
|
||||||
exports.beautylog = beautylog;
|
|
||||||
const npmextra = require("npmextra");
|
|
||||||
exports.npmextra = npmextra;
|
|
||||||
const path = require("path");
|
|
||||||
exports.path = path;
|
|
||||||
const projectinfo = require("projectinfo");
|
|
||||||
exports.projectinfo = projectinfo;
|
|
||||||
const q = require("smartq");
|
|
||||||
exports.q = q;
|
|
||||||
const qenv = require("qenv");
|
|
||||||
exports.qenv = qenv;
|
|
||||||
const smartcli = require("smartcli");
|
|
||||||
exports.smartcli = smartcli;
|
|
||||||
const smartfile = require("smartfile");
|
|
||||||
exports.smartfile = smartfile;
|
|
||||||
const smartshell = require("smartshell");
|
|
||||||
exports.smartshell = smartshell;
|
|
||||||
const smartstring = require("smartstring");
|
|
||||||
exports.smartstring = smartstring;
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtZG9ja2VyLnBsdWdpbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9ucG1kb2NrZXIucGx1Z2lucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLDBCQUF1QjtBQUN2Qix1Q0FBc0M7QUFZcEMsOEJBQVM7QUFYWCxxQ0FBb0M7QUFZbEMsNEJBQVE7QUFYViw2QkFBNEI7QUFZMUIsb0JBQUk7QUFYTiwyQ0FBMEM7QUFZeEMsa0NBQVc7QUFYYiw0QkFBMkI7QUFZekIsY0FBQztBQVhILDZCQUE0QjtBQVkxQixvQkFBSTtBQVhOLHFDQUFvQztBQVlsQyw0QkFBUTtBQVhWLHVDQUFzQztBQVlwQyw4QkFBUztBQVhYLHlDQUF3QztBQVl0QyxnQ0FBVTtBQVhaLDJDQUEwQztBQVl4QyxrQ0FBVyJ9
|
|
5
dist/npmdocker.snippets.d.ts
vendored
5
dist/npmdocker.snippets.d.ts
vendored
@ -1,5 +0,0 @@
|
|||||||
export interface IDockerfileSnippet {
|
|
||||||
baseImage: string;
|
|
||||||
command: string;
|
|
||||||
}
|
|
||||||
export declare let dockerfileSnippet: (optionsArg: IDockerfileSnippet) => string;
|
|
22
dist/npmdocker.snippets.js
vendored
22
dist/npmdocker.snippets.js
vendored
@ -1,22 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
|
||||||
const plugins = require("./npmdocker.plugins");
|
|
||||||
exports.dockerfileSnippet = (optionsArg) => {
|
|
||||||
let commandArray = optionsArg.command.split(/\s/);
|
|
||||||
let commandString = "";
|
|
||||||
for (let stringItem of commandArray) {
|
|
||||||
if (!(commandString == "")) {
|
|
||||||
commandString = commandString + ",";
|
|
||||||
}
|
|
||||||
commandString = commandString + '"' + stringItem + '"';
|
|
||||||
}
|
|
||||||
;
|
|
||||||
return plugins.smartstring.indent.normalize(`
|
|
||||||
FROM ${optionsArg.baseImage}
|
|
||||||
COPY ./buildContextDir /workspace
|
|
||||||
WORKDIR /workspace
|
|
||||||
ENV CI=true
|
|
||||||
CMD [${commandString}];
|
|
||||||
`);
|
|
||||||
};
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtZG9ja2VyLnNuaXBwZXRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvbnBtZG9ja2VyLnNuaXBwZXRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsK0NBQStDO0FBT3BDLFFBQUEsaUJBQWlCLEdBQUcsQ0FBQyxVQUE2QjtJQUN6RCxJQUFJLFlBQVksR0FBRyxVQUFVLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNsRCxJQUFJLGFBQWEsR0FBVSxFQUFFLENBQUM7SUFDOUIsR0FBRyxDQUFBLENBQUMsSUFBSSxVQUFVLElBQUksWUFBWSxDQUFDLENBQUEsQ0FBQztRQUNoQyxFQUFFLENBQUEsQ0FBQyxDQUFDLENBQUMsYUFBYSxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUEsQ0FBQztZQUN2QixhQUFhLEdBQUcsYUFBYSxHQUFHLEdBQUcsQ0FBQztRQUN4QyxDQUFDO1FBQ0QsYUFBYSxHQUFHLGFBQWEsR0FBRyxHQUFHLEdBQUcsVUFBVSxHQUFHLEdBQUcsQ0FBQztJQUMzRCxDQUFDO0lBQUEsQ0FBQztJQUNGLE1BQU0sQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUM7ZUFDakMsVUFBVSxDQUFDLFNBQVM7Ozs7ZUFJcEIsYUFBYTtLQUN2QixDQUFDLENBQUM7QUFDUCxDQUFDLENBQUEifQ==
|
|
@ -1,12 +1,20 @@
|
|||||||
{
|
{
|
||||||
"npmts":{
|
"npmts": {
|
||||||
"mode":"default",
|
"mode": "default",
|
||||||
"cli":true,
|
"cli": true
|
||||||
"dockerSock":true
|
},
|
||||||
},
|
"npmci": {
|
||||||
"npmci": {
|
"npmGlobalTools": [],
|
||||||
"globalNpmTools": [
|
"npmAccessLevel": "public"
|
||||||
"npmts"
|
},
|
||||||
]
|
"gitzone": {
|
||||||
|
"module": {
|
||||||
|
"githost": "gitlab.com",
|
||||||
|
"gitscope": "gitzone",
|
||||||
|
"gitrepo": "npmdocker",
|
||||||
|
"shortDescription": "develop npm modules cross platform with docker",
|
||||||
|
"npmPackagename": "@gitzone/npmdocker",
|
||||||
|
"license": "MIT"
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
28061
package-lock.json
generated
Normal file
28061
package-lock.json
generated
Normal file
File diff suppressed because it is too large
Load Diff
55
package.json
55
package.json
@ -1,20 +1,20 @@
|
|||||||
{
|
{
|
||||||
"name": "npmdocker",
|
"name": "@gitzone/tsdocker",
|
||||||
"version": "1.2.7",
|
"version": "1.2.40",
|
||||||
|
"private": false,
|
||||||
"description": "develop npm modules cross platform with docker",
|
"description": "develop npm modules cross platform with docker",
|
||||||
"main": "dist/index.js",
|
"main": "dist/index.js",
|
||||||
"typings": "dist/index.d.ts",
|
"typings": "dist/index.d.ts",
|
||||||
"bin": {
|
"bin": {
|
||||||
"npmdocker": "dist/cli.js"
|
"tsdocker": "cli.js"
|
||||||
},
|
|
||||||
"directories": {
|
|
||||||
"test": "test"
|
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"test": "(npm run clean && npm run compile && npm run setupCheck && npm run testStandard && npm run testSpeed && npm run testClean)",
|
"test": "(npm run clean && npm run setupCheck && npm run testStandard && npm run testSpeed)",
|
||||||
"testStandard": "(cd test/ && node ../dist/index.js)",
|
"build": "(tsbuild)",
|
||||||
"testSpeed": "(cd test/ && node ../dist/index.js speedtest)",
|
"testStandard": "(cd test/ && node ../cli.ts.js)",
|
||||||
"testClean": "(cd test/ && node ../dist/index.js clean --all)",
|
"testSpeed": "(cd test/ && node ../cli.ts.js speedtest)",
|
||||||
|
"testClean": "(cd test/ && node ../cli.ts.js clean --all)",
|
||||||
|
"testVscode": "(cd test/ && node ../cli.ts.js vscode)",
|
||||||
"clean": "(rm -rf test/)",
|
"clean": "(rm -rf test/)",
|
||||||
"compile": "(npmts --notest)",
|
"compile": "(npmts --notest)",
|
||||||
"setupCheck": "(git clone https://gitlab.com/sandboxzone/sandbox-npmts.git test/)"
|
"setupCheck": "(git clone https://gitlab.com/sandboxzone/sandbox-npmts.git test/)"
|
||||||
@ -32,18 +32,29 @@
|
|||||||
"url": "https://gitlab.com/gitzone/npmdocker/issues"
|
"url": "https://gitlab.com/gitzone/npmdocker/issues"
|
||||||
},
|
},
|
||||||
"homepage": "https://gitlab.com/gitzone/npmdocker#README",
|
"homepage": "https://gitlab.com/gitzone/npmdocker#README",
|
||||||
"devDependencies": {},
|
"devDependencies": {
|
||||||
|
"@gitzone/tsbuild": "^2.1.27",
|
||||||
|
"@gitzone/tsrun": "^1.2.17",
|
||||||
|
"@gitzone/tstest": "^1.0.57",
|
||||||
|
"@pushrocks/tapbundle": "^3.2.14",
|
||||||
|
"@types/node": "^16.10.1",
|
||||||
|
"tslint": "^6.1.3",
|
||||||
|
"tslint-config-prettier": "^1.18.0"
|
||||||
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@types/shelljs": "0.x.x",
|
"@pushrocks/npmextra": "^3.0.9",
|
||||||
"beautylog": "^6.1.5",
|
"@pushrocks/projectinfo": "^4.0.5",
|
||||||
"npmextra": "^2.0.5",
|
"@pushrocks/qenv": "^4.0.10",
|
||||||
"projectinfo": "^3.0.2",
|
"@pushrocks/smartanalytics": "^2.0.15",
|
||||||
"qenv": "^1.1.3",
|
"@pushrocks/smartcli": "^3.0.14",
|
||||||
"smartcli": "^2.0.1",
|
"@pushrocks/smartfile": "^8.0.10",
|
||||||
"smartfile": "^4.1.9",
|
"@pushrocks/smartlog": "^2.0.44",
|
||||||
"smartq": "^1.1.1",
|
"@pushrocks/smartlog-destination-local": "^8.0.8",
|
||||||
"smartshell": "^1.0.6",
|
"@pushrocks/smartlog-source-ora": "^1.0.9",
|
||||||
"smartstring": "^2.0.24",
|
"@pushrocks/smartopen": "^1.0.22",
|
||||||
"typings-global": "^1.0.14"
|
"@pushrocks/smartpromise": "^3.1.6",
|
||||||
|
"@pushrocks/smartshell": "^2.0.28",
|
||||||
|
"@pushrocks/smartstring": "^3.0.24",
|
||||||
|
"@types/shelljs": "^0.8.9"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import * as plugins from './npmdocker.plugins'
|
import * as plugins from './tsdocker.plugins';
|
||||||
import * as cli from './npmdocker.cli'
|
import * as cli from './tsdocker.cli';
|
||||||
|
|
||||||
cli.run()
|
cli.run();
|
||||||
|
@ -1,50 +0,0 @@
|
|||||||
import * as plugins from './npmdocker.plugins'
|
|
||||||
import * as paths from './npmdocker.paths'
|
|
||||||
|
|
||||||
// modules
|
|
||||||
import * as ConfigModule from './npmdocker.config'
|
|
||||||
import * as DockerModule from './npmdocker.docker'
|
|
||||||
|
|
||||||
let npmdockerCli = new plugins.smartcli.Smartcli()
|
|
||||||
|
|
||||||
export let run = () => {
|
|
||||||
npmdockerCli.standardTask().then(async (argvArg) => {
|
|
||||||
let configArg = await ConfigModule.run()
|
|
||||||
.then(DockerModule.run)
|
|
||||||
if (configArg.exitCode === 0) {
|
|
||||||
plugins.beautylog.success('container ended all right!')
|
|
||||||
} else {
|
|
||||||
plugins.beautylog.error('container ended with error!')
|
|
||||||
process.exit(1)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
npmdockerCli.addCommand('clean').then(async (argvArg) => {
|
|
||||||
plugins.beautylog.ora.start()
|
|
||||||
plugins.beautylog.ora.text('cleaning up docker env...')
|
|
||||||
if (argvArg.all) {
|
|
||||||
plugins.beautylog.ora.text('killing any running docker containers...')
|
|
||||||
await plugins.smartshell.exec(`docker kill $(docker ps -q)`)
|
|
||||||
|
|
||||||
plugins.beautylog.ora.text('removing stopped containers...')
|
|
||||||
await plugins.smartshell.exec(`docker rm $(docker ps -a -q)`)
|
|
||||||
|
|
||||||
plugins.beautylog.ora.text('removing images...')
|
|
||||||
await plugins.smartshell.exec(`docker rmi $(docker images -q -f dangling=true)`)
|
|
||||||
|
|
||||||
plugins.beautylog.ora.text('removing all other images...')
|
|
||||||
await plugins.smartshell.exec(`docker rmi $(docker images -a -q)`)
|
|
||||||
|
|
||||||
plugins.beautylog.ora.text('removing all volumes...')
|
|
||||||
await plugins.smartshell.exec(`docker volume rm $(docker volume ls -f dangling=true -q)`)
|
|
||||||
}
|
|
||||||
plugins.beautylog.ora.endOk('docker environment now is clean!')
|
|
||||||
})
|
|
||||||
|
|
||||||
npmdockerCli.addCommand('speedtest').then(async (argvArg) => {
|
|
||||||
plugins.beautylog.ok('Starting speedtest')
|
|
||||||
await plugins.smartshell.exec(`docker pull tianon/speedtest && docker run --rm tianon/speedtest`)
|
|
||||||
})
|
|
||||||
|
|
||||||
npmdockerCli.startParse()
|
|
||||||
}
|
|
@ -1,42 +0,0 @@
|
|||||||
import * as plugins from './npmdocker.plugins'
|
|
||||||
import * as paths from "./npmdocker.paths"
|
|
||||||
|
|
||||||
// interfaces
|
|
||||||
import { IKeyValueObject } from 'qenv'
|
|
||||||
|
|
||||||
export interface IConfig {
|
|
||||||
baseImage: string
|
|
||||||
command: string
|
|
||||||
dockerSock: boolean
|
|
||||||
exitCode?: number
|
|
||||||
keyValueObjectArray: IKeyValueObject[]
|
|
||||||
};
|
|
||||||
|
|
||||||
let getQenvKeyValueObject = async () => {
|
|
||||||
let qenvKeyValueObjectArray: IKeyValueObject[]
|
|
||||||
if (plugins.smartfile.fs.fileExistsSync(plugins.path.join(paths.cwd, 'qenv.yml'))) {
|
|
||||||
qenvKeyValueObjectArray = new plugins.qenv.Qenv(paths.cwd, '.nogit/').keyValueObjectArray
|
|
||||||
} else {
|
|
||||||
qenvKeyValueObjectArray = []
|
|
||||||
};
|
|
||||||
return qenvKeyValueObjectArray
|
|
||||||
}
|
|
||||||
|
|
||||||
let buildConfig = async (qenvKeyValueObjectArrayArg: IKeyValueObject[]) => {
|
|
||||||
let npmextra = new plugins.npmextra.Npmextra(paths.cwd)
|
|
||||||
let config = npmextra.dataFor<IConfig>(
|
|
||||||
'npmdocker',
|
|
||||||
{
|
|
||||||
baseImage: 'hosttoday/ht-docker-node:npmts',
|
|
||||||
command: 'npm test',
|
|
||||||
dockerSock: false,
|
|
||||||
keyValueObjectArray: qenvKeyValueObjectArrayArg
|
|
||||||
}
|
|
||||||
)
|
|
||||||
return config
|
|
||||||
}
|
|
||||||
|
|
||||||
export let run = async (): Promise<IConfig> => {
|
|
||||||
let config = await getQenvKeyValueObject().then(buildConfig)
|
|
||||||
return config
|
|
||||||
}
|
|
@ -1,165 +0,0 @@
|
|||||||
import * as plugins from './npmdocker.plugins';
|
|
||||||
import * as paths from './npmdocker.paths';
|
|
||||||
import * as snippets from './npmdocker.snippets'
|
|
||||||
|
|
||||||
// interfaces
|
|
||||||
import { IConfig } from './npmdocker.config'
|
|
||||||
|
|
||||||
let config: IConfig
|
|
||||||
|
|
||||||
/**
|
|
||||||
* the docker data used to build the internal testing container
|
|
||||||
*/
|
|
||||||
let dockerData = {
|
|
||||||
imageTag: 'npmdocker-temp-image:latest',
|
|
||||||
containerName: 'npmdocker-temp-container',
|
|
||||||
dockerProjectMountString: '',
|
|
||||||
dockerSockString: '',
|
|
||||||
dockerEnvString: ''
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* check if docker is available
|
|
||||||
*/
|
|
||||||
let checkDocker = () => {
|
|
||||||
let done = plugins.q.defer()
|
|
||||||
plugins.beautylog.ora.text('checking docker...')
|
|
||||||
if (plugins.smartshell.which('docker')) {
|
|
||||||
plugins.beautylog.ok('Docker found!')
|
|
||||||
done.resolve()
|
|
||||||
} else {
|
|
||||||
done.reject(new Error('docker not found on this machine'))
|
|
||||||
}
|
|
||||||
return done.promise
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* builds the Dockerfile according to the config in the project
|
|
||||||
*/
|
|
||||||
let buildDockerFile = () => {
|
|
||||||
let done = plugins.q.defer()
|
|
||||||
plugins.beautylog.ora.text('building Dockerfile...')
|
|
||||||
let dockerfile: string = snippets.dockerfileSnippet({
|
|
||||||
baseImage: config.baseImage,
|
|
||||||
command: config.command
|
|
||||||
})
|
|
||||||
plugins.beautylog.info(`Base image is: ${config.baseImage}`)
|
|
||||||
plugins.beautylog.info(`Command is: ${config.command}`)
|
|
||||||
plugins.smartfile.memory.toFsSync(dockerfile, paths.dockerfile)
|
|
||||||
plugins.beautylog.ok('Dockerfile created!')
|
|
||||||
done.resolve()
|
|
||||||
return done.promise
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* builds the Dockerimage from the built Dockerfile
|
|
||||||
*/
|
|
||||||
let buildDockerImage = async () => {
|
|
||||||
plugins.beautylog.ora.text('pulling latest base image from registry...')
|
|
||||||
await plugins.smartshell.execSilent(
|
|
||||||
`docker pull ${config.baseImage}`
|
|
||||||
).then(async () => {
|
|
||||||
plugins.beautylog.ora.text('building Dockerimage...')
|
|
||||||
// are we creating a build context form project ?
|
|
||||||
if (process.env.CI === 'true') {
|
|
||||||
plugins.beautylog.ora.text('creating build context...')
|
|
||||||
plugins.smartfile.fs.copySync(paths.cwd, paths.buildContextDir)
|
|
||||||
}
|
|
||||||
await plugins.smartshell.execSilent(
|
|
||||||
`docker build -f ${paths.dockerfile} -t ${dockerData.imageTag} ${paths.assets}`
|
|
||||||
).then(async () => {
|
|
||||||
plugins.beautylog.ok('Dockerimage built!')
|
|
||||||
})
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
let buildDockerProjectMountString = async () => {
|
|
||||||
if (process.env.CI !== 'true') {
|
|
||||||
dockerData.dockerProjectMountString = `-v ${paths.cwd}:/workspace`
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* builds an environment string that docker cli understands
|
|
||||||
*/
|
|
||||||
let buildDockerEnvString = async () => {
|
|
||||||
for (let keyValueObjectArg of config.keyValueObjectArray) {
|
|
||||||
let envString = dockerData.dockerEnvString = dockerData.dockerEnvString + `-e ${keyValueObjectArg.key}=${keyValueObjectArg.value} `
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* creates string to mount the docker.sock inside the testcontainer
|
|
||||||
*/
|
|
||||||
let buildDockerSockString = async () => {
|
|
||||||
if (config.dockerSock) {
|
|
||||||
dockerData.dockerSockString = `-v /var/run/docker.sock:/var/run/docker.sock`
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* creates a container by running the built Dockerimage
|
|
||||||
*/
|
|
||||||
let runDockerImage = async () => {
|
|
||||||
let done = plugins.q.defer()
|
|
||||||
plugins.beautylog.ora.text('starting Container...')
|
|
||||||
plugins.beautylog.ora.end()
|
|
||||||
plugins.beautylog.log('now running Dockerimage')
|
|
||||||
config.exitCode = (await plugins.smartshell.exec(`docker run ${dockerData.dockerProjectMountString} ${dockerData.dockerSockString} ${dockerData.dockerEnvString} --name ${dockerData.containerName} ${dockerData.imageTag}`)).exitCode
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* cleans up: deletes the test container
|
|
||||||
*/
|
|
||||||
let deleteDockerContainer = async () => {
|
|
||||||
await plugins.smartshell.execSilent(`docker rm -f ${dockerData.containerName}`)
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* cleans up deletes the test image
|
|
||||||
*/
|
|
||||||
let deleteDockerImage = async () => {
|
|
||||||
await plugins.smartshell.exec(`docker rmi ${dockerData.imageTag}`)
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* cleans up, deletes the build context
|
|
||||||
*/
|
|
||||||
let deleteBuildContext = async () => {
|
|
||||||
await plugins.smartfile.fs.remove(paths.buildContextDir)
|
|
||||||
}
|
|
||||||
|
|
||||||
let preClean = async () => {
|
|
||||||
await deleteDockerImage()
|
|
||||||
.then(deleteDockerContainer)
|
|
||||||
.then(async () => {
|
|
||||||
plugins.beautylog.ok('ensured clean Docker environment!')
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
let postClean = async () => {
|
|
||||||
await deleteDockerContainer()
|
|
||||||
.then(deleteDockerImage)
|
|
||||||
.then(deleteBuildContext)
|
|
||||||
.then(async () => {
|
|
||||||
plugins.beautylog.ok('cleaned up!')
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
export let run = async (configArg: IConfig): Promise<IConfig> => {
|
|
||||||
plugins.beautylog.ora.start()
|
|
||||||
config = configArg
|
|
||||||
let resultConfig = await checkDocker()
|
|
||||||
.then(preClean)
|
|
||||||
.then(buildDockerFile)
|
|
||||||
.then(buildDockerImage)
|
|
||||||
.then(buildDockerProjectMountString)
|
|
||||||
.then(buildDockerEnvString)
|
|
||||||
.then(buildDockerSockString)
|
|
||||||
.then(runDockerImage)
|
|
||||||
.then(postClean)
|
|
||||||
.catch(err => { console.log(err) })
|
|
||||||
return config
|
|
||||||
}
|
|
@ -1,13 +0,0 @@
|
|||||||
import * as plugins from "./npmdocker.plugins";
|
|
||||||
|
|
||||||
// directories
|
|
||||||
export let cwd = process.cwd();
|
|
||||||
export let packageBase = plugins.path.join(__dirname, "../");
|
|
||||||
export let assets = plugins.path.join(packageBase, "assets/");
|
|
||||||
plugins.smartfile.fs.ensureDirSync(assets);
|
|
||||||
|
|
||||||
export let buildContextDir = plugins.path.join(assets,"buildContextDir");
|
|
||||||
plugins.smartfile.fs.ensureDirSync(buildContextDir);
|
|
||||||
|
|
||||||
// files
|
|
||||||
export let dockerfile = plugins.path.join(assets, "Dockerfile");
|
|
@ -1,24 +0,0 @@
|
|||||||
import 'typings-global'
|
|
||||||
import * as beautylog from 'beautylog'
|
|
||||||
import * as npmextra from 'npmextra'
|
|
||||||
import * as path from 'path'
|
|
||||||
import * as projectinfo from 'projectinfo'
|
|
||||||
import * as q from 'smartq'
|
|
||||||
import * as qenv from 'qenv'
|
|
||||||
import * as smartcli from 'smartcli'
|
|
||||||
import * as smartfile from 'smartfile'
|
|
||||||
import * as smartshell from 'smartshell'
|
|
||||||
import * as smartstring from 'smartstring'
|
|
||||||
|
|
||||||
export {
|
|
||||||
beautylog,
|
|
||||||
npmextra,
|
|
||||||
path,
|
|
||||||
projectinfo,
|
|
||||||
q,
|
|
||||||
qenv,
|
|
||||||
smartcli,
|
|
||||||
smartfile,
|
|
||||||
smartshell,
|
|
||||||
smartstring
|
|
||||||
}
|
|
@ -1,24 +0,0 @@
|
|||||||
import * as plugins from "./npmdocker.plugins";
|
|
||||||
|
|
||||||
export interface IDockerfileSnippet {
|
|
||||||
baseImage:string;
|
|
||||||
command:string;
|
|
||||||
}
|
|
||||||
|
|
||||||
export let dockerfileSnippet = (optionsArg:IDockerfileSnippet):string => {
|
|
||||||
let commandArray = optionsArg.command.split(/\s/);
|
|
||||||
let commandString:string = "";
|
|
||||||
for(let stringItem of commandArray){
|
|
||||||
if(!(commandString == "")){
|
|
||||||
commandString = commandString + ",";
|
|
||||||
}
|
|
||||||
commandString = commandString + '"' + stringItem + '"';
|
|
||||||
};
|
|
||||||
return plugins.smartstring.indent.normalize(`
|
|
||||||
FROM ${optionsArg.baseImage}
|
|
||||||
COPY ./buildContextDir /workspace
|
|
||||||
WORKDIR /workspace
|
|
||||||
ENV CI=true
|
|
||||||
CMD [${commandString}];
|
|
||||||
`);
|
|
||||||
}
|
|
90
ts/tsdocker.cli.ts
Normal file
90
ts/tsdocker.cli.ts
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
import * as plugins from './tsdocker.plugins';
|
||||||
|
import * as paths from './tsdocker.paths';
|
||||||
|
|
||||||
|
// modules
|
||||||
|
import * as ConfigModule from './tsdocker.config';
|
||||||
|
import * as DockerModule from './tsdocker.docker';
|
||||||
|
|
||||||
|
import { logger, ora } from './tsdocker.logging';
|
||||||
|
|
||||||
|
const tsdockerCli = new plugins.smartcli.Smartcli();
|
||||||
|
|
||||||
|
export let run = () => {
|
||||||
|
tsdockerCli.standardTask().subscribe(async argvArg => {
|
||||||
|
const configArg = await ConfigModule.run().then(DockerModule.run);
|
||||||
|
if (configArg.exitCode === 0) {
|
||||||
|
logger.log('success', 'container ended all right!');
|
||||||
|
} else {
|
||||||
|
logger.log('error', `container ended with error! Exit Code is ${configArg.exitCode}`);
|
||||||
|
process.exit(1);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* this command is executed inside docker and meant for use from outside docker
|
||||||
|
*/
|
||||||
|
tsdockerCli.addCommand('runinside').subscribe(async argvArg => {
|
||||||
|
logger.log('ok', 'Allright. We are now in Docker!');
|
||||||
|
ora.text('now trying to run your specified command');
|
||||||
|
const configArg = await ConfigModule.run();
|
||||||
|
const smartshellInstance = new plugins.smartshell.Smartshell({
|
||||||
|
executor: 'bash'
|
||||||
|
});
|
||||||
|
ora.stop();
|
||||||
|
await smartshellInstance.exec(configArg.command).then(response => {
|
||||||
|
if (response.exitCode !== 0) {
|
||||||
|
process.exit(1);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
tsdockerCli.addCommand('clean').subscribe(async argvArg => {
|
||||||
|
ora.text('cleaning up docker env...');
|
||||||
|
if (argvArg.all) {
|
||||||
|
const smartshellInstance = new plugins.smartshell.Smartshell({
|
||||||
|
executor: 'bash'
|
||||||
|
});
|
||||||
|
ora.text('killing any running docker containers...');
|
||||||
|
await smartshellInstance.exec(`docker kill $(docker ps -q)`);
|
||||||
|
|
||||||
|
ora.text('removing stopped containers...');
|
||||||
|
await smartshellInstance.exec(`docker rm $(docker ps -a -q)`);
|
||||||
|
|
||||||
|
ora.text('removing images...');
|
||||||
|
await smartshellInstance.exec(`docker rmi -f $(docker images -q -f dangling=true)`);
|
||||||
|
|
||||||
|
ora.text('removing all other images...');
|
||||||
|
await smartshellInstance.exec(`docker rmi $(docker images -a -q)`);
|
||||||
|
|
||||||
|
ora.text('removing all volumes...');
|
||||||
|
await smartshellInstance.exec(`docker volume rm $(docker volume ls -f dangling=true -q)`);
|
||||||
|
}
|
||||||
|
ora.finishSuccess('docker environment now is clean!');
|
||||||
|
});
|
||||||
|
|
||||||
|
tsdockerCli.addCommand('speedtest').subscribe(async argvArg => {
|
||||||
|
const smartshellInstance = new plugins.smartshell.Smartshell({
|
||||||
|
executor: 'bash'
|
||||||
|
});
|
||||||
|
logger.log('ok', 'Starting speedtest');
|
||||||
|
await smartshellInstance.exec(
|
||||||
|
`docker pull tianon/speedtest && docker run --rm tianon/speedtest --accept-license --accept-gdpr`
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
tsdockerCli.addCommand('vscode').subscribe(async argvArg => {
|
||||||
|
const smartshellInstance = new plugins.smartshell.Smartshell({
|
||||||
|
executor: 'bash'
|
||||||
|
});
|
||||||
|
logger.log('ok', `Starting vscode in cwd ${paths.cwd}`);
|
||||||
|
await smartshellInstance.execAndWaitForLine(
|
||||||
|
`docker run -p 127.0.0.1:8443:8443 -v "${
|
||||||
|
paths.cwd
|
||||||
|
}:/home/coder/project" registry.gitlab.com/hosttoday/ht-docker-vscode --allow-http --no-auth`,
|
||||||
|
/Connected to shared process/
|
||||||
|
);
|
||||||
|
await plugins.smartopen.openUrl('testing-vscode.git.zone:8443');
|
||||||
|
});
|
||||||
|
|
||||||
|
tsdockerCli.startParse();
|
||||||
|
};
|
37
ts/tsdocker.config.ts
Normal file
37
ts/tsdocker.config.ts
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
import * as plugins from './tsdocker.plugins';
|
||||||
|
import * as paths from './tsdocker.paths';
|
||||||
|
|
||||||
|
export interface IConfig {
|
||||||
|
baseImage: string;
|
||||||
|
command: string;
|
||||||
|
dockerSock: boolean;
|
||||||
|
exitCode?: number;
|
||||||
|
keyValueObject: {[key: string]: any};
|
||||||
|
}
|
||||||
|
|
||||||
|
const getQenvKeyValueObject = async () => {
|
||||||
|
let qenvKeyValueObjectArray: { [key: string]: string | number };
|
||||||
|
if (plugins.smartfile.fs.fileExistsSync(plugins.path.join(paths.cwd, 'qenv.yml'))) {
|
||||||
|
qenvKeyValueObjectArray = new plugins.qenv.Qenv(paths.cwd, '.nogit/').keyValueObject;
|
||||||
|
} else {
|
||||||
|
qenvKeyValueObjectArray = {};
|
||||||
|
}
|
||||||
|
return qenvKeyValueObjectArray;
|
||||||
|
};
|
||||||
|
|
||||||
|
const buildConfig = async (qenvKeyValueObjectArg: { [key: string]: string | number }) => {
|
||||||
|
const npmextra = new plugins.npmextra.Npmextra(paths.cwd);
|
||||||
|
const config = npmextra.dataFor<IConfig>('npmdocker', {
|
||||||
|
baseImage: 'hosttoday/ht-docker-node:npmdocker',
|
||||||
|
init: 'rm -rf node_nodules/ && yarn install',
|
||||||
|
command: 'npmci npm test',
|
||||||
|
dockerSock: false,
|
||||||
|
keyValueObject: qenvKeyValueObjectArg
|
||||||
|
});
|
||||||
|
return config;
|
||||||
|
};
|
||||||
|
|
||||||
|
export let run = async (): Promise<IConfig> => {
|
||||||
|
const config = await getQenvKeyValueObject().then(buildConfig);
|
||||||
|
return config;
|
||||||
|
};
|
169
ts/tsdocker.docker.ts
Normal file
169
ts/tsdocker.docker.ts
Normal file
@ -0,0 +1,169 @@
|
|||||||
|
import * as plugins from './tsdocker.plugins';
|
||||||
|
import * as paths from './tsdocker.paths';
|
||||||
|
import * as snippets from './tsdocker.snippets';
|
||||||
|
|
||||||
|
import { logger, ora } from './tsdocker.logging';
|
||||||
|
|
||||||
|
const smartshellInstance = new plugins.smartshell.Smartshell({
|
||||||
|
executor: 'bash'
|
||||||
|
});
|
||||||
|
|
||||||
|
// interfaces
|
||||||
|
import { IConfig } from './tsdocker.config';
|
||||||
|
|
||||||
|
let config: IConfig;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* the docker data used to build the internal testing container
|
||||||
|
*/
|
||||||
|
const dockerData = {
|
||||||
|
imageTag: 'npmdocker-temp-image:latest',
|
||||||
|
containerName: 'npmdocker-temp-container',
|
||||||
|
dockerProjectMountString: '',
|
||||||
|
dockerSockString: '',
|
||||||
|
dockerEnvString: ''
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* check if docker is available
|
||||||
|
*/
|
||||||
|
const checkDocker = () => {
|
||||||
|
const done = plugins.smartpromise.defer();
|
||||||
|
ora.text('checking docker...');
|
||||||
|
|
||||||
|
if (smartshellInstance.exec('which docker')) {
|
||||||
|
logger.log('ok', 'Docker found!');
|
||||||
|
done.resolve();
|
||||||
|
} else {
|
||||||
|
done.reject(new Error('docker not found on this machine'));
|
||||||
|
}
|
||||||
|
return done.promise;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* builds the Dockerfile according to the config in the project
|
||||||
|
*/
|
||||||
|
const buildDockerFile = () => {
|
||||||
|
const done = plugins.smartpromise.defer();
|
||||||
|
ora.text('building Dockerfile...');
|
||||||
|
const dockerfile: string = snippets.dockerfileSnippet({
|
||||||
|
baseImage: config.baseImage,
|
||||||
|
command: config.command
|
||||||
|
});
|
||||||
|
logger.log('info', `Base image is: ${config.baseImage}`);
|
||||||
|
logger.log('info', `Command is: ${config.command}`);
|
||||||
|
plugins.smartfile.memory.toFsSync(dockerfile, plugins.path.join(paths.cwd, 'npmdocker'));
|
||||||
|
logger.log('ok', 'Dockerfile created!');
|
||||||
|
ora.stop();
|
||||||
|
done.resolve();
|
||||||
|
return done.promise;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* builds the Dockerimage from the built Dockerfile
|
||||||
|
*/
|
||||||
|
const buildDockerImage = async () => {
|
||||||
|
logger.log('info', 'pulling latest base image from registry...');
|
||||||
|
await smartshellInstance.exec(`docker pull ${config.baseImage}`);
|
||||||
|
ora.text('building Dockerimage...');
|
||||||
|
const execResult = await smartshellInstance.execSilent(
|
||||||
|
`docker build -f npmdocker -t ${dockerData.imageTag} ${paths.cwd}`
|
||||||
|
);
|
||||||
|
if (execResult.exitCode !== 0) {
|
||||||
|
console.log(execResult.stdout);
|
||||||
|
process.exit(1);
|
||||||
|
}
|
||||||
|
logger.log('ok', 'Dockerimage built!');
|
||||||
|
};
|
||||||
|
|
||||||
|
const buildDockerProjectMountString = async () => {
|
||||||
|
if (process.env.CI !== 'true') {
|
||||||
|
dockerData.dockerProjectMountString = `-v ${paths.cwd}:/workspace`;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* builds an environment string that docker cli understands
|
||||||
|
*/
|
||||||
|
const buildDockerEnvString = async () => {
|
||||||
|
for (const key of Object.keys(config.keyValueObject)) {
|
||||||
|
const envString = (dockerData.dockerEnvString =
|
||||||
|
dockerData.dockerEnvString + `-e ${key}=${config.keyValueObject[key]} `);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* creates string to mount the docker.sock inside the testcontainer
|
||||||
|
*/
|
||||||
|
const buildDockerSockString = async () => {
|
||||||
|
if (config.dockerSock) {
|
||||||
|
dockerData.dockerSockString = `-v /var/run/docker.sock:/var/run/docker.sock`;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* creates a container by running the built Dockerimage
|
||||||
|
*/
|
||||||
|
const runDockerImage = async () => {
|
||||||
|
const done = plugins.smartpromise.defer();
|
||||||
|
ora.text('starting Container...');
|
||||||
|
ora.stop();
|
||||||
|
logger.log('info', 'now running Dockerimage');
|
||||||
|
config.exitCode = (await smartshellInstance.exec(
|
||||||
|
`docker run ${dockerData.dockerProjectMountString} ${dockerData.dockerSockString} ${
|
||||||
|
dockerData.dockerEnvString
|
||||||
|
} --name ${dockerData.containerName} ${dockerData.imageTag}`
|
||||||
|
)).exitCode;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* cleans up: deletes the test container
|
||||||
|
*/
|
||||||
|
const deleteDockerContainer = async () => {
|
||||||
|
await smartshellInstance.execSilent(`docker rm -f ${dockerData.containerName}`);
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* cleans up deletes the test image
|
||||||
|
*/
|
||||||
|
const deleteDockerImage = async () => {
|
||||||
|
await smartshellInstance.execSilent(`docker rmi ${dockerData.imageTag}`).then(async response => {
|
||||||
|
if (response.exitCode !== 0) {
|
||||||
|
console.log(response.stdout);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
const preClean = async () => {
|
||||||
|
await deleteDockerImage()
|
||||||
|
.then(deleteDockerContainer)
|
||||||
|
.then(async () => {
|
||||||
|
logger.log('ok', 'ensured clean Docker environment!');
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
const postClean = async () => {
|
||||||
|
await deleteDockerContainer()
|
||||||
|
.then(deleteDockerImage)
|
||||||
|
.then(async () => {
|
||||||
|
logger.log('ok', 'cleaned up!');
|
||||||
|
});
|
||||||
|
plugins.smartfile.fs.removeSync(paths.npmdockerFile);
|
||||||
|
};
|
||||||
|
|
||||||
|
export let run = async (configArg: IConfig): Promise<IConfig> => {
|
||||||
|
config = configArg;
|
||||||
|
const resultConfig = await checkDocker()
|
||||||
|
.then(preClean)
|
||||||
|
.then(buildDockerFile)
|
||||||
|
.then(buildDockerImage)
|
||||||
|
.then(buildDockerProjectMountString)
|
||||||
|
.then(buildDockerEnvString)
|
||||||
|
.then(buildDockerSockString)
|
||||||
|
.then(runDockerImage)
|
||||||
|
.then(postClean)
|
||||||
|
.catch(err => {
|
||||||
|
console.log(err);
|
||||||
|
});
|
||||||
|
return config;
|
||||||
|
};
|
17
ts/tsdocker.logging.ts
Normal file
17
ts/tsdocker.logging.ts
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
import * as plugins from './tsdocker.plugins';
|
||||||
|
|
||||||
|
export const logger = new plugins.smartlog.Smartlog({
|
||||||
|
logContext: {
|
||||||
|
company: 'Some Company',
|
||||||
|
companyunit: 'Some CompanyUnit',
|
||||||
|
containerName: 'Some Containername',
|
||||||
|
environment: 'local',
|
||||||
|
runtime: 'node',
|
||||||
|
zone: 'gitzone'
|
||||||
|
},
|
||||||
|
minimumLogLevel: 'silly'
|
||||||
|
});
|
||||||
|
|
||||||
|
logger.addLogDestination(new plugins.smartlogDestinationLocal.DestinationLocal());
|
||||||
|
|
||||||
|
export const ora = new plugins.smartlogSouceOra.SmartlogSourceOra();
|
8
ts/tsdocker.paths.ts
Normal file
8
ts/tsdocker.paths.ts
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
import * as plugins from './tsdocker.plugins';
|
||||||
|
|
||||||
|
// directories
|
||||||
|
export let cwd = process.cwd();
|
||||||
|
export let packageBase = plugins.path.join(__dirname, '../');
|
||||||
|
export let assets = plugins.path.join(packageBase, 'assets/');
|
||||||
|
plugins.smartfile.fs.ensureDirSync(assets);
|
||||||
|
export let npmdockerFile = plugins.path.join(cwd, 'npmdocker');
|
30
ts/tsdocker.plugins.ts
Normal file
30
ts/tsdocker.plugins.ts
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
// pushrocks scope
|
||||||
|
import * as npmextra from '@pushrocks/npmextra';
|
||||||
|
import * as path from 'path';
|
||||||
|
import * as projectinfo from '@pushrocks/projectinfo';
|
||||||
|
import * as smartpromise from '@pushrocks/smartpromise';
|
||||||
|
import * as qenv from '@pushrocks/qenv';
|
||||||
|
import * as smartcli from '@pushrocks/smartcli';
|
||||||
|
import * as smartfile from '@pushrocks/smartfile';
|
||||||
|
import * as smartlog from '@pushrocks/smartlog';
|
||||||
|
import * as smartlogDestinationLocal from '@pushrocks/smartlog-destination-local';
|
||||||
|
import * as smartlogSouceOra from '@pushrocks/smartlog-source-ora';
|
||||||
|
import * as smartopen from '@pushrocks/smartopen';
|
||||||
|
import * as smartshell from '@pushrocks/smartshell';
|
||||||
|
import * as smartstring from '@pushrocks/smartstring';
|
||||||
|
|
||||||
|
export {
|
||||||
|
npmextra,
|
||||||
|
path,
|
||||||
|
projectinfo,
|
||||||
|
smartpromise,
|
||||||
|
qenv,
|
||||||
|
smartcli,
|
||||||
|
smartfile,
|
||||||
|
smartlog,
|
||||||
|
smartlogDestinationLocal,
|
||||||
|
smartlogSouceOra,
|
||||||
|
smartopen,
|
||||||
|
smartshell,
|
||||||
|
smartstring
|
||||||
|
};
|
37
ts/tsdocker.snippets.ts
Normal file
37
ts/tsdocker.snippets.ts
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
import * as plugins from './tsdocker.plugins';
|
||||||
|
|
||||||
|
export interface IDockerfileSnippet {
|
||||||
|
baseImage: string;
|
||||||
|
command: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
let getMountSolutionString = (optionsArg: IDockerfileSnippet) => {
|
||||||
|
if (process.env.CI) {
|
||||||
|
return 'COPY ./ /workspace';
|
||||||
|
} else {
|
||||||
|
return '# not copying workspcae since not in CI';
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
let getGlobalPreparationString = (optionsArg: IDockerfileSnippet) => {
|
||||||
|
if (optionsArg.baseImage !== 'hosttoday/ht-docker-node:npmdocker') {
|
||||||
|
return 'RUN npm install -g npmdocker';
|
||||||
|
} else {
|
||||||
|
return '# not installing npmdocker since it is included in the base image';
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export let dockerfileSnippet = (optionsArg: IDockerfileSnippet): string => {
|
||||||
|
return plugins.smartstring.indent.normalize(
|
||||||
|
`
|
||||||
|
FROM ${optionsArg.baseImage}
|
||||||
|
# For info about what npmdocker does read the docs at https://gitzone.github.io/npmdocker
|
||||||
|
${getGlobalPreparationString(optionsArg)}
|
||||||
|
${getMountSolutionString(optionsArg)}
|
||||||
|
WORKDIR /workspace
|
||||||
|
ENV CI=true
|
||||||
|
ENTRYPOINT ["npmdocker"]
|
||||||
|
CMD ["runinside"]
|
||||||
|
`
|
||||||
|
);
|
||||||
|
};
|
16
tslint.json
16
tslint.json
@ -1,3 +1,17 @@
|
|||||||
{
|
{
|
||||||
"extends": "tslint-config-standard"
|
"extends": ["tslint:latest", "tslint-config-prettier"],
|
||||||
|
"rules": {
|
||||||
|
"semicolon": [true, "always"],
|
||||||
|
"no-console": false,
|
||||||
|
"ordered-imports": false,
|
||||||
|
"object-literal-sort-keys": false,
|
||||||
|
"member-ordering": {
|
||||||
|
"options":{
|
||||||
|
"order": [
|
||||||
|
"static-method"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"defaultSeverity": "warning"
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user