@monorepolint/rules 0.5.0-alpha.9 → 0.5.0-alpha.95

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.
Files changed (138) hide show
  1. package/lib/__tests__/alphabeticalScripts.spec.d.ts +8 -0
  2. package/lib/__tests__/alphabeticalScripts.spec.d.ts.map +1 -0
  3. package/lib/__tests__/alphabeticalScripts.spec.js +61 -0
  4. package/lib/__tests__/alphabeticalScripts.spec.js.map +1 -0
  5. package/lib/__tests__/bannedDependencies.spec.d.ts +2 -0
  6. package/lib/__tests__/bannedDependencies.spec.d.ts.map +1 -0
  7. package/lib/__tests__/bannedDependencies.spec.js +161 -0
  8. package/lib/__tests__/bannedDependencies.spec.js.map +1 -0
  9. package/lib/__tests__/consistentDependencies.spec.js +30 -23
  10. package/lib/__tests__/consistentDependencies.spec.js.map +1 -1
  11. package/lib/__tests__/consistentVersions.spec.d.ts +8 -0
  12. package/lib/__tests__/consistentVersions.spec.d.ts.map +1 -0
  13. package/lib/__tests__/consistentVersions.spec.js +183 -0
  14. package/lib/__tests__/consistentVersions.spec.js.map +1 -0
  15. package/lib/__tests__/fileContents.spec.d.ts +8 -0
  16. package/lib/__tests__/fileContents.spec.d.ts.map +1 -0
  17. package/lib/__tests__/fileContents.spec.js +59 -0
  18. package/lib/__tests__/fileContents.spec.js.map +1 -0
  19. package/lib/__tests__/mustSatisfyPeerDependencies.spec.d.ts +8 -0
  20. package/lib/__tests__/mustSatisfyPeerDependencies.spec.d.ts.map +1 -0
  21. package/lib/__tests__/mustSatisfyPeerDependencies.spec.js +1063 -0
  22. package/lib/__tests__/mustSatisfyPeerDependencies.spec.js.map +1 -0
  23. package/lib/__tests__/nestedWorkspaces.spec.d.ts +2 -0
  24. package/lib/__tests__/nestedWorkspaces.spec.d.ts.map +1 -0
  25. package/lib/__tests__/nestedWorkspaces.spec.js +124 -0
  26. package/lib/__tests__/nestedWorkspaces.spec.js.map +1 -0
  27. package/lib/__tests__/packageEntry.spec.js +72 -27
  28. package/lib/__tests__/packageEntry.spec.js.map +1 -1
  29. package/lib/__tests__/packageOrder.spec.js +34 -33
  30. package/lib/__tests__/packageOrder.spec.js.map +1 -1
  31. package/lib/__tests__/packageScript.spec.js +50 -51
  32. package/lib/__tests__/packageScript.spec.js.map +1 -1
  33. package/lib/__tests__/requireDependency.spec.d.ts +2 -0
  34. package/lib/__tests__/requireDependency.spec.d.ts.map +1 -0
  35. package/lib/__tests__/requireDependency.spec.js +123 -0
  36. package/lib/__tests__/requireDependency.spec.js.map +1 -0
  37. package/lib/__tests__/utils.d.ts +69 -1
  38. package/lib/__tests__/utils.d.ts.map +1 -1
  39. package/lib/__tests__/utils.js +72 -12
  40. package/lib/__tests__/utils.js.map +1 -1
  41. package/lib/alphabeticalDependencies.d.ts +3 -1
  42. package/lib/alphabeticalDependencies.d.ts.map +1 -1
  43. package/lib/alphabeticalDependencies.js +5 -39
  44. package/lib/alphabeticalDependencies.js.map +1 -1
  45. package/lib/alphabeticalScripts.d.ts +12 -0
  46. package/lib/alphabeticalScripts.d.ts.map +1 -0
  47. package/lib/alphabeticalScripts.js +20 -0
  48. package/lib/alphabeticalScripts.js.map +1 -0
  49. package/lib/bannedDependencies.d.ts +23 -5
  50. package/lib/bannedDependencies.d.ts.map +1 -1
  51. package/lib/bannedDependencies.js +110 -36
  52. package/lib/bannedDependencies.js.map +1 -1
  53. package/lib/consistentDependencies.d.ts +8 -1
  54. package/lib/consistentDependencies.d.ts.map +1 -1
  55. package/lib/consistentDependencies.js +30 -12
  56. package/lib/consistentDependencies.js.map +1 -1
  57. package/lib/consistentVersions.d.ts +14 -0
  58. package/lib/consistentVersions.d.ts.map +1 -0
  59. package/lib/consistentVersions.js +94 -0
  60. package/lib/consistentVersions.js.map +1 -0
  61. package/lib/fileContents.d.ts +8 -8
  62. package/lib/fileContents.d.ts.map +1 -1
  63. package/lib/fileContents.js +32 -27
  64. package/lib/fileContents.js.map +1 -1
  65. package/lib/index.d.ts +5 -0
  66. package/lib/index.d.ts.map +1 -1
  67. package/lib/index.js +19 -8
  68. package/lib/index.js.map +1 -1
  69. package/lib/mustSatisfyPeerDependencies.d.ts +240 -0
  70. package/lib/mustSatisfyPeerDependencies.d.ts.map +1 -0
  71. package/lib/mustSatisfyPeerDependencies.js +636 -0
  72. package/lib/mustSatisfyPeerDependencies.js.map +1 -0
  73. package/lib/nestedWorkspaces.d.ts +13 -0
  74. package/lib/nestedWorkspaces.d.ts.map +1 -0
  75. package/lib/nestedWorkspaces.js +50 -0
  76. package/lib/nestedWorkspaces.js.map +1 -0
  77. package/lib/packageEntry.d.ts +15 -6
  78. package/lib/packageEntry.d.ts.map +1 -1
  79. package/lib/packageEntry.js +53 -18
  80. package/lib/packageEntry.js.map +1 -1
  81. package/lib/packageOrder.d.ts +3 -3
  82. package/lib/packageOrder.d.ts.map +1 -1
  83. package/lib/packageOrder.js +8 -7
  84. package/lib/packageOrder.js.map +1 -1
  85. package/lib/packageScript.d.ts +10 -10
  86. package/lib/packageScript.js +6 -5
  87. package/lib/packageScript.js.map +1 -1
  88. package/lib/requireDependency.d.ts +15 -0
  89. package/lib/requireDependency.d.ts.map +1 -0
  90. package/lib/requireDependency.js +65 -0
  91. package/lib/requireDependency.js.map +1 -0
  92. package/lib/standardTsconfig.d.ts +20 -8
  93. package/lib/standardTsconfig.d.ts.map +1 -1
  94. package/lib/standardTsconfig.js +36 -18
  95. package/lib/standardTsconfig.js.map +1 -1
  96. package/lib/util/checkAlpha.d.ts +10 -0
  97. package/lib/util/checkAlpha.d.ts.map +1 -0
  98. package/lib/util/checkAlpha.js +51 -0
  99. package/lib/util/checkAlpha.js.map +1 -0
  100. package/lib/util/makeDirectory.d.ts +8 -0
  101. package/lib/util/makeDirectory.d.ts.map +1 -0
  102. package/lib/util/makeDirectory.js +28 -0
  103. package/lib/util/makeDirectory.js.map +1 -0
  104. package/lib/util/packageDependencyGraphService.d.ts +37 -0
  105. package/lib/util/packageDependencyGraphService.d.ts.map +1 -0
  106. package/lib/util/packageDependencyGraphService.js +70 -0
  107. package/lib/util/packageDependencyGraphService.js.map +1 -0
  108. package/package.json +18 -15
  109. package/src/__tests__/alphabeticalScripts.spec.ts +75 -0
  110. package/src/__tests__/bannedDependencies.spec.ts +191 -0
  111. package/src/__tests__/consistentDependencies.spec.ts +39 -26
  112. package/src/__tests__/consistentVersions.spec.ts +223 -0
  113. package/src/__tests__/fileContents.spec.ts +74 -0
  114. package/src/__tests__/mustSatisfyPeerDependencies.spec.ts +1188 -0
  115. package/src/__tests__/nestedWorkspaces.spec.ts +152 -0
  116. package/src/__tests__/packageEntry.spec.ts +98 -31
  117. package/src/__tests__/packageOrder.spec.ts +46 -40
  118. package/src/__tests__/packageScript.spec.ts +62 -54
  119. package/src/__tests__/requireDependency.spec.ts +151 -0
  120. package/src/__tests__/utils.ts +113 -11
  121. package/src/alphabeticalDependencies.ts +3 -47
  122. package/src/alphabeticalScripts.ts +19 -0
  123. package/src/bannedDependencies.ts +133 -43
  124. package/src/consistentDependencies.ts +34 -12
  125. package/src/consistentVersions.ts +140 -0
  126. package/src/fileContents.ts +31 -27
  127. package/src/index.ts +5 -0
  128. package/src/mustSatisfyPeerDependencies.ts +739 -0
  129. package/src/nestedWorkspaces.ts +59 -0
  130. package/src/packageEntry.ts +67 -24
  131. package/src/packageOrder.ts +6 -6
  132. package/src/packageScript.ts +3 -3
  133. package/src/requireDependency.ts +69 -0
  134. package/src/standardTsconfig.ts +40 -18
  135. package/src/util/checkAlpha.ts +59 -0
  136. package/src/util/makeDirectory.ts +24 -0
  137. package/src/util/packageDependencyGraphService.ts +114 -0
  138. package/tsconfig.tsbuildinfo +1 -2439
