@zohodesk/react-cli 0.0.1-beta.17 → 0.0.1-beta.171
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/.eslintignore +1 -0
- package/.eslintrc.js +49 -10
- package/.prettierrc +6 -0
- package/CHANGELOG.md +5 -0
- package/README.md +859 -0
- package/bin/cli.js +215 -46
- package/cert/Tsicsezwild-22-23.crt +37 -0
- package/cert/Tsicsezwild-22-23.key +27 -0
- package/docs/CustomChunks.md +26 -0
- package/docs/DevStart.md +18 -0
- package/docs/HoverActive.md +12 -0
- package/docs/InstallNode.md +28 -0
- package/docs/TODOS.md +10 -0
- package/docs/ValueReplacer.md +60 -0
- package/docs/warnings_while_install.txt +35 -0
- package/files/eslintrc.js +62 -0
- package/files/prettierrc.js +3 -0
- package/lib/babel/cmjs-plugins-presets.js +24 -0
- package/lib/babel/es-plugins-presets.js +34 -0
- package/lib/common/getEntries.js +33 -46
- package/lib/common/getPublicPathConfig.js +40 -0
- package/lib/common/index.js +24 -19
- package/lib/common/splitChunks.js +110 -25
- package/lib/common/sslcertUpdater.js +59 -0
- package/lib/common/templateParameters.js +25 -0
- package/lib/common/testPattern.js +69 -0
- package/lib/common/valueReplacer.js +55 -0
- package/lib/configs/jest.config.js +31 -27
- package/lib/configs/libAlias.js +31 -0
- package/lib/configs/webpack.component.umd.config.js +46 -53
- package/lib/configs/webpack.css.umd.config.js +47 -46
- package/lib/configs/webpack.dev.config.js +99 -84
- package/lib/configs/webpack.docs.config.js +65 -57
- package/lib/configs/webpack.impact.config.js +109 -0
- package/lib/configs/webpack.prod.config.js +147 -104
- package/lib/hooks/docsProptypeHook.js +32 -38
- package/lib/jest/commitedFilesResult.js +144 -71
- package/lib/jest/coverageCollector.js +68 -35
- package/lib/jest/jsonMaker.js +54 -0
- package/lib/jest/preProcessors/cssPreprocessor.js +16 -18
- package/lib/jest/preProcessors/jsPreprocessor.js +5 -6
- package/lib/jest/preProcessors/otherFilesPreprocessor.js +5 -6
- package/lib/jest/result.js +92 -42
- package/lib/jest/run.js +75 -28
- package/lib/jest/setup.js +103 -102
- package/lib/loaderUtils/configsAssetsLoaders.js +117 -0
- package/lib/loaderUtils/getCSSLoaders.js +113 -0
- package/lib/loaderUtils/getDevJsLoaders.js +35 -23
- package/lib/loaderUtils/index.js +14 -7
- package/lib/loaders/docsLoader.js +15 -15
- package/lib/loaders/docsPropsLoader.js +14 -17
- package/lib/loaders/fileBountryLoader.js +17 -0
- package/lib/loaders/fileLoader.js +47 -38
- package/lib/loaders/scriptInstrumentLoader.js +23 -20
- package/lib/loaders/selectorMappingLoader.js +75 -0
- package/lib/loaders/workerLoader.js +136 -0
- package/lib/middlewares/HMRMiddleware.js +90 -72
- package/lib/middlewares/SSTMiddleware.js +21 -0
- package/lib/pluginUtils/getDevPlugins.js +177 -30
- package/lib/pluginUtils/getDocsPlugins.js +36 -15
- package/lib/pluginUtils/getLibraryImactPlugins.js +23 -0
- package/lib/pluginUtils/getLibraryPlugins.js +8 -10
- package/lib/pluginUtils/getProdPlugins.js +244 -37
- package/lib/pluginUtils/getServerPlugins.js +8 -11
- package/lib/pluginUtils/getUMDCSSPlugins.js +14 -18
- package/lib/pluginUtils/getUMDComponentPlugins.js +14 -9
- package/lib/pluginUtils/index.js +36 -43
- package/lib/plugins/CdnChangePlugin.js +77 -0
- package/lib/plugins/CleanupStatsPlugin.js +28 -0
- package/lib/plugins/EFCPlugin.js +241 -0
- package/lib/plugins/EFCPlugin.md +6 -0
- package/lib/plugins/EFCTemplatePlugin.js +151 -0
- package/lib/plugins/I18NInjectIntoIndexPlugin.js +141 -0
- package/lib/plugins/I18nSplitPlugin/I18nDebugPlugin.js +60 -0
- package/lib/plugins/I18nSplitPlugin/I18nDependency.js +44 -0
- package/lib/plugins/I18nSplitPlugin/I18nDownlodLogic.js +266 -0
- package/lib/plugins/I18nSplitPlugin/I18nFilesEmitter.js +183 -0
- package/lib/plugins/I18nSplitPlugin/I18nKeysIdentifer.js +100 -0
- package/lib/plugins/I18nSplitPlugin/I18nSplit.md +95 -0
- package/lib/plugins/I18nSplitPlugin/README.md +25 -0
- package/lib/plugins/I18nSplitPlugin/index.js +185 -0
- package/lib/plugins/I18nSplitPlugin/utils/collectI18nKeys.js +64 -0
- package/lib/plugins/I18nSplitPlugin/utils/getI18nFileUrlPathTemplate.js +13 -0
- package/lib/plugins/I18nSplitPlugin/utils/getI18nKeysFormModules.js +26 -0
- package/lib/plugins/I18nSplitPlugin/utils/hashUtils.js +40 -0
- package/lib/plugins/I18nSplitPlugin/utils/index.js +31 -0
- package/lib/plugins/I18nSplitPlugin/utils/propertiesUtils.js +112 -0
- package/lib/plugins/ManifestPlugin.js +86 -0
- package/lib/plugins/ModuleStatsPlugin.js +98 -97
- package/lib/plugins/OptimizeJSPlugin.js +41 -0
- package/lib/plugins/PublicPathCallbackPlugin.js +63 -0
- package/lib/plugins/PublicPathChangePlugin.js +226 -0
- package/lib/plugins/ReportGeneratePlugin.js +181 -0
- package/lib/plugins/RequireVariablePublicPlugin.js +30 -0
- package/lib/plugins/ResourceHintsPlugin.js +67 -0
- package/lib/plugins/RtlSplitPlugin/OverwriteCssPathForRTL.js +80 -0
- package/lib/plugins/RtlSplitPlugin/RtlCssPlugin.js +82 -0
- package/lib/plugins/RtlSplitPlugin/RtrSplit.md +30 -0
- package/lib/plugins/RtlSplitPlugin/replaceCssDirTemplate.js +26 -0
- package/lib/plugins/ScriptInstrumentPlugin.js +22 -37
- package/lib/plugins/ServiceWorkerPlugin.js +107 -0
- package/lib/plugins/ShadowDOMSupportPlugin.js +270 -0
- package/lib/plugins/SourceMapHookPlugin.js +25 -59
- package/lib/plugins/TPHashMappingPlugin.js +67 -0
- package/lib/plugins/UglifyCSSPlugin.js +39 -0
- package/lib/plugins/UnusedFilesFindPlugin.js +150 -97
- package/lib/plugins/index.js +127 -37
- package/lib/plugins/libraryImpactPlugin.js +190 -0
- package/lib/plugins/webpackwatchrunplugin.js +26 -0
- package/lib/postcss-plugins/ExcludePlugin.js +23 -0
- package/lib/postcss-plugins/RTLSplitPlugin.js +138 -0
- package/lib/postcss-plugins/ValueReplacer.js +46 -0
- package/lib/postcss-plugins/__test__/hoverActivePlugin.spec.js +22 -0
- package/lib/postcss-plugins/__test__/test1Input.css +39 -0
- package/lib/postcss-plugins/__test__/test1Output.css +39 -0
- package/lib/postcss-plugins/hoverActivePlugin.js +368 -0
- package/lib/postcss-plugins/variableModifier.js +243 -0
- package/lib/schemas/index.js +541 -65
- package/lib/servers/clusterHubServer.js +22 -26
- package/lib/servers/devBuild.js +102 -0
- package/lib/servers/docsServer.js +3 -5
- package/lib/servers/docsServerCore.js +94 -79
- package/lib/servers/getCliPath.js +28 -0
- package/lib/servers/helpServer.js +19 -21
- package/lib/servers/httpsOptions.js +18 -0
- package/lib/servers/impactServer.js +123 -115
- package/lib/servers/mockserver.js +44 -0
- package/lib/servers/nowatchserver.js +200 -0
- package/lib/servers/scrServer.js +147 -0
- package/lib/servers/server.js +134 -132
- package/lib/servers/ssServer.js +106 -70
- package/lib/sh/reportPublish.sh +16 -10
- package/lib/templates/CoverageScriptTemplate.js +45 -18
- package/lib/templates/WMSTemplate.js +17 -18
- package/lib/templates/linterConstant.js +10 -0
- package/lib/utils/babelPresets.js +12 -4
- package/lib/utils/buildstats.html +148 -0
- package/lib/utils/clean.js +12 -11
- package/lib/utils/copy.js +16 -109
- package/lib/utils/copyTimezones.js +21 -0
- package/lib/utils/createEventStream.js +24 -19
- package/lib/utils/cssClassNameGenerate.js +77 -0
- package/lib/utils/cssURLReplacer.js +136 -0
- package/lib/utils/dependencyPostPublish.js +42 -0
- package/lib/utils/fileUtils.js +125 -0
- package/lib/utils/folderIterator.js +47 -0
- package/lib/utils/getComponents.js +126 -0
- package/lib/utils/getCurrentBranch.js +11 -17
- package/lib/utils/getDependenciesImpactList.js +151 -0
- package/lib/utils/getHash.js +26 -0
- package/lib/utils/getIp.js +20 -0
- package/lib/utils/getOptions.js +113 -28
- package/lib/utils/getServerURL.js +25 -8
- package/lib/utils/index.js +283 -68
- package/lib/utils/init.js +2 -2
- package/lib/utils/initPreCommitHook.js +47 -27
- package/lib/utils/jsonHelper.js +106 -0
- package/lib/utils/libraryImpactConfig.js +63 -0
- package/lib/utils/lint/addScripts.js +27 -0
- package/lib/utils/lint/checkExistingConfig.js +67 -0
- package/lib/utils/lint/copyConfigs.js +24 -0
- package/lib/utils/lint/index.js +54 -0
- package/lib/utils/lint/lintScripts.js +11 -0
- package/lib/utils/lint/lintSetup.js +31 -0
- package/lib/utils/lint/lintStagedPreCommitHook.js +7 -0
- package/lib/utils/lint/question.js +30 -0
- package/lib/utils/lintReporter.js +142 -0
- package/lib/utils/mailSender.js +16 -25
- package/lib/utils/pullOrigin.js +28 -0
- package/lib/utils/reinstallDependencies.js +133 -0
- package/lib/utils/removeAttributes.js +25 -23
- package/lib/utils/repoClone.js +59 -63
- package/lib/utils/request.js +64 -77
- package/lib/utils/resultSchema.json +73 -0
- package/lib/utils/rtl.js +59 -0
- package/lib/utils/setEnvVariables.js +13 -0
- package/lib/utils/ssTestHack.js +48 -0
- package/lib/utils/switchBranch.js +28 -0
- package/lib/utils/urlConcat.js +22 -0
- package/lib/utils/useExitCleanup.js +55 -0
- package/npm8.md +9 -0
- package/package.json +96 -64
- package/postpublish.js +6 -0
- package/templates/app/.eslintrc.js +140 -0
- package/templates/app/README.md +12 -12
- package/templates/app/app/index.html +24 -8
- package/templates/app/app/properties/ApplicationResources_en_US.properties +1 -1
- package/templates/app/app/properties/i18nkeys.json +3 -3
- package/templates/app/docs/all.html +69 -69
- package/templates/app/mockapi/index.js +18 -13
- package/templates/app/package.json +37 -17
- package/templates/app/src/actions/SampleActions/index.js +37 -0
- package/templates/app/src/actions/index.js +65 -0
- package/templates/app/src/appUrls.js +19 -0
- package/templates/app/src/components/Alert/Alert.js +134 -0
- package/templates/app/src/components/Alert/Alert.module.css +79 -0
- package/templates/app/src/components/FreezeLayer/FreezeLayer.css +37 -0
- package/templates/app/src/components/FreezeLayer/FreezeLayer.js +84 -0
- package/templates/app/src/components/Sample/Sample.module.css +11 -0
- package/templates/app/src/components/Sample/SampleList.js +61 -0
- package/templates/app/src/components/Slider/Slider.css +41 -0
- package/templates/app/src/components/Slider/Slider.js +55 -0
- package/templates/app/src/containers/AlertContainer/index.js +15 -0
- package/templates/app/src/containers/AppContainer/index.js +96 -0
- package/templates/app/src/containers/AppContainer/index.module.css +27 -0
- package/templates/app/src/containers/CustomMatch/index.js +65 -0
- package/templates/app/src/containers/DevTools/index.js +10 -0
- package/templates/app/src/containers/Header/index.js +67 -0
- package/templates/app/src/containers/Header/index.module.css +43 -0
- package/templates/app/src/containers/Redirect/index.js +63 -0
- package/templates/app/src/containers/Redirector/index.js +47 -0
- package/templates/app/src/containers/SampleListContainer/ListContainer.js +42 -0
- package/templates/app/src/containers/SampleListContainer/ListContainer.module.css +3 -0
- package/templates/app/src/historyChange.js +5 -0
- package/templates/app/src/index.html +10 -0
- package/templates/app/src/index.js +24 -0
- package/templates/app/src/middleware/PromiseMiddleware.js +59 -0
- package/templates/app/src/reducers/alertData.js +11 -0
- package/templates/app/src/reducers/index.js +6 -0
- package/templates/app/src/reducers/samples.js +19 -0
- package/templates/app/src/store/configureStore.dev.js +51 -0
- package/templates/app/src/store/configureStore.js +5 -0
- package/templates/app/src/store/configureStore.prod.js +26 -0
- package/templates/app/src/util/Common.js +5 -0
- package/templates/app/src/util/RequestAPI.js +132 -0
- package/templates/appold/README.md +12 -0
- package/templates/appold/app/index.html +8 -0
- package/templates/appold/app/properties/ApplicationResources_en_US.properties +1 -0
- package/templates/appold/app/properties/i18nkeys.json +3 -0
- package/templates/appold/docs/all.html +69 -0
- package/templates/appold/mockapi/index.js +13 -0
- package/templates/{app → appold}/mockapi/tickets.json +0 -0
- package/templates/appold/package.json +17 -0
- package/templates/appold/src/components/Text/Text.css +0 -0
- package/templates/appold/src/components/Text/Text.js +23 -0
- package/templates/appold/src/components/Text/__tests__/Text.spec.js +30 -0
- package/templates/appold/src/components/Text/docs/Text__default.docs.js +16 -0
- package/templates/appold/src/components/docs.js +1 -0
- package/templates/appold/src/components/index.js +5 -0
- package/templates/appold/src/index.js +13 -0
- package/templates/docs/all.html +1 -1
- package/templates/docs/component.html +110 -69
- package/templates/docs/components.html +221 -0
- package/templates/docs/css/component.css +12 -14
- package/templates/docs/css/componentTest.css +7 -0
- package/templates/docs/css/style.css +150 -206
- package/templates/docs/impactReportTemplate.html +154 -0
- package/templates/docs/index.html +1482 -1336
- package/templates/library/src/index.js +0 -0
- package/.npmignore +0 -3
- package/cert/cert.pem +0 -129
- package/cert/key.pem +0 -27
- package/lib/common/getInsertAt.js +0 -36
- package/lib/common/getInsertIntoFunction.js +0 -13
- package/lib/configs/webpack.server.config.js +0 -93
- package/lib/plugins/ChunkManifestReplacePlugin.js +0 -94
- package/lib/plugins/RuntimePublicPathPlugin.js +0 -46
- package/lib/rmcntrlm.sh +0 -14
- package/lib/servers/nodeServer.js +0 -238
- package/lib/templates/HMRTemplate.js +0 -256
- package/lib/templates/publicPathTemplate.js +0 -16
- package/lib/utils/setConfig.js +0 -14
- package/node_modules/history/CHANGES.md +0 -395
- package/node_modules/history/DOMUtils.js +0 -3
- package/node_modules/history/ExecutionEnvironment.js +0 -3
- package/node_modules/history/LICENSE +0 -21
- package/node_modules/history/LocationUtils.js +0 -3
- package/node_modules/history/PathUtils.js +0 -3
- package/node_modules/history/README.md +0 -282
- package/node_modules/history/cjs/history.js +0 -933
- package/node_modules/history/cjs/history.min.js +0 -1
- package/node_modules/history/createBrowserHistory.js +0 -3
- package/node_modules/history/createHashHistory.js +0 -3
- package/node_modules/history/createMemoryHistory.js +0 -3
- package/node_modules/history/createTransitionManager.js +0 -3
- package/node_modules/history/es/DOMUtils.js +0 -7
- package/node_modules/history/es/ExecutionEnvironment.js +0 -7
- package/node_modules/history/es/LocationUtils.js +0 -7
- package/node_modules/history/es/PathUtils.js +0 -7
- package/node_modules/history/es/createBrowserHistory.js +0 -7
- package/node_modules/history/es/createHashHistory.js +0 -7
- package/node_modules/history/es/createMemoryHistory.js +0 -7
- package/node_modules/history/es/createTransitionManager.js +0 -7
- package/node_modules/history/es/warnAboutDeprecatedESMImport.js +0 -35
- package/node_modules/history/esm/history.js +0 -904
- package/node_modules/history/index.js +0 -7
- package/node_modules/history/package.json +0 -134
- package/node_modules/history/umd/history.js +0 -1059
- package/node_modules/history/umd/history.min.js +0 -1
- package/node_modules/history/warnAboutDeprecatedCJSRequire.js +0 -35
- package/templates/app/.npmignore +0 -9
- package/templates/library/.npmignore +0 -9
package/lib/jest/result.js
CHANGED
@@ -1,42 +1,46 @@
|
|
1
|
-
|
1
|
+
"use strict";
|
2
2
|
|
3
|
-
var _fs = require(
|
3
|
+
var _fs = _interopRequireDefault(require("fs"));
|
4
4
|
|
5
|
-
var
|
5
|
+
var _utils = require("../utils");
|
6
6
|
|
7
|
-
var
|
7
|
+
var _jsonMaker = _interopRequireDefault(require("./jsonMaker"));
|
8
8
|
|
9
9
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
10
10
|
|
11
|
-
|
12
|
-
|
13
|
-
|
11
|
+
let unitTestReport = [];
|
12
|
+
|
13
|
+
const result = inp => {
|
14
|
+
inp.endTime = Date.now();
|
15
|
+
let testPathPattern = process.argv[process.argv.length - 1];
|
16
|
+
|
14
17
|
if (testPathPattern.indexOf('--') !== -1) {
|
15
18
|
testPathPattern = '';
|
16
19
|
} else {
|
17
|
-
testPathPattern =
|
20
|
+
testPathPattern = _fs.default.realpathSync(process.cwd());
|
18
21
|
}
|
19
|
-
var testPathRegex = new RegExp(testPathPattern);
|
20
|
-
var testResults = inp.testResults;
|
21
22
|
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
23
|
+
let testPathRegex = new RegExp(testPathPattern);
|
24
|
+
let {
|
25
|
+
testResults
|
26
|
+
} = inp;
|
27
|
+
let testFilesArr = [];
|
28
|
+
testResults.forEach(testResult => {
|
29
|
+
let filePath = testResult.testFilePath;
|
30
|
+
|
26
31
|
if (!testPathRegex.test(filePath)) {
|
27
32
|
return;
|
28
33
|
}
|
34
|
+
|
29
35
|
filePath = filePath.replace('.spec', '');
|
30
36
|
filePath = filePath.replace('/__tests__', '');
|
31
37
|
filePath = filePath.replace('/__test__', '');
|
32
|
-
|
38
|
+
let fileJson = {};
|
33
39
|
fileJson.testPath = testResult.testFilePath;
|
34
40
|
fileJson.sourcePath = filePath;
|
35
41
|
fileJson.data = testResult;
|
36
42
|
testFilesArr.push(fileJson);
|
37
|
-
testResult.testResults && testResult.testResults.filter(
|
38
|
-
return t.status === 'failed';
|
39
|
-
}).forEach(function (t) {
|
43
|
+
testResult.testResults && testResult.testResults.filter(t => t.status === 'failed').forEach(t => {
|
40
44
|
unitTestReport.push({
|
41
45
|
title: t.title,
|
42
46
|
fullName: t.fullName,
|
@@ -45,51 +49,97 @@ var result = function result(inp) {
|
|
45
49
|
});
|
46
50
|
});
|
47
51
|
|
48
|
-
|
52
|
+
let coverageSummary = _fs.default.readFileSync('./coverage/coverage-summary.json').toString();
|
53
|
+
|
49
54
|
if (coverageSummary.indexOf('\\') !== -1) {
|
50
55
|
coverageSummary = coverageSummary.replace(/\\/g, '\\\\');
|
51
56
|
}
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
57
|
+
|
58
|
+
let coverageJson = JSON.parse(coverageSummary);
|
59
|
+
let linesPercent = 0;
|
60
|
+
let functionPercent = 0;
|
61
|
+
let statementPerment = 0;
|
62
|
+
let branchesPercent = 0;
|
63
|
+
let i = 0;
|
64
|
+
|
58
65
|
for (i; i < testFilesArr.length; i++) {
|
59
|
-
|
60
|
-
|
66
|
+
let curSourceFile = testFilesArr[i].sourcePath;
|
67
|
+
let coverageData = coverageJson[curSourceFile];
|
68
|
+
|
61
69
|
if (!coverageData) {
|
62
|
-
(0, _utils.log)(
|
70
|
+
(0, _utils.log)(`Can't able to find source for ${testFilesArr[i].testPath}\n Or The spec file getting failed during test. Please check the file name and the path is correct for test file or Make them pass.`);
|
63
71
|
continue;
|
64
72
|
}
|
73
|
+
|
65
74
|
linesPercent += coverageData.lines.pct;
|
66
75
|
functionPercent += coverageData.functions.pct;
|
67
76
|
statementPerment += coverageData.statements.pct;
|
68
77
|
branchesPercent += coverageData.branches.pct;
|
69
78
|
}
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
79
|
+
|
80
|
+
let totalLinesPercent = linesPercent / (i * 100) * 100;
|
81
|
+
let totalFunctionPercent = functionPercent / (i * 100) * 100;
|
82
|
+
let totalStatementPercent = statementPerment / (i * 100) * 100;
|
83
|
+
let totalBranchesPercent = branchesPercent / (i * 100) * 100;
|
84
|
+
let totalPercentage = totalLinesPercent + totalFunctionPercent + totalStatementPercent + totalBranchesPercent;
|
85
|
+
let coverage = (totalPercentage / 4).toFixed(2);
|
76
86
|
coverage = Number(coverage);
|
87
|
+
(0, _jsonMaker.default)(inp, coverage, 'Yes', 'unitcase');
|
77
88
|
|
78
89
|
if (Number.isNaN(coverage)) {
|
79
|
-
(0, _utils.log)(
|
90
|
+
(0, _utils.log)('This build does\'t have any JS changes!');
|
80
91
|
coverage = 0;
|
81
92
|
} else {
|
82
|
-
(0, _utils.log)(
|
93
|
+
(0, _utils.log)(`COVERAGE ${coverage}%`);
|
83
94
|
}
|
84
95
|
|
85
|
-
|
86
|
-
|
87
|
-
|
96
|
+
let html = `<html>
|
97
|
+
<head>
|
98
|
+
<style>
|
99
|
+
.red{
|
100
|
+
font-weight:bold;
|
101
|
+
color:red;
|
102
|
+
}
|
103
|
+
.green{
|
104
|
+
font-weight:bold;
|
105
|
+
color:green;
|
106
|
+
}
|
107
|
+
table
|
108
|
+
{
|
109
|
+
font-family: arial, sans-serif;
|
110
|
+
border-collapse: collapse;
|
111
|
+
}
|
112
|
+
|
113
|
+
td, th
|
114
|
+
{
|
115
|
+
border: 1px solid #dddddd;
|
116
|
+
padding: 8px;
|
117
|
+
}
|
118
|
+
</style>
|
119
|
+
</head>
|
120
|
+
<body>
|
121
|
+
<table>
|
122
|
+
<tr>
|
123
|
+
<th>Title</th>
|
124
|
+
<th>FullName</th>
|
125
|
+
<th>Test Case Path</th>
|
126
|
+
</tr>
|
127
|
+
${unitTestReport.map(t => `<tr>
|
128
|
+
<td>${t.title}</td>
|
129
|
+
<td>${t.fullName}</td>
|
130
|
+
<td>${t.filePath}</td>
|
131
|
+
</tr>`)}
|
132
|
+
</table>
|
133
|
+
<br/>COVERAGE <span class="${coverage < 60 ? 'red' : 'green'}">${coverage}%</span> <br/> less than 60% consider failure
|
134
|
+
</body>
|
135
|
+
</html>
|
136
|
+
`;
|
88
137
|
|
89
|
-
if (!
|
90
|
-
|
138
|
+
if (!_fs.default.existsSync('./unittest')) {
|
139
|
+
_fs.default.mkdirSync('./unittest');
|
91
140
|
}
|
92
|
-
|
141
|
+
|
142
|
+
_fs.default.writeFileSync('./unittest/index.html', html, 'utf8');
|
93
143
|
|
94
144
|
return inp;
|
95
145
|
};
|
package/lib/jest/run.js
CHANGED
@@ -1,45 +1,92 @@
|
|
1
|
-
|
1
|
+
"use strict";
|
2
2
|
|
3
|
-
var _jest = require(
|
3
|
+
var _jest = require("jest");
|
4
4
|
|
5
|
-
var
|
5
|
+
var _fs = _interopRequireDefault(require("fs"));
|
6
6
|
|
7
|
-
var _utils = require(
|
7
|
+
var _utils = require("../utils");
|
8
8
|
|
9
|
-
var
|
9
|
+
var _jsonHelper = require("../utils/jsonHelper");
|
10
10
|
|
11
|
-
var
|
11
|
+
var _coverageCollector = _interopRequireDefault(require("./coverageCollector"));
|
12
12
|
|
13
13
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
14
14
|
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
15
|
+
let options = (0, _utils.getOptions)();
|
16
|
+
let {
|
17
|
+
app: {
|
18
|
+
folder
|
19
|
+
},
|
20
|
+
test: {
|
21
|
+
branchName,
|
22
|
+
srcBranch,
|
23
|
+
targetBranch,
|
24
|
+
serviceName,
|
25
|
+
impactServerDomain,
|
26
|
+
isCommitCoverage
|
27
|
+
}
|
28
|
+
} = options;
|
29
|
+
let argv = process.argv.slice(2);
|
23
30
|
|
31
|
+
let config = require('../configs/jest.config');
|
24
32
|
|
25
|
-
var argv = process.argv.slice(2);
|
26
|
-
|
27
|
-
var config = require('../configs/jest.config');
|
28
33
|
if (isCommitCoverage) {
|
29
|
-
(0,
|
30
|
-
var res = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
31
|
-
|
34
|
+
(0, _coverageCollector.default)(srcBranch, targetBranch, serviceName, impactServerDomain).then((res = {}) => {
|
32
35
|
if (res.STATUS) {
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
36
|
+
if (res.LIST.length > 0) {
|
37
|
+
let content = {
|
38
|
+
FILES: res.LIST
|
39
|
+
};
|
40
|
+
|
41
|
+
if (!_fs.default.existsSync('./coverageTest')) {
|
42
|
+
_fs.default.mkdirSync('./coverageTest');
|
43
|
+
|
44
|
+
_fs.default.writeFileSync('./coverageTest/result.json', JSON.stringify(content), 'utf8');
|
45
|
+
} else {
|
46
|
+
_fs.default.writeFileSync('./coverageTest/result.json', JSON.stringify(content), 'utf8');
|
47
|
+
}
|
48
|
+
|
49
|
+
argv.push('--findRelatedTests');
|
50
|
+
argv = argv.concat(res.LIST);
|
51
|
+
argv = argv.concat(['--config', JSON.stringify(config(null, true))]);
|
52
|
+
argv.push('--no-cache');
|
53
|
+
argv.push('--silent');
|
54
|
+
(0, _jest.run)(argv);
|
55
|
+
} else {
|
56
|
+
(0, _jsonHelper.jsonHelper)(`${process.cwd()}/result.json`, ['tests', 'modifiedFileUnitCase', 'hasChanges'], false); // jsonHelper(
|
57
|
+
// `${process.cwd()}/result.json`,
|
58
|
+
// 'testInfo.isBuildVerified',
|
59
|
+
// true
|
60
|
+
// );
|
61
|
+
|
62
|
+
(0, _jsonHelper.setTestInfoStatus)(`${process.cwd()}/result.json`, true);
|
63
|
+
(0, _jsonHelper.jsonHelper)(`${process.cwd()}/result.json`, 'testInfo.failures', [{
|
64
|
+
type: 'modifiedUnitcases',
|
65
|
+
message: res.REASON
|
66
|
+
}]);
|
67
|
+
(0, _utils.log)('No JS changes with last changeset!');
|
68
|
+
}
|
37
69
|
} else {
|
70
|
+
(0, _jsonHelper.jsonHelper)(`${process.cwd()}/result.json`, ['tests', 'modifiedFileUnitCase', 'isExecuted'], res.STATUS); // jsonHelper(
|
71
|
+
// `${process.cwd()}/result.json`,
|
72
|
+
// 'testInfo.isBuildVerified',
|
73
|
+
// true
|
74
|
+
// );
|
75
|
+
|
76
|
+
(0, _jsonHelper.setTestInfoStatus)(`${process.cwd()}/result.json`, true); // jsonHelper(`${process.cwd()}/result.json`, 'testInfo.failures', [{
|
77
|
+
// type: 'modifiedUnitcases',
|
78
|
+
// message: res.REASON
|
79
|
+
// }]);
|
80
|
+
|
38
81
|
(0, _utils.log)(res.REASON);
|
39
82
|
}
|
40
83
|
});
|
41
84
|
} else {
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
85
|
+
if (branchName === 'master' || branchName === null) {
|
86
|
+
argv.push('--config', JSON.stringify(config(folder)), '--no-cache');
|
87
|
+
(0, _jest.run)(argv);
|
88
|
+
} else {
|
89
|
+
(0, _jsonHelper.jsonHelper)(`${process.cwd()}/result.json`, ['tests', 'unitCase', 'isExecuted'], 'onlyMaster');
|
90
|
+
(0, _utils.log)('Only runs with master branch');
|
91
|
+
}
|
92
|
+
}
|
package/lib/jest/setup.js
CHANGED
@@ -1,207 +1,208 @@
|
|
1
|
-
|
1
|
+
"use strict";
|
2
2
|
|
3
|
-
var
|
3
|
+
var _jsdom = require("jsdom");
|
4
4
|
|
5
|
-
var
|
5
|
+
var _testUtils = _interopRequireDefault(require("react-dom/test-utils"));
|
6
6
|
|
7
|
-
var
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
8
8
|
|
9
|
-
var
|
9
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
10
10
|
|
11
|
-
var
|
11
|
+
var _reactDom = _interopRequireDefault(require("react-dom"));
|
12
12
|
|
13
|
-
var
|
13
|
+
var _xhr = _interopRequireDefault(require("xhr2"));
|
14
14
|
|
15
|
-
var
|
16
|
-
|
17
|
-
var _propTypes2 = _interopRequireDefault(_propTypes);
|
18
|
-
|
19
|
-
var _reactDom = require('react-dom');
|
20
|
-
|
21
|
-
var _reactDom2 = _interopRequireDefault(_reactDom);
|
22
|
-
|
23
|
-
var _xhr = require('xhr2');
|
24
|
-
|
25
|
-
var _xhr2 = _interopRequireDefault(_xhr);
|
26
|
-
|
27
|
-
var _nock = require('nock');
|
28
|
-
|
29
|
-
var _nock2 = _interopRequireDefault(_nock);
|
15
|
+
var _nock = _interopRequireDefault(require("nock"));
|
30
16
|
|
31
17
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
32
18
|
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
var mockDomain = 'htt' + 'p://zoho.com';
|
41
|
-
var document = new _jsdom.JSDOM('').window.document;
|
42
|
-
|
19
|
+
//$Id$//
|
20
|
+
let mockDomain = 'htt' + 'p://zoho.com';
|
21
|
+
const {
|
22
|
+
document
|
23
|
+
} = new _jsdom.JSDOM('').window;
|
43
24
|
global.document = document;
|
44
25
|
global.window = document.defaultView;
|
45
26
|
global.navigator = global.window.navigator;
|
46
27
|
global.localStorage = global.sessionStorage = {
|
47
|
-
getItem
|
28
|
+
getItem(key) {
|
48
29
|
return this[key];
|
49
30
|
},
|
50
|
-
|
31
|
+
|
32
|
+
setItem(key, value) {
|
51
33
|
if (value.length > 100) {
|
52
34
|
throw new Error('Data size is too exceeded');
|
53
35
|
}
|
36
|
+
|
54
37
|
this[key] = value;
|
55
38
|
},
|
56
|
-
|
39
|
+
|
40
|
+
removeItem(key) {
|
57
41
|
delete this[key];
|
58
42
|
},
|
59
|
-
|
60
|
-
|
61
|
-
|
43
|
+
|
44
|
+
clear() {
|
45
|
+
let keys = ['getItem', 'setItem', 'removeItem', 'clear'];
|
46
|
+
|
47
|
+
for (let key in this) {
|
62
48
|
if (keys.indexOf(key) === -1) {
|
63
49
|
delete this[key];
|
64
50
|
}
|
65
51
|
}
|
66
52
|
}
|
53
|
+
|
67
54
|
};
|
68
55
|
global.ZE_Init = {};
|
56
|
+
|
69
57
|
global.String.prototype.contains = function (text) {
|
70
58
|
return this.indexOf(text) != -1;
|
71
59
|
};
|
72
|
-
|
73
|
-
|
60
|
+
|
61
|
+
global.TestUtils = _testUtils.default;
|
62
|
+
let xmlReq = _xhr.default;
|
63
|
+
|
74
64
|
window.XMLHttpRequest = function () {
|
75
|
-
|
76
|
-
|
65
|
+
let xmlReqCopy = new xmlReq();
|
66
|
+
let originalOpen = xmlReqCopy.open;
|
67
|
+
|
77
68
|
xmlReqCopy.open = function () {
|
78
69
|
if (arguments[1].indexOf('http') != 0) {
|
79
70
|
arguments[1] = mockDomain + arguments[1];
|
80
71
|
}
|
72
|
+
|
81
73
|
return originalOpen.apply(this, arguments);
|
82
74
|
};
|
75
|
+
|
83
76
|
return xmlReqCopy;
|
84
77
|
};
|
85
78
|
|
86
|
-
|
87
|
-
|
88
|
-
if (
|
89
|
-
|
79
|
+
_testUtils.default.scryRenderedComponentsWithTestid = function (dom, name) {
|
80
|
+
let componentList = _testUtils.default.findAllInRenderedTree(dom, (i, j) => {
|
81
|
+
if (_testUtils.default.isDOMComponent(i)) {
|
82
|
+
let val = i.getAttribute('data-id');
|
83
|
+
|
90
84
|
if (typeof val !== 'undefined' && val == name) {
|
91
85
|
return true;
|
92
86
|
}
|
87
|
+
|
93
88
|
return false;
|
94
89
|
}
|
95
90
|
});
|
91
|
+
|
96
92
|
return componentList;
|
97
93
|
};
|
98
94
|
|
99
|
-
|
100
|
-
|
95
|
+
_testUtils.default.findRenderedComponentsWithTestid = function (dom, name) {
|
96
|
+
let list = _testUtils.default.scryRenderedComponentsWithTestid(dom, name);
|
97
|
+
|
101
98
|
if (list.length !== 1) {
|
102
|
-
throw new Error(
|
99
|
+
throw new Error(`Did not find exactly one match (found: ${list.length}) ` + `for data-id:${name}`);
|
103
100
|
}
|
101
|
+
|
104
102
|
return list[0];
|
105
103
|
};
|
106
104
|
|
107
105
|
global.render = function (Component, props) {
|
108
|
-
|
106
|
+
const renderedDOM = _testUtils.default.renderIntoDocument( /*#__PURE__*/_react.default.createElement(Component, props));
|
107
|
+
|
109
108
|
return {
|
110
|
-
props
|
111
|
-
renderedDOM
|
109
|
+
props,
|
110
|
+
renderedDOM
|
112
111
|
};
|
113
112
|
};
|
114
113
|
|
115
114
|
global.setup = function (Component, props, state) {
|
116
|
-
|
115
|
+
let router = {
|
117
116
|
router: {
|
118
|
-
push
|
119
|
-
|
117
|
+
push() {},
|
118
|
+
|
119
|
+
createHref(ob) {
|
120
120
|
return ob.pathname;
|
121
121
|
},
|
122
|
-
|
122
|
+
|
123
|
+
isActive() {
|
123
124
|
return true;
|
124
125
|
},
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
126
|
+
|
127
|
+
replace() {},
|
128
|
+
|
129
|
+
go() {},
|
130
|
+
|
131
|
+
goBack() {},
|
132
|
+
|
133
|
+
goForward() {},
|
134
|
+
|
135
|
+
setRouteLeaveHook() {},
|
136
|
+
|
137
|
+
getState() {}
|
138
|
+
|
131
139
|
},
|
132
140
|
store: {
|
133
|
-
getState
|
141
|
+
getState() {
|
134
142
|
return state;
|
135
143
|
}
|
144
|
+
|
136
145
|
}
|
137
|
-
};
|
138
|
-
// var store = {
|
146
|
+
}; // var store = {
|
139
147
|
// store:{
|
140
148
|
// getState:function(){return state;}
|
141
149
|
// }
|
142
150
|
// }
|
151
|
+
|
143
152
|
var Component = higherComponent(Component, router);
|
144
|
-
|
153
|
+
|
154
|
+
const renderedDOM = _testUtils.default.renderIntoDocument( /*#__PURE__*/_react.default.createElement(Component, props), router);
|
155
|
+
|
145
156
|
return {
|
146
|
-
props
|
147
|
-
renderedDOM
|
157
|
+
props,
|
158
|
+
renderedDOM
|
148
159
|
};
|
149
160
|
};
|
150
161
|
|
151
162
|
function higherComponent(ActualComponent, context) {
|
152
163
|
if (context) {
|
153
|
-
|
154
|
-
|
164
|
+
class HigherComponent extends _react.default.Component {
|
165
|
+
constructor() {
|
166
|
+
super();
|
167
|
+
}
|
155
168
|
|
156
|
-
|
157
|
-
|
169
|
+
getChildContext() {
|
170
|
+
return context;
|
171
|
+
}
|
158
172
|
|
159
|
-
|
173
|
+
render() {
|
174
|
+
return /*#__PURE__*/_react.default.createElement(ActualComponent, this.props);
|
160
175
|
}
|
161
176
|
|
162
|
-
|
163
|
-
key: 'getChildContext',
|
164
|
-
value: function getChildContext() {
|
165
|
-
return context;
|
166
|
-
}
|
167
|
-
}, {
|
168
|
-
key: 'render',
|
169
|
-
value: function render() {
|
170
|
-
return _react2.default.createElement(ActualComponent, this.props);
|
171
|
-
}
|
172
|
-
}]);
|
173
|
-
|
174
|
-
return HigherComponent;
|
175
|
-
}(_react2.default.Component);
|
177
|
+
}
|
176
178
|
|
177
179
|
HigherComponent.childContextTypes = {
|
178
|
-
router:
|
179
|
-
store:
|
180
|
+
router: _propTypes.default.any,
|
181
|
+
store: _propTypes.default.any
|
180
182
|
};
|
181
|
-
|
182
183
|
return HigherComponent;
|
183
184
|
}
|
185
|
+
|
184
186
|
return ActualComponent;
|
185
187
|
}
|
188
|
+
|
186
189
|
global.window.matchMedia = window.matchMedia || function () {
|
187
190
|
return {
|
188
191
|
matches: false,
|
189
|
-
|
190
|
-
|
192
|
+
|
193
|
+
addListener() {},
|
194
|
+
|
195
|
+
removeListener() {}
|
196
|
+
|
191
197
|
};
|
192
|
-
};
|
193
|
-
// global.renderHTML = function(comp) {
|
198
|
+
}; // global.renderHTML = function(comp) {
|
194
199
|
// return ReactDOM.findDOMNode(comp);
|
195
200
|
// };
|
196
201
|
|
197
|
-
|
202
|
+
|
203
|
+
global.TestUtils = _testUtils.default;
|
198
204
|
global.XMLHttpRequest = window.XMLHttpRequest;
|
205
|
+
|
199
206
|
global.getI18NValue = function (inp) {
|
200
207
|
return inp;
|
201
|
-
};
|
202
|
-
|
203
|
-
var hook = require('css-modules-require-hook');
|
204
|
-
|
205
|
-
hook({
|
206
|
-
generateScopedName: '[name]__[local]___[hash:base64:5]'
|
207
|
-
});
|
208
|
+
};
|