build(docs-infra): fix `autoLinkCode` to ignore docs without a path (#36316)

Previously, the auto linker generated links without an `href` when the
API was private. This commit fixes this by making sure that the `path`
of the document is not empty.

Closes #36260

PR Close #36316
This commit is contained in:
Sonu Kapoor 2020-03-30 07:10:15 -04:00 committed by Matias Niemelä
parent 4da901f8c0
commit 4fb034aeec
2 changed files with 37 additions and 6 deletions

View File

@ -28,7 +28,7 @@ module.exports = function autoLinkCode(getDocFromAlias) {
return autoLinkCodeImpl; return autoLinkCodeImpl;
function autoLinkCodeImpl() { function autoLinkCodeImpl() {
return (ast) => { return (ast, file) => {
visit(ast, 'element', (node, ancestors) => { visit(ast, 'element', (node, ancestors) => {
// Only interested in code elements that: // Only interested in code elements that:
// * do not have `no-auto-link` class // * do not have `no-auto-link` class
@ -46,7 +46,7 @@ module.exports = function autoLinkCode(getDocFromAlias) {
// Can we convert the whole text node into a doc link? // Can we convert the whole text node into a doc link?
const docs = getDocFromAlias(node.value); const docs = getDocFromAlias(node.value);
if (foundValidDoc(docs)) { if (foundValidDoc(docs, node.value, file)) {
parent.children.splice(index, 1, createLinkNode(docs[0], node.value)); parent.children.splice(index, 1, createLinkNode(docs[0], node.value));
} else { } else {
// Parse the text for words that we can convert to links // Parse the text for words that we can convert to links
@ -58,7 +58,7 @@ module.exports = function autoLinkCode(getDocFromAlias) {
// remove docs that fail the custom filter tests // remove docs that fail the custom filter tests
const filteredDocs = autoLinkCodeImpl.customFilters.reduce( const filteredDocs = autoLinkCodeImpl.customFilters.reduce(
(docs, filter) => filter(docs, words, index), getDocFromAlias(word)); (docs, filter) => filter(docs, words, index), getDocFromAlias(word));
return foundValidDoc(filteredDocs) ? return foundValidDoc(filteredDocs, word, file) ?
// Create a link wrapping the text node. // Create a link wrapping the text node.
createLinkNode(filteredDocs[0], word) : createLinkNode(filteredDocs[0], word) :
// this is just text so push a new text node // this is just text so push a new text node
@ -75,9 +75,31 @@ module.exports = function autoLinkCode(getDocFromAlias) {
}; };
} }
function foundValidDoc(docs) { /**
return docs.length === 1 && !docs[0].internal && * Validates the docs to be used to generate the links. The validation ensures
autoLinkCodeImpl.docTypes.indexOf(docs[0].docType) !== -1; * that the docs are not `internal` and that the `docType` is supported. The `path`
* can be empty when the `API` is not public.
*
* @param {Array<Object>} docs An array of objects containing the doc details
*
* @param {string} keyword The keyword the doc applies to
*/
function foundValidDoc(docs, keyword, file) {
if (docs.length !== 1) {
return false;
}
var doc = docs[0];
if (doc.path === '') {
var message = `
autoLinkCode: Doc path is empty for "${doc.id}" - link will not be generated for "${keyword}".
Please make sure if the doc should be public. If not, it should probably not be referenced in the docs.`;
file.message(message);
return false;
}
return !doc.internal && autoLinkCodeImpl.docTypes.includes(doc.docType);
} }
function createLinkNode(doc, text) { function createLinkNode(doc, text) {

View File

@ -126,6 +126,15 @@ describe('autoLinkCode post-processor', () => {
expect(doc.renderedContent).toEqual('<code>MyClass</code>'); expect(doc.renderedContent).toEqual('<code>MyClass</code>');
}); });
it('should ignore code items that match an API doc but have no path set',
() => {
aliasMap.addDoc(
{docType: 'class', id: 'MyClass', aliases: ['MyClass'], path: ''});
const doc = {docType: 'test-doc', renderedContent: '<code>MyClass</code>'};
processor.$process([doc]);
expect(doc.renderedContent).toEqual('<code>MyClass</code>');
});
it('should insert anchors for individual text nodes within a code block', () => { it('should insert anchors for individual text nodes within a code block', () => {
aliasMap.addDoc({docType: 'class', id: 'MyClass', aliases: ['MyClass'], path: 'a/b/myclass'}); aliasMap.addDoc({docType: 'class', id: 'MyClass', aliases: ['MyClass'], path: 'a/b/myclass'});
const doc = { const doc = {