@@ -0,0 +1,636 @@
1
+ "use strict";
2
+ /*!
3
+ * Copyright 2020 Palantir Technologies, Inc.
4
+ *
5
+ * Licensed under the MIT license. See LICENSE file in the project root for details.
6
+ *
7
+ */
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.isValidRange = exports.doesASatisfyB = exports.findIntersection = exports.RANGE_REGEX = exports.MATCH_MAJOR_VERSION_RANGE = exports.MATCH_GREATER_OR_EQUAL_VERSION_RANGE = exports.MATCH_ANY_VERSION_RANGE = exports.mustSatisfyPeerDependencies = void 0;
10
+ const tslib_1 = require("tslib");
11
+ const utils_1 = require("@monorepolint/utils");
12
+ const path_1 = tslib_1.__importDefault(require("path"));
13
+ const resolve_package_path_1 = tslib_1.__importDefault(require("resolve-package-path"));
14
+ const r = tslib_1.__importStar(require("runtypes"));
15
+ const semver_1 = require("semver");
16
+ const Options = r.Union(r.Partial({
17
+ skipUnparseableRanges: r.Undefined,
18
+ dependencyWhitelist: r.Undefined,
19
+ dependencyBlacklist: r.Undefined,
20
+ enforceForDevDependencies: r.Undefined,
21
+ }), r
22
+ .Record({
23
+ skipUnparseableRanges: r.Boolean,
24
+ })
25
+ .And(r.Partial({
26
+ dependencyWhitelist: r.Undefined,
27
+ dependencyBlacklist: r.Undefined,
28
+ enforceForDevDependencies: r.Undefined,
29
+ })), r
30
+ .Record({
31
+ dependencyWhitelist: r.Array(r.String),
32
+ })
33
+ .And(r.Partial({
34
+ skipUnparseableRanges: r.Undefined,
35
+ dependencyBlacklist: r.Undefined,
36
+ enforceForDevDependencies: r.Undefined,
37
+ })), r
38
+ .Record({
39
+ dependencyBlacklist: r.Array(r.String),
40
+ })
41
+ .And(r.Partial({
42
+ skipUnparseableRanges: r.Undefined,
43
+ dependencyWhitelist: r.Undefined,
44
+ enforceForDevDependencies: r.Undefined,
45
+ })), r
46
+ .Record({
47
+ enforceForDevDependencies: r.Boolean,
48
+ })
49
+ .And(r.Partial({
50
+ skipUnparseableRanges: r.Undefined,
51
+ dependencyWhitelist: r.Undefined,
52
+ dependencyBlacklist: r.Undefined,
53
+ })), r
54
+ .Record({
55
+ skipUnparseableRanges: r.Boolean,
56
+ dependencyWhitelist: r.Array(r.String),
57
+ })
58
+ .And(r.Partial({
59
+ dependencyBlacklist: r.Undefined,
60
+ enforceForDevDependencies: r.Undefined,
61
+ })), r
62
+ .Record({
63
+ skipUnparseableRanges: r.Boolean,
64
+ dependencyBlacklist: r.Array(r.String),
65
+ })
66
+ .And(r.Partial({
67
+ dependencyWhitelist: r.Undefined,
68
+ enforceForDevDependencies: r.Undefined,
69
+ })), r
70
+ .Record({
71
+ skipUnparseableRanges: r.Boolean,
72
+ enforceForDevDependencies: r.Boolean,
73
+ })
74
+ .And(r.Partial({
75
+ dependencyWhitelist: r.Undefined,
76
+ dependencyBlacklist: r.Undefined,
77
+ })), r
78
+ .Record({
79
+ dependencyWhitelist: r.Array(r.String),
80
+ dependencyBlacklist: r.Array(r.String),
81
+ })
82
+ .And(r.Partial({
83
+ skipUnparseableRanges: r.Undefined,
84
+ enforceForDevDependencies: r.Undefined,
85
+ })), r
86
+ .Record({
87
+ dependencyWhitelist: r.Array(r.String),
88
+ enforceForDevDependencies: r.Boolean,
89
+ })
90
+ .And(r.Partial({
91
+ skipUnparseableRanges: r.Undefined,
92
+ dependencyBlacklist: r.Undefined,
93
+ })), r
94
+ .Record({
95
+ dependencyBlacklist: r.Array(r.String),
96
+ enforceForDevDependencies: r.Boolean,
97
+ })
98
+ .And(r.Partial({
99
+ skipUnparseableRanges: r.Undefined,
100
+ dependencyWhitelist: r.Undefined,
101
+ })), r
102
+ .Record({
103
+ skipUnparseableRanges: r.Boolean,
104
+ dependencyWhitelist: r.Array(r.String),
105
+ dependencyBlacklist: r.Array(r.String),
106
+ })
107
+ .And(r.Partial({
108
+ enforceForDevDependencies: r.Undefined,
109
+ })), r
110
+ .Record({
111
+ skipUnparseableRanges: r.Boolean,
112
+ dependencyWhitelist: r.Array(r.String),
113
+ enforceForDevDependencies: r.Boolean,
114
+ })
115
+ .And(r.Partial({
116
+ dependencyBlacklist: r.Undefined,
117
+ })), r
118
+ .Record({
119
+ skipUnparseableRanges: r.Boolean,
120
+ dependencyBlacklist: r.Array(r.String),
121
+ enforceForDevDependencies: r.Boolean,
122
+ })
123
+ .And(r.Partial({
124
+ dependencyWhitelist: r.Undefined,
125
+ })), r
126
+ .Record({
127
+ dependencyWhitelist: r.Array(r.String),
128
+ dependencyBlacklist: r.Array(r.String),
129
+ enforceForDevDependencies: r.Boolean,
130
+ })
131
+ .And(r.Partial({
132
+ skipUnparseableRanges: r.Undefined,
133
+ })), r.Record({
134
+ skipUnparseableRanges: r.Boolean,
135
+ dependencyWhitelist: r.Array(r.String),
136
+ dependencyBlacklist: r.Array(r.String),
137
+ enforceForDevDependencies: r.Boolean,
138
+ }));
139
+ exports.mustSatisfyPeerDependencies = {
140
+ check: checkSatisfyPeerDependencies,
141
+ optionsRuntype: Options,
142
+ };
143
+ /**
144
+ * separating on `|`, this regex allows any of the following formats:
145
+ * - `*`
146
+ * - `x`
147
+ *
148
+ * More info: https://docs.npmjs.com/about-semantic-versioning
149
+ */
150
+ exports.MATCH_ANY_VERSION_RANGE = /^(\*|x)$/;
151
+ /**
152
+ * This regex allows any of the following formats:
153
+ * - `>=15`
154
+ * - `>=15.2`
155
+ * - `>=15.2.1`
156
+ * - `>=15.2.1-rc.0`
157
+ * - `>=15.2.1+sha`
158
+ * - `>=15.2.1-rc.0+sha`
159
+ *
160
+ * See https://semver.org/#spec-item-9 for details about semver formatting, and
161
+ * https://regex101.com/r/vkijKf/1/ for a sample Regex.
162
+ *
163
+ * Note that the semver spec does _not_ specify npm range syntax. (`^`, `||`, `~`, `>`, etc.)
164
+ *
165
+ * More info: https://docs.npmjs.com/about-semantic-versioning
166
+ */
167
+ exports.MATCH_GREATER_OR_EQUAL_VERSION_RANGE = /^>= ?\d+(?:\.\d+|\.\d+\.\d+(?:-((?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?)?$/;
168
+ /**
169
+ * This regex allows any of the following formats:
170
+ * - `15`
171
+ * - `^15`
172
+ * - `15.x`
173
+ * - `^15.x`
174
+ * - `15.x.x`
175
+ * - `^15.x.x`
176
+ * - `^15.2`
177
+ * - `^15.2.x`
178
+ * - `^15.2.1`
179
+ * - `^15.2.1-rc.0`
180
+ * - `^15.2.1+sha`
181
+ * - `^15.2.1-rc.0+sha`
182
+ *
183
+ * See https://semver.org/#spec-item-9 for details about semver formatting, and
184
+ * https://regex101.com/r/vkijKf/1/ for a sample Regex.
185
+ *
186
+ * Note that the semver spec does _not_ specify npm range syntax. (`^`, `||`, `~`, `>`, etc.)
187
+ *
188
+ * More info: https://docs.npmjs.com/about-semantic-versioning
189
+ */
190
+ exports.MATCH_MAJOR_VERSION_RANGE = /^(?:\^?\d+|\^?\d+\.x|\^?\d+\.x\.x|\^\d+\.\d+|\^\d+\.\d+\.x|\^\d+\.\d+\.\d+(?:-((?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?)$/;
191
+ /**
192
+ * Does not currently accept `<`, `<=`, `>`, `=` or `-` for ranges (e.g. `> 2.5.1 < 3` or `1.0.0 - 1.2.0`),
193
+ * though it will accept isolated `>=` ranges (e.g. `>=2.5.1`, but not `^1 || >=2.5.1`)
194
+ *
195
+ * See https://semver.org/#spec-item-9 for details about semver formatting, and
196
+ * https://regex101.com/r/vkijKf/1/ for a sample Regex.
197
+ *
198
+ * Note that the semver spec does _not_ specify npm range syntax. (`^`, `||`, `~`, `>`, etc.)
199
+ *
200
+ * More info: https://docs.npmjs.com/about-semantic-versioning
201
+ *
202
+ * TODO: accept minor pins `~4.2.1`
203
+ */
204
+ exports.RANGE_REGEX = /^(\*|x|>= ?\d+(?:\.\d+|\.\d+\.\d+(?:-((?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?)?|\^?\d+(\.x|\.x\.x|\.\d+|\.\d+\.x|\.\d+\.\d+(?:-((?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?)?( \|\| \^?\d+(\.x|\.x\.x|\.\d+|\.\d+\.x|\.\d+\.\d+(?:-((?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?)?)*)$/;
205
+ function checkSatisfyPeerDependencies(context, opts) {
206
+ const { dependencyBlacklist, dependencyWhitelist, enforceForDevDependencies, skipUnparseableRanges } = opts;
207
+ const packageJsonPath = path_1.default.resolve(context.getPackageJsonPath());
208
+ const packageJson = require(packageJsonPath);
209
+ const packageDependencies = packageJson.dependencies || {};
210
+ const packageDevDependencies = packageJson.devDependencies || {};
211
+ const packagePeerDependencies = packageJson.peerDependencies || {};
212
+ const packageName = packageJson.name || packageJsonPath;
213
+ // check that no peer dependencies are also declared as regular dependencies
214
+ for (const [peerDependencyName, peerDependencyRange] of Object.entries(packagePeerDependencies)) {
215
+ if (shouldSkipPackage({ dependencyBlacklist, dependencyWhitelist, packageName: peerDependencyName })) {
216
+ continue;
217
+ }
218
+ const dependencyRange = packageDependencies[peerDependencyName];
219
+ if (dependencyRange != null) {
220
+ context.addError({
221
+ file: packageJsonPath,
222
+ message: `[0] Package ${packageName} has overloaded ${peerDependencyName} dependencies.\n\t` +
223
+ `Peer dependency '${peerDependencyRange}' and regular dependency '${dependencyRange}'.`,
224
+ });
225
+ }
226
+ }
227
+ // map of all inherited peer dependency requirements
228
+ const allRequiredPeerDependencies = {};
229
+ // for each of this package's dependencies, add the dependency's peer requirements into `allRequiredPeerDependencies`
230
+ const allDependencies = enforceForDevDependencies
231
+ ? [...Object.keys(packageDependencies), ...Object.keys(packageDevDependencies)]
232
+ : Object.keys(packageDependencies);
233
+ for (const dependency of allDependencies) {
234
+ const dependencyPackageJsonPath = (0, resolve_package_path_1.default)(dependency, path_1.default.dirname(packageJsonPath));
235
+ if (dependencyPackageJsonPath == null) {
236
+ throw new Error(`Could not resolve ${dependency} from ${path_1.default.dirname(packageJsonPath)}`);
237
+ }
238
+ const dependencyPackageJson = require(dependencyPackageJsonPath);
239
+ const requiredPeerDependencies = dependencyPackageJson.peerDependencies;
240
+ if (requiredPeerDependencies == null) {
241
+ continue;
242
+ }
243
+ for (const [peerDependencyName, range] of Object.entries(requiredPeerDependencies)) {
244
+ if (shouldSkipPackage({ dependencyBlacklist, dependencyWhitelist, packageName: peerDependencyName })) {
245
+ continue;
246
+ }
247
+ if (!isValidRange(range)) {
248
+ const message = `Unable to parse ${dependencyPackageJson.name}'s ${peerDependencyName} peer dependency range '${range}'.`;
249
+ if (skipUnparseableRanges) {
250
+ context.addWarning({ file: dependencyPackageJsonPath, message });
251
+ continue;
252
+ }
253
+ throw new Error(message);
254
+ }
255
+ if (allRequiredPeerDependencies[peerDependencyName] == null) {
256
+ allRequiredPeerDependencies[peerDependencyName] = [];
257
+ }
258
+ allRequiredPeerDependencies[peerDependencyName].push({ fromPackageName: dependencyPackageJson.name, range });
259
+ }
260
+ }
261
+ for (const [peerDependencyName, peerDependencyRequirements] of Object.entries(allRequiredPeerDependencies)) {
262
+ // for each inherited peer dependency, determine the strictest range
263
+ let mostStrictPeerRequirement = {
264
+ fromPeerDependencyRequirements: [peerDependencyRequirements[0]],
265
+ range: peerDependencyRequirements[0].range,
266
+ };
267
+ for (const peerRequirement of peerDependencyRequirements) {
268
+ if (doesASatisfyB(mostStrictPeerRequirement.range, peerRequirement.range)) {
269
+ continue;
270
+ }
271
+ else if (doesASatisfyB(peerRequirement.range, mostStrictPeerRequirement.range)) {
272
+ mostStrictPeerRequirement = {
273
+ fromPeerDependencyRequirements: [peerRequirement],
274
+ range: peerRequirement.range,
275
+ };
276
+ }
277
+ else {
278
+ const maybeIntersection = findIntersection(peerRequirement.range, mostStrictPeerRequirement.range);
279
+ if (maybeIntersection !== undefined) {
280
+ mostStrictPeerRequirement = {
281
+ fromPeerDependencyRequirements: [
282
+ ...mostStrictPeerRequirement.fromPeerDependencyRequirements,
283
+ peerRequirement,
284
+ ],
285
+ range: maybeIntersection,
286
+ };
287
+ }
288
+ else {
289
+ context.addError({
290
+ file: packageJsonPath,
291
+ message: `[1] Package ${packageName} has conflicting inherited ${peerDependencyName} peer dependencies.\n\t` +
292
+ `Dependency ${peerRequirement.fromPackageName} requires '${peerRequirement.range}' but\n\t` +
293
+ getMostStrictStatement(mostStrictPeerRequirement),
294
+ });
295
+ }
296
+ }
297
+ }
298
+ // if this package has a dependency on an inherited peer dependency,
299
+ // the range must be equal to or stricter than `mostStrictPeerRequirement`
300
+ const packageDependencyRange = packageDependencies[peerDependencyName];
301
+ if (packageDependencyRange != null) {
302
+ if (!isValidRange(packageDependencyRange)) {
303
+ const message = `Unable to parse ${packageName}'s ${peerDependencyName} dependency range '${packageDependencyRange}'.`;
304
+ if (skipUnparseableRanges) {
305
+ context.addWarning({ file: packageJsonPath, message });
306
+ }
307
+ else {
308
+ throw new Error(message);
309
+ }
310
+ }
311
+ else if (!doesASatisfyB(packageDependencyRange, mostStrictPeerRequirement.range)) {
312
+ context.addError({
313
+ file: packageJsonPath,
314
+ message: `[2] Package ${packageName} dependency on ${peerDependencyName} '${packageDependencyRange}' does not satisfy inherited peer dependencies.\n\t` +
315
+ getMostStrictStatement(mostStrictPeerRequirement),
316
+ });
317
+ }
318
+ }
319
+ // for every inherited peer dependency, this package must declare a dependency or peer dependency
320
+ // equal to or stricter than `mostStrictPeerRequirement`
321
+ const packagePeerDependencyRange = packagePeerDependencies[peerDependencyName];
322
+ if (packageDependencyRange == null && packagePeerDependencyRange == null) {
323
+ context.addError({
324
+ file: packageJsonPath,
325
+ message: `[3] Package ${packageName} is missing required ${peerDependencyName} dependency.\n\t` +
326
+ getMostStrictStatement(mostStrictPeerRequirement),
327
+ fixer: getAddDependencyTypeFixer({
328
+ packageJsonPath,
329
+ dependencyType: "peerDependencies",
330
+ dependencyName: peerDependencyName,
331
+ version: mostStrictPeerRequirement.range,
332
+ host: context.host,
333
+ }),
334
+ });
335
+ }
336
+ // if this package has a peer dependency on an inherited peer dependency,
337
+ // the range must be equal to or stricter than `mostStrictPeerRequirement`
338
+ if (packagePeerDependencyRange != null) {
339
+ if (!isValidRange(packagePeerDependencyRange)) {
340
+ const message = `Unable to parse ${packageName}'s ${peerDependencyName} peer dependency range '${packagePeerDependencyRange}'.`;
341
+ if (skipUnparseableRanges) {
342
+ context.addWarning({ file: packageJsonPath, message });
343
+ }
344
+ else {
345
+ throw new Error(message);
346
+ }
347
+ }
348
+ else if (!doesASatisfyB(packagePeerDependencyRange, mostStrictPeerRequirement.range)) {
349
+ context.addError({
350
+ file: packageJsonPath,
351
+ message: `[4] Package ${packageName} peer dependency on ${peerDependencyName} '${packagePeerDependencyRange}' is not strict enough.\n\t` +
352
+ getMostStrictStatement(mostStrictPeerRequirement),
353
+ fixer: getAddDependencyTypeFixer({
354
+ packageJsonPath,
355
+ dependencyType: "peerDependencies",
356
+ dependencyName: peerDependencyName,
357
+ version: mostStrictPeerRequirement.range,
358
+ host: context.host,
359
+ }),
360
+ });
361
+ }
362
+ }
363
+ }
364
+ }
365
+ function shouldSkipPackage({ dependencyBlacklist, dependencyWhitelist, packageName, }) {
366
+ // blacklist should take precedance
367
+ if ((dependencyBlacklist != null && dependencyBlacklist.includes(packageName)) ||
368
+ (dependencyWhitelist != null && !dependencyWhitelist.includes(packageName))) {
369
+ return true;
370
+ }
371
+ return false;
372
+ }
373
+ function getMostStrictStatement(mostStrictPeerRequirement) {
374
+ if (mostStrictPeerRequirement.fromPeerDependencyRequirements.length === 1) {
375
+ const dependencyName = mostStrictPeerRequirement.fromPeerDependencyRequirements[0].fromPackageName;
376
+ return `Dependency ${dependencyName} requires '${mostStrictPeerRequirement.range}'.`;
377
+ }
378
+ else {
379
+ const dependencyNames = mostStrictPeerRequirement.fromPeerDependencyRequirements
380
+ .map((peerDependencyRequirement) => peerDependencyRequirement.fromPackageName)
381
+ .join(", ");
382
+ const dependencyRequirements = mostStrictPeerRequirement.fromPeerDependencyRequirements
383
+ .map((peerDependencyRequirement) => `'${peerDependencyRequirement.range}'`)
384
+ .join(", ");
385
+ return (`Dependencies [${dependencyNames}] require [${dependencyRequirements}] respectively, ` +
386
+ `resolving to '${mostStrictPeerRequirement.range}'.`);
387
+ }
388
+ }
389
+ /**
390
+ * Given two version ranges, find the maximum intersecting range
391
+ * of `a` and `b`. `findIntersection(a,b)` should return the same
392
+ * result as `findIntersection(b,a)`.
393
+ *
394
+ * NOTE: This code assumes that input version ranges match `RANGE_REGEX`.
395
+ * Additionally, major version ranges must not be repeated in union ranges.
396
+ * e.g. `^15.0.5 || ^16.0.0` is permitted, but `15.0.5 || 15.0.999` is not.
397
+ *
398
+ * EXAMPLES:
399
+ * findIntersection("15.1.0", "*") => "15.1.0"
400
+ * findIntersection("^15", "*") => "^15"
401
+ * findIntersection(">=15", "*") => ">=15"
402
+ * findIntersection("*", "*") => "*"
403
+ * findIntersection("15.1.0", ">=1") => "15.1.0"
404
+ * findIntersection("^15", ">=1") => "^15"
405
+ * findIntersection(">=15", ">=1") => ">=15"
406
+ * findIntersection("15.1.0", "^15") => "15.1.0"
407
+ * findIntersection("^15.2", "^15") => "^15.2"
408
+ * findIntersection("14", "^15") => undefined
409
+ * findIntersection("15.1.0", "^15 || ^16") => "15.1.0"
410
+ * findIntersection("^15.2", "^15 || ^16") => "^15.2"
411
+ * findIntersection("14", "^15 || ^16") => undefined
412
+ * findIntersection("^15.2 || ^16", "^15 || ^16.4") => "^15.2 || ^16.4"
413
+ *
414
+ * @param a version range that matches `RANGE_REGEX`
415
+ * @param b version range that matches `RANGE_REGEX`
416
+ * @returns the maximum intersecting `ValidRange`, or `undefined` if there is no intersection
417
+ */
418
+ function findIntersection(a, b) {
419
+ if (doesASatisfyB(a, b)) {
420
+ return a;
421
+ }
422
+ else if (doesASatisfyB(b, a)) {
423
+ return b;
424
+ }
425
+ // It's safe to assume that `isAnyVersionRange(a)` and `isAnyVersionRange(b)` are false,
426
+ // since a `MATCH_ANY_VERSION_RANGE` would have been satisfied by anything.
427
+ if (isAnyVersionRange(a) || isAnyVersionRange(b)) {
428
+ throw new Error();
429
+ }
430
+ const aVersions = a.includes("||") ? a.split("||").map((s) => s.trim()) : [a];
431
+ const bVersions = b.includes("||") ? b.split("||").map((s) => s.trim()) : [b];
432
+ const aIsGreaterOrEqualVersionRange = isGreaterOrEqualVersionRange(a);
433
+ const bIsGreaterOrEqualVersionRange = isGreaterOrEqualVersionRange(b);
434
+ if (aIsGreaterOrEqualVersionRange && bIsGreaterOrEqualVersionRange) {
435
+ // If the ranges were equal, they'd both satisfy each other.
436
+ // Otherwise, the higher range should have satisfied the lower range.
437
+ throw new Error();
438
+ }
439
+ if (aIsGreaterOrEqualVersionRange) {
440
+ const aSemVer = (0, semver_1.coerce)(a);
441
+ // keep every version where `bSemVer` is >= `aSemVer`
442
+ // where bVersion has an operator, we need to adjust the version to take into
443
+ // account aVersion, e.g. if a is >=15.2.3 and b is ^15, then the intersection is actually ^15.2.3
444
+ const compatibleBVersions = bVersions
445
+ .map((bVersion) => {
446
+ const bSemVer = (0, semver_1.coerce)(bVersion);
447
+ if (bVersion.startsWith("^") && bSemVer.major >= aSemVer.major) {
448
+ return `^${bSemVer.compare(aSemVer) >= 0 ? bSemVer.raw : aSemVer.raw}`;
449
+ }
450
+ return bSemVer.compare(aSemVer) !== -1 ? bVersion : undefined;
451
+ })
452
+ .filter((bVersion) => bVersion != null);
453
+ if (compatibleBVersions.length === 0) {
454
+ return undefined;
455
+ }
456
+ return compatibleBVersions.join(" || ");
457
+ }
458
+ if (bIsGreaterOrEqualVersionRange) {
459
+ const bSemVer = (0, semver_1.coerce)(b);
460
+ // keep every version where `aSemVer` is >= `bSemVer`
461
+ // where aVersion has an operator, we need to adjust the version to take into
462
+ // account bVersion, e.g. if b is >=15.2.3 and a is ^15, then the intersection is actually ^15.2.3
463
+ const compatibleAVersions = aVersions
464
+ .map((aVersion) => {
465
+ const aSemVer = (0, semver_1.coerce)(aVersion);
466
+ if (aVersion.startsWith("^") && aSemVer.major >= bSemVer.major) {
467
+ return `^${aSemVer.compare(bSemVer) >= 0 ? aSemVer.raw : bSemVer.raw}`;
468
+ }
469
+ return aSemVer.compare(bSemVer) !== -1 ? aVersion : undefined;
470
+ })
471
+ .filter((aVersion) => aVersion != null);
472
+ if (compatibleAVersions.length === 0) {
473
+ return undefined;
474
+ }
475
+ return compatibleAVersions.join(" || ");
476
+ }
477
+ const compatibleVersions = aVersions
478
+ .map((aVersion) => {
479
+ const aSemVer = (0, semver_1.coerce)(aVersion);
480
+ const majorMatchingBVersion = bVersions.find((m) => (0, semver_1.coerce)(m).major === aSemVer.major);
481
+ if (majorMatchingBVersion === undefined) {
482
+ // there is no intersecting `b` major version for this `a` major version
483
+ return undefined;
484
+ }
485
+ if (doesASatisfyB(aVersion, majorMatchingBVersion)) {
486
+ return aVersion;
487
+ }
488
+ else if (doesASatisfyB(majorMatchingBVersion, aVersion)) {
489
+ return majorMatchingBVersion;
490
+ }
491
+ else {
492
+ return undefined;
493
+ }
494
+ })
495
+ .filter((aVersion) => aVersion !== undefined);
496
+ if (compatibleVersions.length === 0) {
497
+ return undefined;
498
+ }
499
+ return compatibleVersions.join(" || ");
500
+ }
501
+ exports.findIntersection = findIntersection;
502
+ /**
503
+ * Given two version ranges, determine whether `a` satisfies `b`.
504
+ * `a` satisfies `b` iff `a` is a "more strict than or equal to" subset of `b`.
505
+ * For example, both `^15` and `^15.2.0` satisfy `^15`, but `^15 || ^16` does not.
506
+ *
507
+ * NOTE: This code assumes that input version ranges match `RANGE_REGEX`.
508
+ * Additionally, major version ranges must not be repeated in union ranges.
509
+ * e.g. `^15.0.5 || ^16.0.0` is permitted, but `15.0.5 || 15.0.999` is not.
510
+ *
511
+ * To determine that `a` is "more strict than or equal to" `b`, we first
512
+ * split the set of all versions or ranges that are potentially unioned in `a` and `b`.
513
+ * For example, if `a` is `15.0.5`, we produce the set `[ "15.0.5" ]`,
514
+ * and if `b` is `^15 || ^16`, we produce the set `[ "^15", "^16" ]`.
515
+ * `a` is "more strict than or equal to" `b` iff each entry in `a`'s set
516
+ * satisfies (equal to or greater than) some entry in `b`.
517
+ *
518
+ * The following version ranges satisfy `^15.0.5 || ^16.0.0`:
519
+ * - `^15.0.5 || ^16.0.0`
520
+ * - `^15.0.5 || ^16.x.x`
521
+ * - `15.0.5 || 16.0.0`
522
+ * - `^15.0.999 || ^16.0.0`
523
+ * - `^15.0.5 || ^16.0.999`
524
+ * - `^15.0.999`
525
+ * - `^16.0.0`
526
+ * - `16.0.0`
527
+ * The following version ranges do not satisfy `^15.0.5 || ^16.0.0`:
528
+ * - `^15.0.0 || ^16.0.0`
529
+ * - `^15.0.5 || ^17.0.0`
530
+ * - `^14.0.0 || ^15.0.5 || ^16.0.0`
531
+ * - `^17.0.0`
532
+ * - `17.0.0`
533
+ *
534
+ * @param a version range that matches `RANGE_REGEX`
535
+ * @param b version range that matches `RANGE_REGEX`
536
+ * @returns `true` if `a` is more strict than or equal to `b`, `false` otherwise
537
+ */
538
+ function doesASatisfyB(a, b) {
539
+ if (a === b) {
540
+ return true;
541
+ }
542
+ const aIsAnyVersionRange = isAnyVersionRange(a);
543
+ const bIsAnyVersionRange = isAnyVersionRange(b);
544
+ if (bIsAnyVersionRange) {
545
+ return true;
546
+ }
547
+ else if (aIsAnyVersionRange) {
548
+ // `bIsAnyVersionRange` is `false`
549
+ // `a` permits more values than `b`, therefore `a` is "less strict"
550
+ return false;
551
+ }
552
+ const aVersions = a.includes("||") ? a.split("||").map((s) => s.trim()) : [a];
553
+ const bVersions = b.includes("||") ? b.split("||").map((s) => s.trim()) : [b];
554
+ const aIsGreaterOrEqualVersionRange = isGreaterOrEqualVersionRange(a);
555
+ const bIsGreaterOrEqualVersionRange = isGreaterOrEqualVersionRange(b);
556
+ if (aIsGreaterOrEqualVersionRange && bIsGreaterOrEqualVersionRange) {
557
+ const aSemVer = (0, semver_1.coerce)(a);
558
+ const bSemVer = (0, semver_1.coerce)(b);
559
+ // `a` satisfies `b` so long as `aSemVer` is greater than or equal to `bSemVer`
560
+ return aSemVer.compare(bSemVer) !== -1;
561
+ }
562
+ else if (bIsGreaterOrEqualVersionRange) {
563
+ const bSemVer = (0, semver_1.coerce)(b);
564
+ return aVersions.every((aVersion) => {
565
+ const aSemVer = (0, semver_1.coerce)(aVersion);
566
+ // `a` satisfies `b` so long as `aSemVer` is greater than or equal to `bSemVer`
567
+ return aSemVer.compare(bSemVer) !== -1;
568
+ });
569
+ }
570
+ else if (aIsGreaterOrEqualVersionRange) {
571
+ // `bIsGreaterOrEqualVersionRange` is `false` (and `bIsAnyVersionRange` is `false`)
572
+ // `a` permits more values than `b`, therefore `a` is "less strict"
573
+ return false;
574
+ }
575
+ return aVersions.every((aVersion) => {
576
+ const aSemVer = (0, semver_1.coerce)(aVersion);
577
+ const majorMatchingBVersion = bVersions.find((m) => (0, semver_1.coerce)(m).major === aSemVer.major);
578
+ if (majorMatchingBVersion === undefined) {
579
+ // `a` permits a major version that is not permitted by `b`, therefore `a` is "less strict"
580
+ return false;
581
+ }
582
+ const aVersionIsRange = isMajorVersionRange(aVersion);
583
+ const majorMatchingBSemVer = (0, semver_1.coerce)(majorMatchingBVersion);
584
+ const majorMatchingBVersionIsRange = isMajorVersionRange(majorMatchingBVersion);
585
+ if (majorMatchingBVersionIsRange) {
586
+ // `a` satisfies `b` so long as `aSemVer` is greater than or equal to `majorMatchingBSemVer`
587
+ // this is true whether or not `aVersionIsRange`
588
+ return aSemVer.compare(majorMatchingBSemVer) !== -1;
589
+ }
590
+ else {
591
+ // `majorMatchingBVersionIsRange` is `false`
592
+ if (aVersionIsRange) {
593
+ // `a` permits more values than `b`, therefore `a` is "less strict"
594
+ // e.g if `b` is `15.5.5`, this is true whether `a` is `^15.0.0`, `^15.5.5`, or `^15.9.9`
595
+ return false;
596
+ }
597
+ else {
598
+ // `aVersionIsRange` is `false`
599
+ // `a` satisfies `b` if and only if `aSemVer` is equal to `majorMatchingBSemVer`
600
+ return aSemVer.compare(majorMatchingBSemVer) === 0;
601
+ }
602
+ }
603
+ });
604
+ }
605
+ exports.doesASatisfyB = doesASatisfyB;
606
+ /**
607
+ * Returns true if the version evaluates to 'any', e.g. * or x
608
+ */
609
+ function isAnyVersionRange(version) {
610
+ return exports.MATCH_ANY_VERSION_RANGE.test(version);
611
+ }
612
+ /**
613
+ * Retruns true if the version begins with '>='
614
+ */
615
+ function isGreaterOrEqualVersionRange(version) {
616
+ return exports.MATCH_GREATER_OR_EQUAL_VERSION_RANGE.test(version);
617
+ }
618
+ function isMajorVersionRange(version) {
619
+ return exports.MATCH_MAJOR_VERSION_RANGE.test(version);
620
+ }
621
+ function isValidRange(version) {
622
+ return exports.RANGE_REGEX.test(version);
623
+ }
624
+ exports.isValidRange = isValidRange;
625
+ function getAddDependencyTypeFixer({ packageJsonPath, dependencyType, dependencyName, version, host, }) {
626
+ return () => {
627
+ (0, utils_1.mutateJson)(packageJsonPath, host, (packageJson) => {
628
+ if (packageJson[dependencyType] == null) {
629
+ packageJson[dependencyType] = {};
630
+ }
631
+ packageJson[dependencyType][dependencyName] = version;
632
+ return packageJson;
633
+ });
634
+ };
635
+ }
636
+ //# sourceMappingURL=mustSatisfyPeerDependencies.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mustSatisfyPeerDependencies.js","sourceRoot":"","sources":["../src/mustSatisfyPeerDependencies.ts"],"names":[],"mappings":"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"}