dependency-cruiser 17.3.2 → 17.3.3-beta-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/bin/depcruise-baseline.mjs +43 -43
- package/bin/depcruise-fmt.mjs +89 -89
- package/bin/dependency-cruise.mjs +171 -171
- package/configs/plugins/3d-reporter-plugin.mjs +36 -36
- package/configs/plugins/stats-reporter-plugin.mjs +51 -51
- package/configs/recommended-strict.cjs +5 -5
- package/configs/recommended-warn-only.cjs +5 -5
- package/configs/recommended.cjs +22 -22
- package/configs/rules/no-circular.cjs +10 -10
- package/configs/rules/no-deprecated-core.cjs +10 -10
- package/configs/rules/no-duplicate-dependency-types.cjs +17 -17
- package/configs/rules/no-non-package-json.cjs +11 -11
- package/configs/rules/no-orphans.cjs +18 -18
- package/configs/rules/not-to-deprecated.cjs +10 -10
- package/configs/rules/not-to-unresolvable.cjs +10 -10
- package/package.json +170 -170
- package/src/cache/cache.mjs +139 -139
- package/src/cache/content-strategy.mjs +88 -88
- package/src/cache/find-content-changes.mjs +58 -58
- package/src/cache/helpers.mjs +52 -52
- package/src/cache/metadata-strategy.mjs +83 -83
- package/src/cache/options-compatible.mjs +56 -109
- package/src/cli/assert-node-environment-suitable.mjs +7 -7
- package/src/cli/defaults.mjs +5 -5
- package/src/cli/format-meta-info.mjs +22 -22
- package/src/cli/format.mjs +28 -28
- package/src/cli/index.mjs +145 -145
- package/src/cli/init-config/build-config.mjs +94 -94
- package/src/cli/init-config/environment-helpers.mjs +77 -77
- package/src/cli/init-config/find-extensions.mjs +27 -27
- package/src/cli/init-config/get-user-input.mjs +151 -151
- package/src/cli/init-config/index.mjs +88 -88
- package/src/cli/init-config/normalize-init-options.mjs +47 -47
- package/src/cli/init-config/utl.mjs +4 -4
- package/src/cli/init-config/validators.mjs +10 -10
- package/src/cli/init-config/write-config.mjs +21 -21
- package/src/cli/init-config/write-run-scripts-to-manifest.mjs +103 -107
- package/src/cli/listeners/cli-feedback.mjs +49 -49
- package/src/cli/listeners/ndjson.mjs +66 -66
- package/src/cli/listeners/performance-log/format-helpers.mjs +63 -63
- package/src/cli/listeners/performance-log/handlers.mjs +56 -56
- package/src/cli/listeners/performance-log/index.mjs +37 -37
- package/src/cli/normalize-cli-options.mjs +182 -182
- package/src/cli/tools/wrap-stream-in-html.mjs +37 -37
- package/src/cli/utl/assert-file-existence.mjs +7 -7
- package/src/cli/utl/io.mjs +28 -31
- package/src/config-utl/extract-babel-config.mjs +69 -69
- package/src/config-utl/extract-depcruise-config/index.mjs +54 -54
- package/src/config-utl/extract-depcruise-config/merge-configs.mjs +63 -63
- package/src/config-utl/extract-depcruise-config/read-config.mjs +9 -9
- package/src/config-utl/extract-depcruise-options.mjs +9 -9
- package/src/config-utl/extract-known-violations.mjs +49 -49
- package/src/config-utl/extract-ts-config.mjs +46 -48
- package/src/config-utl/extract-webpack-resolve-config.mjs +88 -88
- package/src/config-utl/make-absolute.mjs +5 -5
- package/src/enrich/add-validations.mjs +13 -13
- package/src/enrich/derive/circular.mjs +49 -49
- package/src/enrich/derive/dependents.mjs +27 -27
- package/src/enrich/derive/folders/aggregate-to-folders.mjs +104 -104
- package/src/enrich/derive/folders/index.mjs +19 -19
- package/src/enrich/derive/folders/utl.mjs +18 -18
- package/src/enrich/derive/metrics/get-module-metrics.mjs +27 -27
- package/src/enrich/derive/metrics/index.mjs +8 -8
- package/src/enrich/derive/module-utl.mjs +18 -18
- package/src/enrich/derive/orphan/index.mjs +18 -18
- package/src/enrich/derive/orphan/is-orphan.mjs +9 -9
- package/src/enrich/derive/reachable.mjs +165 -168
- package/src/enrich/enrich-modules.mjs +25 -25
- package/src/enrich/index.mjs +15 -15
- package/src/enrich/soften-known-violations.mjs +90 -90
- package/src/enrich/summarize/add-rule-set-used.mjs +13 -13
- package/src/enrich/summarize/get-stats.mjs +17 -17
- package/src/enrich/summarize/index.mjs +18 -18
- package/src/enrich/summarize/is-same-violation.mjs +30 -30
- package/src/enrich/summarize/summarize-folders.mjs +35 -35
- package/src/enrich/summarize/summarize-modules.mjs +97 -97
- package/src/enrich/summarize/summarize-options.mjs +71 -71
- package/src/extract/acorn/estree-helpers.mjs +66 -66
- package/src/extract/acorn/extract-amd-deps.mjs +63 -64
- package/src/extract/acorn/extract-cjs-deps.mjs +83 -83
- package/src/extract/acorn/extract-es6-deps.mjs +54 -54
- package/src/extract/acorn/extract-stats.mjs +4 -4
- package/src/extract/acorn/extract.mjs +28 -28
- package/src/extract/acorn/parse.mjs +37 -37
- package/src/extract/clear-caches.mjs +7 -7
- package/src/extract/extract-dependencies.mjs +109 -109
- package/src/extract/extract-stats.mjs +21 -21
- package/src/extract/gather-initial-sources.mjs +64 -64
- package/src/extract/helpers.mjs +73 -71
- package/src/extract/index.mjs +120 -120
- package/src/extract/resolve/determine-dependency-types.mjs +166 -169
- package/src/extract/resolve/external-module-helpers.mjs +76 -76
- package/src/extract/resolve/get-manifest.mjs +79 -79
- package/src/extract/resolve/index.mjs +175 -164
- package/src/extract/resolve/is-built-in.mjs +22 -24
- package/src/extract/resolve/merge-manifests.mjs +43 -43
- package/src/extract/resolve/module-classifiers.mjs +229 -229
- package/src/extract/resolve/resolve-amd.mjs +44 -44
- package/src/extract/resolve/resolve-cjs.mjs +40 -40
- package/src/extract/resolve/resolve-helpers.mjs +20 -20
- package/src/extract/resolve/resolve.mjs +26 -26
- package/src/extract/swc/dependency-visitor.mjs +211 -211
- package/src/extract/swc/extract-swc-deps.mjs +4 -4
- package/src/extract/swc/extract.mjs +7 -7
- package/src/extract/swc/parse.mjs +12 -12
- package/src/extract/transpile/babel-wrap.mjs +9 -9
- package/src/extract/transpile/coffeescript-wrap.mjs +21 -21
- package/src/extract/transpile/index.mjs +47 -47
- package/src/extract/transpile/javascript-wrap.mjs +6 -6
- package/src/extract/transpile/livescript-wrap.mjs +5 -5
- package/src/extract/transpile/meta.mjs +80 -80
- package/src/extract/transpile/svelte-preprocess.mjs +73 -73
- package/src/extract/transpile/svelte-wrap.mjs +19 -19
- package/src/extract/transpile/try-import-available.mjs +26 -27
- package/src/extract/transpile/typescript-wrap.mjs +39 -39
- package/src/extract/transpile/vue-template-wrap.cjs +43 -43
- package/src/extract/tsc/extract-stats.mjs +4 -4
- package/src/extract/tsc/extract-typescript-deps.mjs +429 -398
- package/src/extract/tsc/extract.mjs +22 -22
- package/src/extract/tsc/parse.mjs +21 -21
- package/src/graph-utl/add-focus.mjs +35 -35
- package/src/graph-utl/compare.mjs +24 -24
- package/src/graph-utl/consolidate-module-dependencies.mjs +35 -35
- package/src/graph-utl/consolidate-modules.mjs +33 -33
- package/src/graph-utl/consolidate-to-folder.mjs +13 -13
- package/src/graph-utl/consolidate-to-pattern.mjs +34 -34
- package/src/graph-utl/filter-bank.mjs +74 -69
- package/src/graph-utl/indexed-module-graph.mjs +227 -225
- package/src/graph-utl/match-facade.mjs +3 -3
- package/src/graph-utl/rule-set.mjs +20 -20
- package/src/graph-utl/strip-self-transitions.mjs +6 -6
- package/src/main/cruise.mjs +81 -81
- package/src/main/files-and-dirs/normalize.mjs +7 -7
- package/src/main/format.mjs +11 -14
- package/src/main/helpers.mjs +25 -25
- package/src/main/index.mjs +8 -8
- package/src/main/options/assert-validity.mjs +100 -100
- package/src/main/options/defaults.mjs +11 -11
- package/src/main/options/normalize.mjs +158 -160
- package/src/main/report-wrap.mjs +37 -37
- package/src/main/resolve-options/normalize.mjs +127 -128
- package/src/main/rule-set/assert-validity.mjs +67 -73
- package/src/main/rule-set/normalize.mjs +81 -79
- package/src/meta.cjs +15 -16
- package/src/report/anon/anonymize-path-element.mjs +20 -34
- package/src/report/anon/anonymize-path.mjs +11 -11
- package/src/report/anon/index.mjs +119 -119
- package/src/report/anon/random-string.mjs +23 -23
- package/src/report/azure-devops.mjs +75 -99
- package/src/report/baseline.mjs +9 -9
- package/src/report/csv.mjs +13 -13
- package/src/report/d2.mjs +105 -105
- package/src/report/dot/default-theme.mjs +152 -152
- package/src/report/dot/index.mjs +146 -146
- package/src/report/dot/module-utl.mjs +72 -72
- package/src/report/dot/prepare-custom-level.mjs +20 -20
- package/src/report/dot/prepare-flat-level.mjs +11 -11
- package/src/report/dot/prepare-folder-level.mjs +12 -13
- package/src/report/dot/theming.mjs +73 -73
- package/src/report/dot-webpage/dot-module.mjs +36 -36
- package/src/report/dot-webpage/svg-in-html-snippets/script.cjs +208 -210
- package/src/report/dot-webpage/svg-in-html-snippets/style.css +51 -51
- package/src/report/dot-webpage/wrap-in-html.mjs +7 -7
- package/src/report/error-html/index.mjs +49 -49
- package/src/report/error-html/utl.mjs +99 -99
- package/src/report/error-long.mjs +1 -1
- package/src/report/error.mjs +93 -93
- package/src/report/html/index.mjs +48 -48
- package/src/report/identity.mjs +4 -4
- package/src/report/index.mjs +33 -33
- package/src/report/json.mjs +4 -4
- package/src/report/markdown.mjs +120 -120
- package/src/report/mermaid.mjs +111 -111
- package/src/report/metrics.mjs +185 -185
- package/src/report/null.mjs +4 -4
- package/src/report/plugins.mjs +41 -41
- package/src/report/teamcity.mjs +150 -150
- package/src/report/text.mjs +42 -42
- package/src/report/utl/dependency-to-incidence-transformer.mjs +32 -32
- package/src/report/utl/index.mjs +53 -53
- package/src/schema/configuration.validate.mjs +1 -0
- package/src/schema/cruise-result.validate.mjs +1 -0
- package/src/schema/utl.mjs +6 -0
- package/src/utl/array-util.mjs +25 -25
- package/src/utl/bus.mjs +12 -12
- package/src/utl/extract-root-module-name.cjs +8 -8
- package/src/utl/find-all-files.mjs +54 -54
- package/src/utl/get-extension.mjs +2 -2
- package/src/utl/object-util.mjs +21 -22
- package/src/utl/path-to-posix.mjs +5 -5
- package/src/utl/regex-util.mjs +20 -20
- package/src/utl/try-import.mjs +42 -41
- package/src/utl/try-require.cjs +23 -23
- package/src/utl/wrap-and-indent.mjs +33 -33
- package/src/validate/index.mjs +65 -65
- package/src/validate/match-dependency-rule.mjs +47 -47
- package/src/validate/match-folder-dependency-rule.mjs +27 -27
- package/src/validate/match-module-rule-helpers.mjs +76 -76
- package/src/validate/match-module-rule.mjs +12 -12
- package/src/validate/matchers.mjs +162 -162
- package/src/validate/rule-classifiers.mjs +9 -9
- package/src/validate/violates-required-rule.mjs +23 -23
- package/types/cache-options.d.mts +27 -27
- package/types/config-utl/extract-babel-config.d.mts +1 -1
- package/types/config-utl/extract-depcruise-config.d.mts +3 -3
- package/types/config-utl/extract-depcruise-options.d.mts +1 -1
- package/types/config-utl/extract-ts-config.d.mts +1 -1
- package/types/config-utl/extract-webpack-resolve-config.d.mts +3 -3
- package/types/configuration.d.mts +10 -10
- package/types/cruise-result.d.mts +414 -414
- package/types/dependency-cruiser.d.mts +52 -52
- package/types/filter-types.d.mts +45 -45
- package/types/options.d.mts +430 -430
- package/types/plugins/3d-reporter-plugin.d.mts +9 -9
- package/types/plugins/mermaid-reporter-plugin.d.mts +10 -10
- package/types/plugins/stats-reporter-plugin.d.mts +9 -9
- package/types/reporter-options.d.mts +196 -196
- package/types/resolve-options.d.mts +23 -23
- package/types/restrictions.d.mts +174 -174
- package/types/rule-set.d.mts +132 -132
- package/types/rule-summary.d.mts +14 -14
- package/types/shared-types.d.mts +89 -89
- package/types/strict-filter-types.d.mts +52 -52
- package/types/strict-options.d.mts +34 -34
- package/types/strict-restrictions.d.mts +25 -25
- package/types/strict-rule-set.d.mts +36 -36
- package/types/violations.d.mts +40 -40
- package/src/schema/README.md +0 -5
- package/src/schema/baseline-violations.schema.mjs +0 -1
- package/src/schema/configuration.schema.mjs +0 -1
- package/src/schema/cruise-result.schema.mjs +0 -1
- package/types/README.md +0 -1
|
@@ -59,21 +59,21 @@ const TEMPLATE = `
|
|
|
59
59
|
</html>`;
|
|
60
60
|
|
|
61
61
|
function deriveGroup(pFileName) {
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
62
|
+
let lReturnValue = "unknown";
|
|
63
|
+
const lGroupPositionInRe = 2;
|
|
64
|
+
const lMatch = path.dirname(pFileName).match(/^([^/]+)\/([^/]+)/);
|
|
65
|
+
if (lMatch) {
|
|
66
|
+
// eslint-disable-next-line security/detect-object-injection
|
|
67
|
+
lReturnValue = lMatch[lGroupPositionInRe];
|
|
68
|
+
}
|
|
69
|
+
return lReturnValue;
|
|
70
70
|
}
|
|
71
71
|
|
|
72
72
|
function formatFileName(pFileName) {
|
|
73
|
-
|
|
73
|
+
return `${path.dirname(pFileName)}/<b>${path.basename(pFileName)}</b>`;
|
|
74
74
|
}
|
|
75
75
|
function formatDependency(pFrom, pTo) {
|
|
76
|
-
|
|
76
|
+
return `${formatFileName(pFrom)} →</br>${formatFileName(pTo)}`;
|
|
77
77
|
}
|
|
78
78
|
|
|
79
79
|
/**
|
|
@@ -81,31 +81,31 @@ function formatDependency(pFrom, pTo) {
|
|
|
81
81
|
* @param {import('../../types/dependency-cruiser').ICruiseResult} pCruiseResult
|
|
82
82
|
*/
|
|
83
83
|
function render3DThing(pCruiseResult) {
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
84
|
+
const lNodes = pCruiseResult.modules.map((pModule) => {
|
|
85
|
+
return {
|
|
86
|
+
id: pModule.source,
|
|
87
|
+
displayname: path.basename(pModule.source),
|
|
88
|
+
dirname: path.dirname(pModule.source),
|
|
89
|
+
label: formatFileName(pModule.source),
|
|
90
|
+
group: deriveGroup(pModule.source),
|
|
91
|
+
};
|
|
92
|
+
});
|
|
93
|
+
const lLinks = pCruiseResult.modules.reduce(
|
|
94
|
+
(pAll, pCurrentModule) =>
|
|
95
|
+
pAll.concat(
|
|
96
|
+
pCurrentModule.dependencies.map((pDependency) => ({
|
|
97
|
+
source: pCurrentModule.source,
|
|
98
|
+
target: pDependency.resolved,
|
|
99
|
+
label: formatDependency(pCurrentModule.source, pDependency.resolved),
|
|
100
|
+
})),
|
|
101
|
+
),
|
|
102
|
+
[],
|
|
103
|
+
);
|
|
104
104
|
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
105
|
+
return TEMPLATE.replace(/@@NODES@@/g, JSON.stringify(lNodes)).replace(
|
|
106
|
+
/@@LINKS@@/g,
|
|
107
|
+
JSON.stringify(lLinks),
|
|
108
|
+
);
|
|
109
109
|
}
|
|
110
110
|
|
|
111
111
|
/**
|
|
@@ -119,6 +119,6 @@ function render3DThing(pCruiseResult) {
|
|
|
119
119
|
* exitCode: 0
|
|
120
120
|
*/
|
|
121
121
|
export default (pCruiseResult) => ({
|
|
122
|
-
|
|
123
|
-
|
|
122
|
+
output: render3DThing(pCruiseResult),
|
|
123
|
+
exitCode: 0,
|
|
124
124
|
});
|
|
@@ -3,31 +3,31 @@ const P75 = 0.75;
|
|
|
3
3
|
const DEFAULT_JSON_INDENT = 2;
|
|
4
4
|
|
|
5
5
|
function doMagic(pCruiseResult) {
|
|
6
|
-
|
|
6
|
+
let lReturnValue = {};
|
|
7
7
|
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
8
|
+
if (pCruiseResult.modules.some((pModule) => pModule.dependents)) {
|
|
9
|
+
const lDependentCounts = pCruiseResult.modules
|
|
10
|
+
.map((pModule) => pModule.dependents.length)
|
|
11
|
+
.sort();
|
|
12
12
|
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
13
|
+
lReturnValue = {
|
|
14
|
+
minDependentsPerModule: lDependentCounts[0] || 0,
|
|
15
|
+
maxDependentsPerModule:
|
|
16
|
+
lDependentCounts[Math.max(lDependentCounts.length - 1, 0)] || 0,
|
|
17
|
+
meanDependentsPerModule:
|
|
18
|
+
lDependentCounts.reduce((pAll, pCurrent) => pAll + pCurrent, 0) /
|
|
19
|
+
pCruiseResult.summary.totalCruised,
|
|
20
|
+
medianDependentsPerModule:
|
|
21
|
+
lDependentCounts[
|
|
22
|
+
Math.max(0, Math.floor(lDependentCounts.length * MEDIAN))
|
|
23
|
+
],
|
|
24
|
+
p75DependentsPerModule:
|
|
25
|
+
lDependentCounts[
|
|
26
|
+
Math.max(0, Math.floor(lDependentCounts.length * P75))
|
|
27
|
+
],
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
return lReturnValue;
|
|
31
31
|
}
|
|
32
32
|
/**
|
|
33
33
|
* returns an object with some stats from the ICruiseResult pCruiseResult it
|
|
@@ -37,29 +37,29 @@ function doMagic(pCruiseResult) {
|
|
|
37
37
|
* @return {string} an object with some stats
|
|
38
38
|
*/
|
|
39
39
|
function samplePluginReporter(pCruiseResult) {
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
40
|
+
const lDependencyCounts = pCruiseResult.modules
|
|
41
|
+
.map((pModule) => pModule.dependencies.length)
|
|
42
|
+
.sort();
|
|
43
43
|
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
44
|
+
return {
|
|
45
|
+
moduleCount: pCruiseResult.summary.totalCruised,
|
|
46
|
+
dependencyCount: pCruiseResult.summary.totalDependenciesCruised,
|
|
47
|
+
minDependenciesPerModule: lDependencyCounts[0] || 0,
|
|
48
|
+
maxDependenciesPerModule:
|
|
49
|
+
lDependencyCounts[Math.max(lDependencyCounts.length - 1, 0)] || 0,
|
|
50
|
+
meanDependenciesPerModule:
|
|
51
|
+
pCruiseResult.summary.totalDependenciesCruised /
|
|
52
|
+
pCruiseResult.summary.totalCruised,
|
|
53
|
+
medianDependenciesPerModule:
|
|
54
|
+
lDependencyCounts[
|
|
55
|
+
Math.max(0, Math.floor(lDependencyCounts.length * MEDIAN))
|
|
56
|
+
],
|
|
57
|
+
p75DependenciesPerModule:
|
|
58
|
+
lDependencyCounts[
|
|
59
|
+
Math.max(0, Math.floor(lDependencyCounts.length * P75))
|
|
60
|
+
],
|
|
61
|
+
...doMagic(pCruiseResult),
|
|
62
|
+
};
|
|
63
63
|
}
|
|
64
64
|
|
|
65
65
|
/**
|
|
@@ -73,10 +73,10 @@ function samplePluginReporter(pCruiseResult) {
|
|
|
73
73
|
* exitCode: 0
|
|
74
74
|
*/
|
|
75
75
|
export default (pCruiseResult) => ({
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
76
|
+
output: JSON.stringify(
|
|
77
|
+
samplePluginReporter(pCruiseResult),
|
|
78
|
+
null,
|
|
79
|
+
DEFAULT_JSON_INDENT,
|
|
80
|
+
),
|
|
81
|
+
exitCode: 0,
|
|
82
82
|
});
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
const recommended = require("./recommended.cjs");
|
|
2
2
|
|
|
3
3
|
module.exports = {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
4
|
+
...recommended,
|
|
5
|
+
forbidden: recommended.forbidden.map((pRule) => {
|
|
6
|
+
pRule.severity = "error";
|
|
7
|
+
return pRule;
|
|
8
|
+
}),
|
|
9
9
|
};
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
const recommended = require("./recommended.cjs");
|
|
2
2
|
|
|
3
3
|
module.exports = {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
4
|
+
...recommended,
|
|
5
|
+
forbidden: recommended.forbidden.map((pRule) => {
|
|
6
|
+
pRule.severity = "warn";
|
|
7
|
+
return pRule;
|
|
8
|
+
}),
|
|
9
9
|
};
|
package/configs/recommended.cjs
CHANGED
|
@@ -7,26 +7,26 @@ const notToDeprecated = require("./rules/not-to-deprecated.cjs");
|
|
|
7
7
|
const notToUnresolvable = require("./rules/not-to-unresolvable.cjs");
|
|
8
8
|
|
|
9
9
|
module.exports = {
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
10
|
+
forbidden: [
|
|
11
|
+
noOrphans,
|
|
12
|
+
noCircular,
|
|
13
|
+
noDeprecatedCore,
|
|
14
|
+
noDuplicateDependencyTypes,
|
|
15
|
+
noNonPackageJson,
|
|
16
|
+
notToDeprecated,
|
|
17
|
+
notToUnresolvable,
|
|
18
|
+
],
|
|
19
|
+
options: {
|
|
20
|
+
doNotFollow: {
|
|
21
|
+
path: "node_modules",
|
|
22
|
+
dependencyTypes: [
|
|
23
|
+
"npm",
|
|
24
|
+
"npm-dev",
|
|
25
|
+
"npm-optional",
|
|
26
|
+
"npm-peer",
|
|
27
|
+
"npm-bundled",
|
|
28
|
+
"npm-no-pkg",
|
|
29
|
+
],
|
|
30
|
+
},
|
|
31
|
+
},
|
|
32
32
|
};
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
module.exports = {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
2
|
+
name: "no-circular",
|
|
3
|
+
comment:
|
|
4
|
+
"This dependency is part of a circular relationship. You might want to revise " +
|
|
5
|
+
"your solution (i.e. use dependency inversion, make sure the modules have a " +
|
|
6
|
+
"single responsibility) ",
|
|
7
|
+
severity: "error",
|
|
8
|
+
from: {},
|
|
9
|
+
to: {
|
|
10
|
+
circular: true,
|
|
11
|
+
},
|
|
12
12
|
};
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
module.exports = {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
2
|
+
name: "no-deprecated-core",
|
|
3
|
+
comment:
|
|
4
|
+
"This module depends on a node core module that has been deprecated. Find an " +
|
|
5
|
+
"alternative - these are bound to exist - node doesn't deprecate lightly.",
|
|
6
|
+
severity: "error",
|
|
7
|
+
from: {},
|
|
8
|
+
to: {
|
|
9
|
+
dependencyTypes: ["core"],
|
|
10
|
+
path: "^(?:punycode|domain|constants|sys|_linklist|_stream_wrap)$",
|
|
11
|
+
},
|
|
12
12
|
};
|
|
@@ -1,19 +1,19 @@
|
|
|
1
1
|
module.exports = {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
2
|
+
name: "no-duplicate-dep-types",
|
|
3
|
+
comment:
|
|
4
|
+
"Likely this module depends on an external ('npm') package that occurs more " +
|
|
5
|
+
"than once in your package.json i.e. bot as a devDependencies and in dependencies. " +
|
|
6
|
+
"This will cause maintenance problems later on. If it's intentional, you can " +
|
|
7
|
+
"disable this rule by adding this override as a rule in the 'forbidden' section " +
|
|
8
|
+
"of your dependency-cruiser configuration: " +
|
|
9
|
+
'{"name": "no-duplicate-dep-types", "severity": "ignore"}',
|
|
10
|
+
severity: "warn",
|
|
11
|
+
from: {},
|
|
12
|
+
to: {
|
|
13
|
+
moreThanOneDependencyType: true,
|
|
14
|
+
// as it's pretty common to have a type import be a type only import
|
|
15
|
+
// _and_ (e.g.) a devDependency - don't consider type-only dependency
|
|
16
|
+
// types for this rule
|
|
17
|
+
dependencyTypesNot: ["type-only"],
|
|
18
|
+
},
|
|
19
19
|
};
|
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
module.exports = {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
2
|
+
name: "no-non-package-json",
|
|
3
|
+
severity: "error",
|
|
4
|
+
comment:
|
|
5
|
+
"This module depends on an npm package that isn't in the 'dependencies' section " +
|
|
6
|
+
"of your package.json. That's problematic as the package either (1) won't be " +
|
|
7
|
+
"available on live (2 - worse) will be available on live with an non-guaranteed " +
|
|
8
|
+
"version. Fix it by adding the package to the dependencies in your package.json.",
|
|
9
|
+
from: {},
|
|
10
|
+
to: {
|
|
11
|
+
dependencyTypes: ["npm-no-pkg", "npm-unknown"],
|
|
12
|
+
},
|
|
13
13
|
};
|
|
@@ -2,27 +2,27 @@ const DOT_FILE_PATTERN = "(^|/)\\.[^/]+\\.(js|cjs|mjs|ts|json)$";
|
|
|
2
2
|
const TS_DECLARATION_FILE_PATTERN = "\\.d\\.(c|m)?ts$";
|
|
3
3
|
const TS_CONFIG_FILE_PATTERN = "(^|/)tsconfig\\.json$";
|
|
4
4
|
const OTHER_CONFIG_FILES_PATTERN =
|
|
5
|
-
|
|
5
|
+
"(^|/)(?:babel|webpack)\\.config\\.(?:js|cjs|mjs|ts|json)$";
|
|
6
6
|
|
|
7
7
|
const KNOWN_CONFIG_FILE_PATTERNS = [
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
8
|
+
DOT_FILE_PATTERN,
|
|
9
|
+
TS_DECLARATION_FILE_PATTERN,
|
|
10
|
+
TS_CONFIG_FILE_PATTERN,
|
|
11
|
+
OTHER_CONFIG_FILES_PATTERN,
|
|
12
12
|
].join("|");
|
|
13
13
|
|
|
14
14
|
module.exports = {
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
15
|
+
name: "no-orphans",
|
|
16
|
+
comment:
|
|
17
|
+
"This is an orphan module - it's likely not used (anymore?). Either use it or " +
|
|
18
|
+
"remove it. If it's logical this module is an orphan (i.e. it's a config file), " +
|
|
19
|
+
"add an exception for it in your dependency-cruiser configuration. By default " +
|
|
20
|
+
"this rule does not scrutinize dotfiles (e.g. .eslintrc.js), TypeScript declaration " +
|
|
21
|
+
"files (.d.ts/ .d.cts/ .d.mts), tsconfig.json and some of the babel and webpack configs.",
|
|
22
|
+
severity: "warn",
|
|
23
|
+
from: {
|
|
24
|
+
orphan: true,
|
|
25
|
+
pathNot: KNOWN_CONFIG_FILE_PATTERNS,
|
|
26
|
+
},
|
|
27
|
+
to: {},
|
|
28
28
|
};
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
module.exports = {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
2
|
+
name: "not-to-deprecated",
|
|
3
|
+
comment:
|
|
4
|
+
"This module uses a (version of an) npm module that has been deprecated. Either " +
|
|
5
|
+
"upgrade to a later version of that module, or find an alternative. Deprecated " +
|
|
6
|
+
"modules are a security risk.",
|
|
7
|
+
severity: "warn",
|
|
8
|
+
from: {},
|
|
9
|
+
to: {
|
|
10
|
+
dependencyTypes: ["deprecated"],
|
|
11
|
+
},
|
|
12
12
|
};
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
module.exports = {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
2
|
+
name: "not-to-unresolvable",
|
|
3
|
+
comment:
|
|
4
|
+
"This module depends on a module that cannot be found ('resolved to disk'). " +
|
|
5
|
+
"If it's an npm module: add it to your package.json. In all other cases you " +
|
|
6
|
+
"likely already know what to do.",
|
|
7
|
+
severity: "error",
|
|
8
|
+
from: {},
|
|
9
|
+
to: {
|
|
10
|
+
couldNotResolve: true,
|
|
11
|
+
},
|
|
12
12
|
};
|