Remove 'async' dependency, used only in errorCheck.ts, modernize file (#50667)

This commit is contained in:
Jake Bailey 2022-09-23 09:54:36 -07:00 committed by GitHub
parent c6bef3f028
commit f16ca7dd36
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 55 additions and 81 deletions

26
package-lock.json generated
View File

@ -14,7 +14,6 @@
},
"devDependencies": {
"@octokit/rest": "latest",
"@types/async": "latest",
"@types/chai": "latest",
"@types/fs-extra": "^9.0.13",
"@types/glob": "latest",
@ -36,7 +35,6 @@
"@typescript-eslint/eslint-plugin": "^5.33.1",
"@typescript-eslint/parser": "^5.33.1",
"@typescript-eslint/utils": "^5.33.1",
"async": "latest",
"azure-devops-node-api": "^11.2.0",
"chai": "latest",
"chalk": "^4.1.2",
@ -411,12 +409,6 @@
"@octokit/openapi-types": "^13.11.0"
}
},
"node_modules/@types/async": {
"version": "3.2.15",
"resolved": "https://registry.npmjs.org/@types/async/-/async-3.2.15.tgz",
"integrity": "sha512-PAmPfzvFA31mRoqZyTVsgJMsvbynR429UTTxhmfsUCrWGh3/fxOrzqBtaTPJsn4UtzTv4Vb0+/O7CARWb69N4g==",
"dev": true
},
"node_modules/@types/chai": {
"version": "4.3.3",
"resolved": "https://registry.npmjs.org/@types/chai/-/chai-4.3.3.tgz",
@ -1209,12 +1201,6 @@
"node": ">=0.10.0"
}
},
"node_modules/async": {
"version": "3.2.4",
"resolved": "https://registry.npmjs.org/async/-/async-3.2.4.tgz",
"integrity": "sha512-iAB+JbDEGXhyIUavoDl9WP/Jj106Kz9DEn1DPgYw5ruDn0e3Wgi3sKFm55sASdGBNOQB8F59d9qQ7deqrHA8wQ==",
"dev": true
},
"node_modules/async-done": {
"version": "1.3.2",
"resolved": "https://registry.npmjs.org/async-done/-/async-done-1.3.2.tgz",
@ -8808,12 +8794,6 @@
"@octokit/openapi-types": "^13.11.0"
}
},
"@types/async": {
"version": "3.2.15",
"resolved": "https://registry.npmjs.org/@types/async/-/async-3.2.15.tgz",
"integrity": "sha512-PAmPfzvFA31mRoqZyTVsgJMsvbynR429UTTxhmfsUCrWGh3/fxOrzqBtaTPJsn4UtzTv4Vb0+/O7CARWb69N4g==",
"dev": true
},
"@types/chai": {
"version": "4.3.3",
"resolved": "https://registry.npmjs.org/@types/chai/-/chai-4.3.3.tgz",
@ -9415,12 +9395,6 @@
"integrity": "sha512-Q+JC7Whu8HhmTdBph/Tq59IoRtoy6KAm5zzPv00WdujX82lbAL8K7WVjne7vdCsAmbF4AYaDOPyO3k0kl8qIrw==",
"dev": true
},
"async": {
"version": "3.2.4",
"resolved": "https://registry.npmjs.org/async/-/async-3.2.4.tgz",
"integrity": "sha512-iAB+JbDEGXhyIUavoDl9WP/Jj106Kz9DEn1DPgYw5ruDn0e3Wgi3sKFm55sASdGBNOQB8F59d9qQ7deqrHA8wQ==",
"dev": true
},
"async-done": {
"version": "1.3.2",
"resolved": "https://registry.npmjs.org/async-done/-/async-done-1.3.2.tgz",

View File

@ -40,7 +40,6 @@
],
"devDependencies": {
"@octokit/rest": "latest",
"@types/async": "latest",
"@types/chai": "latest",
"@types/fs-extra": "^9.0.13",
"@types/glob": "latest",
@ -62,7 +61,6 @@
"@typescript-eslint/eslint-plugin": "^5.33.1",
"@typescript-eslint/parser": "^5.33.1",
"@typescript-eslint/utils": "^5.33.1",
"async": "latest",
"azure-devops-node-api": "^11.2.0",
"chai": "latest",
"chalk": "^4.1.2",

View File

@ -1,12 +1,12 @@
import * as fs from "fs";
import * as async from "async";
import * as glob from "glob";
import * as fsPromises from "fs/promises";
import * as _glob from "glob";
import * as util from "util";
fs.readFile("src/compiler/diagnosticMessages.json", "utf-8", (err, data) => {
if (err) {
throw err;
}
const glob = util.promisify(_glob);
async function checkErrorBaselines() {
const data = await fsPromises.readFile("src/compiler/diagnosticMessages.json", "utf-8");
const messages = JSON.parse(data);
const keys = Object.keys(messages);
console.log("Loaded " + keys.length + " errors");
@ -18,39 +18,35 @@ fs.readFile("src/compiler/diagnosticMessages.json", "utf-8", (err, data) => {
const errRegex = /\(\d+,\d+\): error TS([^:]+):/g;
const baseDir = "tests/baselines/reference/";
fs.readdir(baseDir, (err, files) => {
files = files.filter(f => f.indexOf(".errors.txt") > 0);
const tasks: ((callback: () => void) => void)[] = [];
files.forEach(f => tasks.push(done => {
fs.readFile(baseDir + f, "utf-8", (err, baseline) => {
if (err) throw err;
const files = (await fsPromises.readdir(baseDir)).filter(f => f.endsWith(".errors.txt"));
let g: RegExpExecArray | null;
while (g = errRegex.exec(baseline)) {
const errCode = +g[1];
const msg = keys.filter(k => messages[k].code === errCode)[0];
messages[msg].seen = true;
}
files.forEach(f => {
fs.readFile(baseDir + f, "utf-8", (err, baseline) => {
if (err) throw err;
done();
});
}));
async.parallelLimit(tasks, 25, done => {
console.log("== List of errors not present in baselines ==");
let count = 0;
for (const k of keys) {
if (messages[k].seen !== true) {
console.log(k);
count++;
}
let g: RegExpExecArray | null;
while (g = errRegex.exec(baseline)) {
const errCode = +g[1];
const msg = keys.filter(k => messages[k].code === errCode)[0];
messages[msg].seen = true;
}
console.log(count + " of " + keys.length + " errors are not in baselines");
});
});
});
fs.readFile("src/compiler/diagnosticInformationMap.generated.ts", "utf-8", (err, data) => {
console.log("== List of errors not present in baselines ==");
let count = 0;
for (const k of keys) {
if (messages[k].seen !== true) {
console.log(k);
count++;
}
}
console.log(count + " of " + keys.length + " errors are not in baselines");
}
async function checkSourceFiles() {
const data = await fsPromises.readFile("src/compiler/diagnosticInformationMap.generated.ts", "utf-8");
const errorRegexp = /\s(\w+): \{ code/g;
const errorNames: string[] = [];
let errMatch: RegExpExecArray | null;
@ -59,27 +55,33 @@ fs.readFile("src/compiler/diagnosticInformationMap.generated.ts", "utf-8", (err,
}
let allSrc = "";
glob("./src/**/*.ts", {}, (err, files) => {
console.log("Reading " + files.length + " source files");
for (const file of files) {
if (file.indexOf("diagnosticInformationMap.generated.ts") > 0) {
continue;
}
const src = fs.readFileSync(file, "utf-8");
allSrc = allSrc + src;
const files = await glob("./src/**/*.ts");
console.log("Reading " + files.length + " source files");
for (const file of files) {
if (file.indexOf("diagnosticInformationMap.generated.ts") > 0) {
continue;
}
console.log("Consumed " + allSrc.length + " characters of source");
const src = fs.readFileSync(file, "utf-8");
allSrc = allSrc + src;
}
let count = 0;
console.log("== List of errors not used in source ==");
for (const errName of errorNames) {
if (allSrc.indexOf(errName) < 0) {
console.log(errName);
count++;
}
console.log("Consumed " + allSrc.length + " characters of source");
let count = 0;
console.log("== List of errors not used in source ==");
for (const errName of errorNames) {
if (allSrc.indexOf(errName) < 0) {
console.log(errName);
count++;
}
console.log(count + " of " + errorNames.length + " errors are not used in source");
});
});
}
console.log(count + " of " + errorNames.length + " errors are not used in source");
}
async function main() {
await checkErrorBaselines();
await checkSourceFiles();
}
main();