@zohodesk/testinglibrary 0.0.1 → 0.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +17 -17
- package/bin/cli.js +1 -1
- package/bin/postinstall.js +15 -15
- package/changelog.md +11 -0
- package/jest.config.js +63 -63
- package/npm-shrinkwrap.json +5772 -0
- package/package.json +31 -31
- package/playwright.config.js +112 -112
- package/src/core/jest/preprocessor/jsPreprocessor.js +9 -9
- package/src/core/jest/runner/jest-runner.js +44 -45
- package/src/core/jest/setup/index.js +165 -165
- package/src/core/playwright/codegen.js +60 -61
- package/src/core/playwright/custom-commands.js +2 -2
- package/src/core/playwright/env-initializer.js +23 -23
- package/src/core/playwright/index.js +81 -80
- package/src/core/playwright/readConfigFile.js +17 -17
- package/src/core/playwright/report-generator.js +42 -43
- package/src/core/playwright/test-runner.js +64 -64
- package/src/index.js +8 -8
- package/src/lib/cli.js +34 -34
- package/src/utils/cliArgsToObject.js +34 -34
- package/src/utils/getFilePath.js +8 -8
- package/src/utils/logger.js +27 -27
- package/src/utils/rootPath.js +50 -18
|
@@ -1,81 +1,82 @@
|
|
|
1
|
-
const { expect, test: base } = require('@playwright/test');
|
|
2
|
-
// function test(descrition, callback) {
|
|
3
|
-
// return test(descrition, ({ page }) => {
|
|
4
|
-
// const { locator, ...custompage } = page
|
|
5
|
-
// callback({ page: custompage })
|
|
6
|
-
// })
|
|
7
|
-
// }
|
|
8
|
-
|
|
9
|
-
// class FilteredPage {
|
|
10
|
-
// constructor(page) {
|
|
11
|
-
// this.page = page;
|
|
12
|
-
// this.allowedMethods = ['getByText', 'getByTitle'];
|
|
13
|
-
// this.context = page.context;
|
|
14
|
-
// }
|
|
15
|
-
|
|
16
|
-
// goto(...args) {
|
|
17
|
-
// return this.page['goto'](...args);
|
|
18
|
-
// }
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
// getByRole(...args) {
|
|
22
|
-
// return this.page['getByRole'](...args);
|
|
23
|
-
// }
|
|
24
|
-
// }
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
// function FilteredPage(page) {
|
|
28
|
-
// return {
|
|
29
|
-
// getByRole: () => {
|
|
30
|
-
// throw new Error('You cannnot use getByRole property')
|
|
31
|
-
// }
|
|
32
|
-
// }
|
|
33
|
-
// }
|
|
34
|
-
|
|
35
|
-
const test = base.extend({
|
|
36
|
-
page: async ({ baseURL, page }, use) => {
|
|
37
|
-
// const proxyPage = new Proxy(page, {
|
|
38
|
-
// get: function (obj, prop) {
|
|
39
|
-
// console.log('Gettig Priop', prop);
|
|
40
|
-
// let filterMethod = FilteredPage(page)[prop];
|
|
41
|
-
// if (filterMethod) {
|
|
42
|
-
// return filterMethod;
|
|
43
|
-
// } else {
|
|
44
|
-
// return obj[prop] ? obj[prop] : 'property does not exist';
|
|
45
|
-
// }
|
|
46
|
-
// }
|
|
47
|
-
// })
|
|
48
|
-
page.getBaseUrl = function () {
|
|
49
|
-
if (process.env.mode === 'dev') {
|
|
50
|
-
return `${process.env.domain}?devURL=${process.env.devUrl}`;
|
|
51
|
-
}
|
|
52
|
-
return `${process.env.domain}`;
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
page.getCustomPageUrl = function (url) {
|
|
56
|
-
if (process.env.mode === 'dev') {
|
|
57
|
-
return `${process.env.domain}/${url}?devURL=${process.env.devUrl}`
|
|
58
|
-
}
|
|
59
|
-
return `${process.env.domain}/${url}`
|
|
60
|
-
}
|
|
61
|
-
await use(page);
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
//await use(new FilteredPage(page));
|
|
65
|
-
|
|
66
|
-
// await use(async (page) => {
|
|
67
|
-
// delete page.getByTestId;
|
|
68
|
-
// await page;
|
|
69
|
-
// });
|
|
70
|
-
|
|
71
|
-
},
|
|
72
|
-
context: async ({ context }, use) => {
|
|
73
|
-
await context.addInitScript(() => window.localStorage.setItem('isDnBannerHide', true));
|
|
74
|
-
await use(context);
|
|
75
|
-
}
|
|
76
|
-
})
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
1
|
+
const { expect, test: base } = require('@playwright/test');
|
|
2
|
+
// function test(descrition, callback) {
|
|
3
|
+
// return test(descrition, ({ page }) => {
|
|
4
|
+
// const { locator, ...custompage } = page
|
|
5
|
+
// callback({ page: custompage })
|
|
6
|
+
// })
|
|
7
|
+
// }
|
|
8
|
+
|
|
9
|
+
// class FilteredPage {
|
|
10
|
+
// constructor(page) {
|
|
11
|
+
// this.page = page;
|
|
12
|
+
// this.allowedMethods = ['getByText', 'getByTitle'];
|
|
13
|
+
// this.context = page.context;
|
|
14
|
+
// }
|
|
15
|
+
|
|
16
|
+
// goto(...args) {
|
|
17
|
+
// return this.page['goto'](...args);
|
|
18
|
+
// }
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
// getByRole(...args) {
|
|
22
|
+
// return this.page['getByRole'](...args);
|
|
23
|
+
// }
|
|
24
|
+
// }
|
|
25
|
+
|
|
26
|
+
|
|
27
|
+
// function FilteredPage(page) {
|
|
28
|
+
// return {
|
|
29
|
+
// getByRole: () => {
|
|
30
|
+
// throw new Error('You cannnot use getByRole property')
|
|
31
|
+
// }
|
|
32
|
+
// }
|
|
33
|
+
// }
|
|
34
|
+
|
|
35
|
+
const test = base.extend({
|
|
36
|
+
page: async ({ baseURL, page }, use) => {
|
|
37
|
+
// const proxyPage = new Proxy(page, {
|
|
38
|
+
// get: function (obj, prop) {
|
|
39
|
+
// console.log('Gettig Priop', prop);
|
|
40
|
+
// let filterMethod = FilteredPage(page)[prop];
|
|
41
|
+
// if (filterMethod) {
|
|
42
|
+
// return filterMethod;
|
|
43
|
+
// } else {
|
|
44
|
+
// return obj[prop] ? obj[prop] : 'property does not exist';
|
|
45
|
+
// }
|
|
46
|
+
// }
|
|
47
|
+
// })
|
|
48
|
+
page.getBaseUrl = function () {
|
|
49
|
+
if (process.env.mode === 'dev') {
|
|
50
|
+
return `${process.env.domain}?devURL=${process.env.devUrl}`;
|
|
51
|
+
}
|
|
52
|
+
return `${process.env.domain}`;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
page.getCustomPageUrl = function (url) {
|
|
56
|
+
if (process.env.mode === 'dev') {
|
|
57
|
+
return `${process.env.domain}/${url}?devURL=${process.env.devUrl}`
|
|
58
|
+
}
|
|
59
|
+
return `${process.env.domain}/${url}`
|
|
60
|
+
}
|
|
61
|
+
await use(page);
|
|
62
|
+
|
|
63
|
+
|
|
64
|
+
//await use(new FilteredPage(page));
|
|
65
|
+
|
|
66
|
+
// await use(async (page) => {
|
|
67
|
+
// delete page.getByTestId;
|
|
68
|
+
// await page;
|
|
69
|
+
// });
|
|
70
|
+
|
|
71
|
+
},
|
|
72
|
+
context: async ({ context }, use) => {
|
|
73
|
+
await context.addInitScript(() => window.localStorage.setItem('isDnBannerHide', true));
|
|
74
|
+
await use(context);
|
|
75
|
+
}
|
|
76
|
+
})
|
|
77
|
+
|
|
78
|
+
|
|
79
|
+
module.exports = {
|
|
80
|
+
expect,
|
|
81
|
+
test
|
|
81
82
|
}
|
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
const { existsSync } = require('fs');
|
|
2
|
-
const path = require('path');
|
|
3
|
-
|
|
4
|
-
const fileName = 'test.config.js';
|
|
5
|
-
|
|
6
|
-
function generateConfigFromFile() {
|
|
7
|
-
const filePath = path.resolve(process.cwd(), fileName);
|
|
8
|
-
|
|
9
|
-
if (existsSync(filePath)) {
|
|
10
|
-
const config = require(filePath);
|
|
11
|
-
return config;
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
return {};
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
|
|
1
|
+
const { existsSync } = require('fs');
|
|
2
|
+
const path = require('path');
|
|
3
|
+
|
|
4
|
+
const fileName = 'test.config.js';
|
|
5
|
+
|
|
6
|
+
function generateConfigFromFile() {
|
|
7
|
+
const filePath = path.resolve(process.cwd(), fileName);
|
|
8
|
+
|
|
9
|
+
if (existsSync(filePath)) {
|
|
10
|
+
const config = require(filePath);
|
|
11
|
+
return config;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
return {};
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
|
|
18
18
|
module.exports = generateConfigFromFile;
|
|
@@ -1,44 +1,43 @@
|
|
|
1
|
-
const { spawn } = require('child_process');
|
|
2
|
-
const path = require('path');
|
|
3
|
-
const { Logger } = require('../../utils/logger');
|
|
4
|
-
const
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
const
|
|
11
|
-
const
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
1
|
+
const { spawn } = require('child_process');
|
|
2
|
+
const path = require('path');
|
|
3
|
+
const { Logger } = require('../../utils/logger');
|
|
4
|
+
const { getExecutableBinaryPath } = require('../../utils/rootPath');
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
const userArgs = process.argv.slice(3);
|
|
8
|
+
|
|
9
|
+
const playwrightPath = path.resolve(getExecutableBinaryPath('playwright'));;
|
|
10
|
+
const command = playwrightPath;
|
|
11
|
+
const reportPath = path.resolve(process.cwd(), './playwright-report');
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
const args = ['show-report', reportPath].concat(userArgs);
|
|
15
|
+
|
|
16
|
+
function generateReport() {
|
|
17
|
+
const childProcess = spawn(command, args, { stdio: 'inherit' });
|
|
18
|
+
childProcess.on('error', (error) => {
|
|
19
|
+
Logger.log(Logger.FAILURE_TYPE, error);
|
|
20
|
+
})
|
|
21
|
+
|
|
22
|
+
childProcess.on('exit', (code, signal) => {
|
|
23
|
+
Logger.log(Logger.FAILURE_TYPE, `Child Process Exited with Code ${code} and Signal ${signal}`);
|
|
24
|
+
|
|
25
|
+
process.exit();
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
process.on('exit', () => {
|
|
29
|
+
Logger.log(Logger.INFO_TYPE, 'Terminating Playwright Process...');
|
|
30
|
+
childProcess.kill();
|
|
31
|
+
return;
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
process.on('SIGINT', () => {
|
|
35
|
+
Logger.log(Logger.INFO_TYPE, 'Cleaning up...');
|
|
36
|
+
childProcess.kill();
|
|
37
|
+
process.exit();
|
|
38
|
+
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
|
|
44
43
|
module.exports = generateReport;
|
|
@@ -1,64 +1,64 @@
|
|
|
1
|
-
const { spawn } = require('child_process');
|
|
2
|
-
const path = require('path');
|
|
3
|
-
const { CUSTOM_COMMANDS } = require('./custom-commands');
|
|
4
|
-
const { cliArgsToObject, objectToCliArgs } = require('../../utils/cliArgsToObject');
|
|
5
|
-
const { initializeEnvConfig } = require('./env-initializer');
|
|
6
|
-
const { Logger } = require('../../utils/logger');
|
|
7
|
-
const getFilePathWithExtension = require('../../utils/getFilePath');
|
|
8
|
-
const generateConfigFromFile = require('./readConfigFile');
|
|
9
|
-
const {
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
// Access the command line arguments
|
|
14
|
-
const userArgs = process.argv.slice(2);
|
|
15
|
-
|
|
16
|
-
const userArgsObject = cliArgsToObject(userArgs);
|
|
17
|
-
|
|
18
|
-
initializeEnvConfig(userArgsObject.mode ? userArgsObject.mode : 'dev');
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
generateConfigFromFile();
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
const playwrightArgs = objectToCliArgs(userArgsObject, (key) => !CUSTOM_COMMANDS.includes(key));
|
|
26
|
-
|
|
27
|
-
// Command and arguments for npx playwright test
|
|
28
|
-
const playwrightPath = path.resolve(
|
|
29
|
-
|
|
30
|
-
const command = playwrightPath;
|
|
31
|
-
const args = ['test', '--config', require.resolve('../../../playwright.config.js')].concat(playwrightArgs);
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
function createTestRunner() {
|
|
35
|
-
// Spawn the child process
|
|
36
|
-
|
|
37
|
-
const childProcess = spawn(command, args, { stdio: 'inherit' });
|
|
38
|
-
|
|
39
|
-
childProcess.on('error', (error) => {
|
|
40
|
-
Logger.log(Logger.FAILURE_TYPE, error);
|
|
41
|
-
})
|
|
42
|
-
|
|
43
|
-
childProcess.on('exit', (code, signal) => {
|
|
44
|
-
Logger.log(Logger.FAILURE_TYPE, `Child Process Exited with Code ${code} and Signal ${signal}`);
|
|
45
|
-
|
|
46
|
-
process.exit();
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
process.on('exit', () => {
|
|
50
|
-
Logger.log(Logger.INFO_TYPE, 'Terminating Playwright Process...');
|
|
51
|
-
//childProcess.kill();
|
|
52
|
-
return;
|
|
53
|
-
});
|
|
54
|
-
|
|
55
|
-
process.on('SIGINT', () => {
|
|
56
|
-
Logger.log(Logger.INFO_TYPE, 'Cleaning up...');
|
|
57
|
-
//childProcess.kill();
|
|
58
|
-
process.exit();
|
|
59
|
-
|
|
60
|
-
});
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
module.exports = createTestRunner;
|
|
1
|
+
const { spawn } = require('child_process');
|
|
2
|
+
const path = require('path');
|
|
3
|
+
const { CUSTOM_COMMANDS } = require('./custom-commands');
|
|
4
|
+
const { cliArgsToObject, objectToCliArgs } = require('../../utils/cliArgsToObject');
|
|
5
|
+
const { initializeEnvConfig } = require('./env-initializer');
|
|
6
|
+
const { Logger } = require('../../utils/logger');
|
|
7
|
+
const getFilePathWithExtension = require('../../utils/getFilePath');
|
|
8
|
+
const generateConfigFromFile = require('./readConfigFile');
|
|
9
|
+
const { getExecutableBinaryPath } = require('../../utils/rootPath');
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
// Access the command line arguments
|
|
14
|
+
const userArgs = process.argv.slice(2);
|
|
15
|
+
|
|
16
|
+
const userArgsObject = cliArgsToObject(userArgs);
|
|
17
|
+
|
|
18
|
+
initializeEnvConfig(userArgsObject.mode ? userArgsObject.mode : 'dev');
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
generateConfigFromFile();
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
const playwrightArgs = objectToCliArgs(userArgsObject, (key) => !CUSTOM_COMMANDS.includes(key));
|
|
26
|
+
|
|
27
|
+
// Command and arguments for npx playwright test
|
|
28
|
+
const playwrightPath = path.resolve(getExecutableBinaryPath('playwright'));
|
|
29
|
+
|
|
30
|
+
const command = playwrightPath;
|
|
31
|
+
const args = ['test', '--config', require.resolve('../../../playwright.config.js')].concat(playwrightArgs);
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
function createTestRunner() {
|
|
35
|
+
// Spawn the child process
|
|
36
|
+
|
|
37
|
+
const childProcess = spawn(command, args, { stdio: 'inherit' });
|
|
38
|
+
|
|
39
|
+
childProcess.on('error', (error) => {
|
|
40
|
+
Logger.log(Logger.FAILURE_TYPE, error);
|
|
41
|
+
})
|
|
42
|
+
|
|
43
|
+
childProcess.on('exit', (code, signal) => {
|
|
44
|
+
Logger.log(Logger.FAILURE_TYPE, `Child Process Exited with Code ${code} and Signal ${signal}`);
|
|
45
|
+
|
|
46
|
+
process.exit();
|
|
47
|
+
});
|
|
48
|
+
|
|
49
|
+
process.on('exit', () => {
|
|
50
|
+
Logger.log(Logger.INFO_TYPE, 'Terminating Playwright Process...');
|
|
51
|
+
//childProcess.kill();
|
|
52
|
+
return;
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
process.on('SIGINT', () => {
|
|
56
|
+
Logger.log(Logger.INFO_TYPE, 'Cleaning up...');
|
|
57
|
+
//childProcess.kill();
|
|
58
|
+
process.exit();
|
|
59
|
+
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
|
|
64
|
+
module.exports = createTestRunner;
|
package/src/index.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
const { expect, test } = require('./core/playwright/index');
|
|
2
|
-
const { fireEvent, render } = require('@testing-library/react');
|
|
3
|
-
|
|
4
|
-
module.exports = {
|
|
5
|
-
expect,
|
|
6
|
-
test,
|
|
7
|
-
fireEvent,
|
|
8
|
-
render
|
|
1
|
+
const { expect, test } = require('./core/playwright/index');
|
|
2
|
+
const { fireEvent, render } = require('@testing-library/react');
|
|
3
|
+
|
|
4
|
+
module.exports = {
|
|
5
|
+
expect,
|
|
6
|
+
test,
|
|
7
|
+
fireEvent,
|
|
8
|
+
render
|
|
9
9
|
}
|
package/src/lib/cli.js
CHANGED
|
@@ -1,35 +1,35 @@
|
|
|
1
|
-
const createTestRunner = require("../core/playwright/test-runner");
|
|
2
|
-
const createJestRunner = require('../core/jest/runner/jest-runner');
|
|
3
|
-
const generateReport = require("../core/playwright/report-generator");
|
|
4
|
-
const generateCodegen = require('../core/playwright/codegen')
|
|
5
|
-
const { Logger } = require("../utils/logger");
|
|
6
|
-
|
|
7
|
-
const [, , option] = process.argv;
|
|
8
|
-
const args = process.argv.slice(3);
|
|
9
|
-
const appPath = process.cwd();
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
switch (option) {
|
|
13
|
-
case 'test': {
|
|
14
|
-
Logger.log(Logger.SUCCESS_TYPE, 'Running Tests..');
|
|
15
|
-
createTestRunner();
|
|
16
|
-
//createJestRunner();
|
|
17
|
-
break;
|
|
18
|
-
}
|
|
19
|
-
case 'report': {
|
|
20
|
-
// console.log('\x1b[36mGenerating Reports...\x1b[0m');
|
|
21
|
-
Logger.log(Logger.SUCCESS_TYPE, 'Generating Reports...');
|
|
22
|
-
generateReport();
|
|
23
|
-
break;
|
|
24
|
-
}
|
|
25
|
-
case 'codegen': {
|
|
26
|
-
Logger.log(Logger.INFO_TYPE, 'The purpose of codegen is to assist developer .....')
|
|
27
|
-
generateCodegen();
|
|
28
|
-
break;
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
default: {
|
|
32
|
-
console.log('Supported Commands test and report')
|
|
33
|
-
break;
|
|
34
|
-
}
|
|
1
|
+
const createTestRunner = require("../core/playwright/test-runner");
|
|
2
|
+
const createJestRunner = require('../core/jest/runner/jest-runner');
|
|
3
|
+
const generateReport = require("../core/playwright/report-generator");
|
|
4
|
+
const generateCodegen = require('../core/playwright/codegen')
|
|
5
|
+
const { Logger } = require("../utils/logger");
|
|
6
|
+
|
|
7
|
+
const [, , option] = process.argv;
|
|
8
|
+
const args = process.argv.slice(3);
|
|
9
|
+
const appPath = process.cwd();
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
switch (option) {
|
|
13
|
+
case 'test': {
|
|
14
|
+
Logger.log(Logger.SUCCESS_TYPE, 'Running Tests..');
|
|
15
|
+
createTestRunner();
|
|
16
|
+
//createJestRunner();
|
|
17
|
+
break;
|
|
18
|
+
}
|
|
19
|
+
case 'report': {
|
|
20
|
+
// console.log('\x1b[36mGenerating Reports...\x1b[0m');
|
|
21
|
+
Logger.log(Logger.SUCCESS_TYPE, 'Generating Reports...');
|
|
22
|
+
generateReport();
|
|
23
|
+
break;
|
|
24
|
+
}
|
|
25
|
+
case 'codegen': {
|
|
26
|
+
Logger.log(Logger.INFO_TYPE, 'The purpose of codegen is to assist developer .....')
|
|
27
|
+
generateCodegen();
|
|
28
|
+
break;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
default: {
|
|
32
|
+
console.log('Supported Commands test and report')
|
|
33
|
+
break;
|
|
34
|
+
}
|
|
35
35
|
}
|
|
@@ -1,35 +1,35 @@
|
|
|
1
|
-
function cliArgsToObject(cliArgs, isKeyNeedToBeAdded) {
|
|
2
|
-
const processEnv = {};
|
|
3
|
-
cliArgs.forEach(option => {
|
|
4
|
-
if (/^--./.test(option)) {
|
|
5
|
-
const equIndex = option.indexOf('=');
|
|
6
|
-
let key = option.slice(2, equIndex);
|
|
7
|
-
let value = option.slice(equIndex + 1);
|
|
8
|
-
if (equIndex === -1) {
|
|
9
|
-
key = option.slice(2);
|
|
10
|
-
value = true;
|
|
11
|
-
}
|
|
12
|
-
processEnv[key] = value;
|
|
13
|
-
}
|
|
14
|
-
});
|
|
15
|
-
return processEnv;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
function objectToCliArgs(objectToBeConverted, isKeyNeedToBeAdded) {
|
|
19
|
-
const argsArray = [];
|
|
20
|
-
|
|
21
|
-
Object.keys(objectToBeConverted).forEach(key => {
|
|
22
|
-
if (isKeyNeedToBeAdded(key)) {
|
|
23
|
-
if (typeof objectToBeConverted[key] === 'boolean' && objectToBeConverted[key]) {
|
|
24
|
-
argsArray.push(`--${key}`)
|
|
25
|
-
} else {
|
|
26
|
-
argsArray.push(`--${key}=${objectToBeConverted[key]}`)
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
})
|
|
30
|
-
|
|
31
|
-
return argsArray;
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
|
|
1
|
+
function cliArgsToObject(cliArgs, isKeyNeedToBeAdded) {
|
|
2
|
+
const processEnv = {};
|
|
3
|
+
cliArgs.forEach(option => {
|
|
4
|
+
if (/^--./.test(option)) {
|
|
5
|
+
const equIndex = option.indexOf('=');
|
|
6
|
+
let key = option.slice(2, equIndex);
|
|
7
|
+
let value = option.slice(equIndex + 1);
|
|
8
|
+
if (equIndex === -1) {
|
|
9
|
+
key = option.slice(2);
|
|
10
|
+
value = true;
|
|
11
|
+
}
|
|
12
|
+
processEnv[key] = value;
|
|
13
|
+
}
|
|
14
|
+
});
|
|
15
|
+
return processEnv;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
function objectToCliArgs(objectToBeConverted, isKeyNeedToBeAdded) {
|
|
19
|
+
const argsArray = [];
|
|
20
|
+
|
|
21
|
+
Object.keys(objectToBeConverted).forEach(key => {
|
|
22
|
+
if (isKeyNeedToBeAdded(key)) {
|
|
23
|
+
if (typeof objectToBeConverted[key] === 'boolean' && objectToBeConverted[key]) {
|
|
24
|
+
argsArray.push(`--${key}`)
|
|
25
|
+
} else {
|
|
26
|
+
argsArray.push(`--${key}=${objectToBeConverted[key]}`)
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
})
|
|
30
|
+
|
|
31
|
+
return argsArray;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
|
|
35
35
|
module.exports = { cliArgsToObject, objectToCliArgs };
|
package/src/utils/getFilePath.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
const { platform } = require('os');
|
|
2
|
-
|
|
3
|
-
const isWindows = platform().toLowerCase() === 'win32';
|
|
4
|
-
|
|
5
|
-
function getFilePathWithExtension(binName) {
|
|
6
|
-
return isWindows ? `${binName}.cmd` : binName;
|
|
7
|
-
}
|
|
8
|
-
|
|
1
|
+
const { platform } = require('os');
|
|
2
|
+
|
|
3
|
+
const isWindows = platform().toLowerCase() === 'win32';
|
|
4
|
+
|
|
5
|
+
function getFilePathWithExtension(binName) {
|
|
6
|
+
return isWindows ? `${binName}.cmd` : binName;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
9
|
module.exports = getFilePathWithExtension;
|
package/src/utils/logger.js
CHANGED
|
@@ -1,28 +1,28 @@
|
|
|
1
|
-
const SUCCESS_TYPE = 'success';
|
|
2
|
-
const FAILURE_TYPE = 'failure';
|
|
3
|
-
const INFO_TYPE = 'info';
|
|
4
|
-
|
|
5
|
-
function logger() {
|
|
6
|
-
this.colors = {
|
|
7
|
-
'success': ['\x1b[36m', '\x1b[0m'],
|
|
8
|
-
'failure': ['\x1b[31m', '\x1b[0m'],
|
|
9
|
-
'info': ['\x1b[33m', '\x1b[0m']
|
|
10
|
-
}
|
|
11
|
-
this.consoleLogger = console;
|
|
12
|
-
return {
|
|
13
|
-
SUCCESS_TYPE,
|
|
14
|
-
FAILURE_TYPE,
|
|
15
|
-
INFO_TYPE,
|
|
16
|
-
error: () => { },
|
|
17
|
-
info: () => { },
|
|
18
|
-
log: (type, message) => {
|
|
19
|
-
const color = this.colors[type];
|
|
20
|
-
this.consoleLogger.log(`${color[0]}${message}${color[1]}`)
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
module.exports = {
|
|
27
|
-
Logger: logger()
|
|
1
|
+
const SUCCESS_TYPE = 'success';
|
|
2
|
+
const FAILURE_TYPE = 'failure';
|
|
3
|
+
const INFO_TYPE = 'info';
|
|
4
|
+
|
|
5
|
+
function logger() {
|
|
6
|
+
this.colors = {
|
|
7
|
+
'success': ['\x1b[36m', '\x1b[0m'],
|
|
8
|
+
'failure': ['\x1b[31m', '\x1b[0m'],
|
|
9
|
+
'info': ['\x1b[33m', '\x1b[0m']
|
|
10
|
+
}
|
|
11
|
+
this.consoleLogger = console;
|
|
12
|
+
return {
|
|
13
|
+
SUCCESS_TYPE,
|
|
14
|
+
FAILURE_TYPE,
|
|
15
|
+
INFO_TYPE,
|
|
16
|
+
error: () => { },
|
|
17
|
+
info: () => { },
|
|
18
|
+
log: (type, message) => {
|
|
19
|
+
const color = this.colors[type];
|
|
20
|
+
this.consoleLogger.log(`${color[0]}${message}${color[1]}`)
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
module.exports = {
|
|
27
|
+
Logger: logger()
|
|
28
28
|
}
|