forked from microsoft/rushstack
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbuild.js
108 lines (92 loc) · 3.81 KB
/
build.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
// This project has a duplicate "eslint-bulk-suppressions-test-legacy" intended to test eslint
// against the older version of the TypeScript parser. Any modifications made to this project
// should be reflected in "eslint-bulk-suppressions-test-legacy" as well.
const { FileSystem, Executable, Text, Import } = require('@rushstack/node-core-library');
const path = require('path');
const {
ESLINT_PACKAGE_NAME_ENV_VAR_NAME
} = require('@rushstack/eslint-patch/lib/eslint-bulk-suppressions/constants');
const eslintBulkStartPath = Import.resolveModule({
modulePath: '@rushstack/eslint-bulk/lib/start',
baseFolderPath: __dirname
});
function tryLoadSuppressions(suppressionsJsonPath) {
try {
return Text.convertToLf(FileSystem.readFile(suppressionsJsonPath)).trim();
} catch (e) {
if (FileSystem.isNotExistError(e)) {
return '';
} else {
throw e;
}
}
}
const RUN_FOLDER_PATHS = ['client', 'server'];
const ESLINT_PACKAGE_NAMES = ['eslint'];
const updateFilePaths = new Set();
for (const runFolderPath of RUN_FOLDER_PATHS) {
const folderPath = `${__dirname}/${runFolderPath}`;
const suppressionsJsonPath = `${folderPath}/.eslint-bulk-suppressions.json`;
const folderItems = FileSystem.readFolderItems(folderPath);
for (const folderItem of folderItems) {
if (folderItem.isFile() && folderItem.name.match(/^\.eslint\-bulk\-suppressions\-[\d.]+\.json$/)) {
const fullPath = `${folderPath}/${folderItem.name}`;
updateFilePaths.add(fullPath);
}
}
for (const eslintPackageName of ESLINT_PACKAGE_NAMES) {
const { version: eslintVersion } = require(`${eslintPackageName}/package.json`);
const startLoggingMessage = `-- Running eslint-bulk-suppressions for eslint@${eslintVersion} in ${runFolderPath} --`;
console.log(startLoggingMessage);
const referenceSuppressionsJsonPath = `${folderPath}/.eslint-bulk-suppressions-${eslintVersion}.json`;
const existingSuppressions = tryLoadSuppressions(referenceSuppressionsJsonPath);
// The eslint-bulk-suppressions patch expects to find "eslint" in the shell PATH. To ensure deterministic
// test behavior, we need to designate an explicit "node_modules/.bin" folder.
//
// Use the ".bin" folder from @rushstack/eslint-patch as a workaround for this PNPM bug:
// https://github.com/pnpm/pnpm/issues/7833
const dependencyBinFolder = path.join(
__dirname,
'node_modules',
'@rushstack',
'eslint-patch',
'node_modules',
'.bin'
);
const shellPathWithEslint = `${dependencyBinFolder}${path.delimiter}${process.env['PATH']}`;
const executableResult = Executable.spawnSync(
process.argv0,
[eslintBulkStartPath, 'suppress', '--all', 'src'],
{
currentWorkingDirectory: folderPath,
environment: {
...process.env,
PATH: shellPathWithEslint,
[ESLINT_PACKAGE_NAME_ENV_VAR_NAME]: eslintPackageName
}
}
);
if (executableResult.status !== 0) {
console.error('The eslint-bulk-suppressions command failed.');
console.error('STDOUT:');
console.error(executableResult.stdout.toString());
console.error('STDERR:');
console.error(executableResult.stderr.toString());
process.exit(1);
}
const newSuppressions = tryLoadSuppressions(suppressionsJsonPath);
if (newSuppressions === existingSuppressions) {
updateFilePaths.delete(referenceSuppressionsJsonPath);
} else {
updateFilePaths.add(referenceSuppressionsJsonPath);
FileSystem.writeFile(referenceSuppressionsJsonPath, newSuppressions);
}
FileSystem.deleteFile(suppressionsJsonPath);
}
}
if (updateFilePaths.size > 0) {
for (const updateFilePath of updateFilePaths) {
console.log(`The suppressions file "${updateFilePath}" was updated and must be committed to git.`);
}
process.exit(1);
}