[ADF-3809] Added image URL checks and added missing image files (#4054)

* [ADF-3809] Updated file checker with broken image URL hints

* [ADF-3809] Updated rel note images based on file checker
This commit is contained in:
Andy Stark
2018-12-05 16:00:42 +00:00
committed by Eugenio Romano
parent 6f526c3862
commit 21460ce64c
14 changed files with 76 additions and 23 deletions

View File

@@ -3,12 +3,19 @@ import * as fs from "fs";
import { select, selectAll } from "unist-util-select";
import * as lev from "fast-levenshtein";
import * as ngHelpers from "../ngHelpers";
//const angFilenameRegex = /([a-zA-Z0-9\-]+)\.((component)|(directive)|(interface)|(model)|(pipe)|(service)|(widget))/;
const imageFolderPath = path.resolve('docs', 'docassets', 'images');
// Using this value for the edit distance between Markdown image URLs
// and filenames is enough to trap errors like missing out the 'images'
// folder in the path. Keeping it low avoids crazy suggestions.
const maxImagePathLevDistance = 7;
export function processDocs(mdCache, aggData, errorMessages) {
var pathnames = Object.keys(mdCache);
@@ -16,6 +23,7 @@ export function processDocs(mdCache, aggData, errorMessages) {
let classlessDocs = [];
let linkRefs = {};
let imageRefs = {};
let brokenImageRefs = {};
let filters = makeFilepathFilters(aggData.config["fileCheckerFilter"]);
@@ -35,12 +43,7 @@ export function processDocs(mdCache, aggData, errorMessages) {
linkElems.forEach(linkElem => {
let normUrl = normaliseLinkPath(pathname, linkElem.url);
if (linkRefs[normUrl]) {
linkRefs[normUrl].push(pathname);
} else {
linkRefs[normUrl] = [ pathname ];
}
multiSetAdd(linkRefs, normUrl, pathname);
});
}
@@ -48,11 +51,10 @@ export function processDocs(mdCache, aggData, errorMessages) {
imageElems.forEach(imageElem => {
let normUrl = normaliseLinkPath(pathname, imageElem.url);
multiSetAdd(imageRefs, normUrl, pathname);
if (imageRefs[normUrl]) {
imageRefs[normUrl].push(pathname);
} else {
imageRefs[normUrl] = [ pathname ];
if (!fs.existsSync(normUrl)) {
brokenImageRefs[normUrl] = pathname;
}
});
});
@@ -71,6 +73,8 @@ export function processDocs(mdCache, aggData, errorMessages) {
console.groupEnd();
});
console.log();
let imagePaths = getImagePaths(imageFolderPath);
imagePaths.forEach(imagePath => {
@@ -79,6 +83,25 @@ export function processDocs(mdCache, aggData, errorMessages) {
console.log(`Warning: no links to image file "${relImagePath}"`);
}
});
console.log();
let brokenImUrls = Object.keys(brokenImageRefs);
brokenImUrls.forEach(url => {
let relUrl = url.substring(url.indexOf('docs'));
let relDocPath = brokenImageRefs[url].substring(brokenImageRefs[url].indexOf('docs'));
console.group(`Broken image link "${relUrl}" found in "${relDocPath}`);
imagePaths.forEach(imPath => {
if (lev.get(imPath, url) <= maxImagePathLevDistance) {
let relImPath = imPath.substring(imPath.indexOf('docs'));
console.log(`Should it be "${relImPath}"?`)
}
});
console.groupEnd();
});
}
@@ -106,4 +129,13 @@ function filterFilepath(filters: RegExp[], filepath: string): boolean {
}
}
return false;
}
function multiSetAdd(container: {}, key: string, value: string) {
if (container[key]) {
container[key].push(value);
} else {
container[key] = [ value ];
}
}