chore: fix DocLint method diffing (#5594)

Our logic around missing methods wasn't quite right; if there is no set of missing methods for a class it _is_ an error and we still need to report it, we don't want to `continue`.
This commit is contained in:
Jack Franklin 2020-04-06 11:36:28 +01:00 committed by GitHub
parent 841c2a5fc0
commit efe561e112
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -172,6 +172,7 @@ function compareDocumentations(actual, expected) {
const actualClasses = Array.from(actual.classes.keys()).sort(); const actualClasses = Array.from(actual.classes.keys()).sort();
const expectedClasses = Array.from(expected.classes.keys()).sort(); const expectedClasses = Array.from(expected.classes.keys()).sort();
const classesDiff = diff(actualClasses, expectedClasses); const classesDiff = diff(actualClasses, expectedClasses);
for (const className of classesDiff.extra) for (const className of classesDiff.extra)
errors.push(`Non-existing class found: ${className}`); errors.push(`Non-existing class found: ${className}`);
for (const className of classesDiff.missing) for (const className of classesDiff.missing)
@ -183,10 +184,11 @@ function compareDocumentations(actual, expected) {
const actualMethods = Array.from(actualClass.methods.keys()).sort(); const actualMethods = Array.from(actualClass.methods.keys()).sort();
const expectedMethods = Array.from(expectedClass.methods.keys()).sort(); const expectedMethods = Array.from(expectedClass.methods.keys()).sort();
const methodDiff = diff(actualMethods, expectedMethods); const methodDiff = diff(actualMethods, expectedMethods);
for (const methodName of methodDiff.extra) { for (const methodName of methodDiff.extra) {
const missingMethodsForClass = expectedNonExistingMethods.get(className); const missingMethodsForClass = expectedNonExistingMethods.get(className);
if (!missingMethodsForClass) continue; if (missingMethodsForClass && missingMethodsForClass.has(methodName)) continue;
if (missingMethodsForClass.has(methodName)) continue;
errors.push(`Non-existing method found: ${className}.${methodName}()`); errors.push(`Non-existing method found: ${className}.${methodName}()`);
} }
for (const methodName of methodDiff.missing) for (const methodName of methodDiff.missing)