TypeScript/scripts/errorCheck.ts

86 lines
2.8 KiB
TypeScript
Raw Normal View History

2019-06-19 16:58:49 +02:00
const fs = require("fs");
const async = require("async");
const glob = require("glob");
2015-06-25 22:34:42 +02:00
2019-06-14 11:18:27 +02:00
fs.readFile("src/compiler/diagnosticMessages.json", "utf-8", (err, data) => {
if (err) {
throw err;
}
2015-06-25 22:34:42 +02:00
2019-06-19 16:58:49 +02:00
const messages = JSON.parse(data);
const keys = Object.keys(messages);
2019-06-14 11:18:27 +02:00
console.log("Loaded " + keys.length + " errors");
2015-06-25 22:34:42 +02:00
2019-06-19 16:58:49 +02:00
for (const k of keys) {
2019-06-14 09:44:19 +02:00
messages[k].seen = false;
}
2015-06-25 22:34:42 +02:00
2019-06-19 16:58:49 +02:00
const errRegex = /\(\d+,\d+\): error TS([^:]+):/g;
const baseDir = "tests/baselines/reference/";
2015-06-25 22:34:42 +02:00
fs.readdir(baseDir, (err, files) => {
2019-06-14 11:18:27 +02:00
files = files.filter(f => f.indexOf(".errors.txt") > 0);
2019-07-29 17:39:11 +02:00
const tasks: ((callback: () => void) => void)[] = [];
files.forEach(f => tasks.push(done => {
2019-06-14 11:18:27 +02:00
fs.readFile(baseDir + f, "utf-8", (err, baseline) => {
if (err) throw err;
2015-06-25 22:34:42 +02:00
let g: string[];
while (g = errRegex.exec(baseline)) {
2019-06-19 16:58:49 +02:00
const errCode = +g[1];
const msg = keys.filter(k => messages[k].code === errCode)[0];
2019-06-14 09:44:19 +02:00
messages[msg].seen = true;
}
2015-06-25 22:34:42 +02:00
done();
});
}));
async.parallelLimit(tasks, 25, done => {
2019-06-14 11:18:27 +02:00
console.log("== List of errors not present in baselines ==");
let count = 0;
2019-06-19 16:58:49 +02:00
for (const k of keys) {
2019-06-14 09:44:19 +02:00
if (messages[k].seen !== true) {
console.log(k);
count++;
}
}
2019-06-14 11:18:27 +02:00
console.log(count + " of " + keys.length + " errors are not in baselines");
});
});
2015-06-25 22:34:42 +02:00
});
2019-06-14 11:18:27 +02:00
fs.readFile("src/compiler/diagnosticInformationMap.generated.ts", "utf-8", (err, data) => {
2019-06-19 16:58:49 +02:00
const errorRegexp = /\s(\w+): \{ code/g;
const errorNames: string[] = [];
let errMatch: string[];
while (errMatch = errorRegexp.exec(data)) {
errorNames.push(errMatch[1]);
}
2015-06-25 22:34:42 +02:00
2019-06-14 11:18:27 +02:00
let allSrc = "";
glob("./src/**/*.ts", {}, (err, files) => {
console.log("Reading " + files.length + " source files");
2019-06-19 16:58:49 +02:00
for (const file of files) {
2019-06-14 11:18:27 +02:00
if (file.indexOf("diagnosticInformationMap.generated.ts") > 0) {
continue;
}
2015-06-25 22:34:42 +02:00
2019-06-19 16:58:49 +02:00
const src = fs.readFileSync(file, "utf-8");
allSrc = allSrc + src;
}
2015-06-25 22:34:42 +02:00
2019-06-14 11:18:27 +02:00
console.log("Consumed " + allSrc.length + " characters of source");
2015-06-25 22:34:42 +02:00
let count = 0;
2019-06-14 11:18:27 +02:00
console.log("== List of errors not used in source ==");
2019-06-19 16:58:49 +02:00
for (const errName of errorNames) {
if (allSrc.indexOf(errName) < 0) {
console.log(errName);
count++;
}
}
2019-06-14 11:18:27 +02:00
console.log(count + " of " + errorNames.length + " errors are not used in source");
});
2015-06-25 22:34:42 +02:00
});