angular/adev/shared-docs/pipeline/guides/testing/docs-alert/docs-alert.spec.ts
Joey Perrott 2d8635d29d refactor(docs-infra): migrate @angular/docs from dev-infra into adev directory (#57132)
To increase the ease of development we are moving @angular/docs into the adev directory within this repo. While
we are doing this to improve our development experience in the short term, efforts are also in place
to maintain a division between this @angular/docs (shared) code and adev itself, so that it can be extracted
back out in the future when components is ready to leverage it as well.

PR Close #57132
2024-07-30 15:51:26 +00:00

36 lines
1.3 KiB
TypeScript

import {runfiles} from '@bazel/runfiles';
import {readFile} from 'fs/promises';
import {JSDOM} from 'jsdom';
import {AlertSeverityLevel} from '../../../guides/extensions/docs-alert';
import {parseMarkdown} from '../../../guides/parse';
describe('markdown to html', () => {
let markdownDocument: DocumentFragment;
beforeAll(async () => {
const markdownContent = await readFile(
runfiles.resolvePackageRelative('docs-alert/docs-alert.md'),
{encoding: 'utf-8'},
);
markdownDocument = JSDOM.fragment(await parseMarkdown(markdownContent, {}));
});
for (let level in AlertSeverityLevel) {
it(`should create a docs-alert for ${level}:`, () => {
const noteEl = markdownDocument.querySelector(`.docs-alert-${level.toLowerCase()}`);
// TLDR is written without a semi colon in the markdown, but is rendered
// with a colon, as such we have to adjust our expectation here.
if (level === AlertSeverityLevel.TLDR) {
level = 'TL;DR';
}
expect(noteEl?.textContent?.trim()).toMatch(`^${level}:`);
});
}
it(`should handle multi-line alerts`, () => {
const noteEl = markdownDocument.querySelector(`.docs-alert-note`);
expect(noteEl?.textContent?.trim()).toContain(`This is a multiline note`);
});
});