2024-11-28 23:22:31 +00:00
|
|
|
/**
|
|
|
|
|
* @license
|
|
|
|
|
* Copyright Google LLC All Rights Reserved.
|
|
|
|
|
*
|
|
|
|
|
* Use of this source code is governed by an MIT-style license that can be
|
|
|
|
|
* found in the LICENSE file at https://angular.dev/license
|
|
|
|
|
*/
|
|
|
|
|
|
2025-05-06 20:59:30 +00:00
|
|
|
import {parseMarkdown} from '../../../guides/parse.mjs';
|
2025-06-12 16:47:15 +00:00
|
|
|
import {resolve} from 'node:path';
|
2024-07-23 16:50:12 +00:00
|
|
|
import {readFile} from 'fs/promises';
|
|
|
|
|
import {JSDOM} from 'jsdom';
|
2025-05-06 20:59:30 +00:00
|
|
|
import {initHighlighter} from '../../extensions/docs-code/format/highlight.mjs';
|
2024-07-23 16:50:12 +00:00
|
|
|
|
|
|
|
|
describe('markdown to html', () => {
|
|
|
|
|
let markdownDocument: DocumentFragment;
|
|
|
|
|
|
|
|
|
|
beforeAll(async () => {
|
|
|
|
|
await initHighlighter();
|
2025-06-12 16:47:15 +00:00
|
|
|
const markdownContent = await readFile(resolve('./docs-code.md'), {encoding: 'utf-8'});
|
2024-07-23 16:50:12 +00:00
|
|
|
markdownDocument = JSDOM.fragment(await parseMarkdown(markdownContent, {}));
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('converts docs-code elements into a code block', () => {
|
|
|
|
|
const codeBlock = markdownDocument.querySelectorAll('code')[0];
|
|
|
|
|
expect(codeBlock).toBeTruthy();
|
|
|
|
|
expect(codeBlock?.textContent?.trim()).toBe('this is code');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('removes eslint comments from the code', () => {
|
|
|
|
|
const codeBlock = markdownDocument.querySelectorAll('code')[1];
|
|
|
|
|
expect(codeBlock).toBeTruthy();
|
|
|
|
|
expect(codeBlock?.textContent?.trim()).not.toContain('// eslint');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('extract regions from the code', () => {
|
|
|
|
|
// This unit test is sensible to additional node, like text nodes between the lines.
|
|
|
|
|
// The specific index here makes sure there is no space/linebreak between the code lines
|
|
|
|
|
const codeBlock = markdownDocument.querySelectorAll('code')[2];
|
|
|
|
|
expect(codeBlock).toBeTruthy();
|
|
|
|
|
|
|
|
|
|
expect(codeBlock?.textContent?.trim()).toContain(`const x = 'within the region';`);
|
|
|
|
|
expect(codeBlock?.textContent?.trim()).not.toContain('docregion');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('properly shows the diff of two provided file paths', () => {
|
|
|
|
|
const codeBlock = markdownDocument.querySelectorAll('code')[3];
|
|
|
|
|
expect(codeBlock).toBeTruthy();
|
|
|
|
|
|
|
|
|
|
const codeLines = codeBlock.querySelectorAll('.line');
|
2024-11-28 23:22:31 +00:00
|
|
|
expect(codeLines[8].textContent).toContain('oldFuncName');
|
|
|
|
|
expect(codeLines[8].classList.contains('remove')).toBeTrue();
|
2024-07-23 16:50:12 +00:00
|
|
|
|
2024-11-28 23:22:31 +00:00
|
|
|
expect(codeLines[9].textContent).toContain('newName');
|
|
|
|
|
expect(codeLines[9].classList.contains('add')).toBeTrue();
|
2024-07-23 16:50:12 +00:00
|
|
|
|
2024-11-28 23:22:31 +00:00
|
|
|
expect(codeLines[10].classList.contains('add')).toBeFalse();
|
|
|
|
|
expect(codeLines[10].classList.contains('remove')).toBeFalse();
|
2024-07-23 16:50:12 +00:00
|
|
|
});
|
2024-08-10 12:50:27 +00:00
|
|
|
|
|
|
|
|
it('should load header and html code', () => {
|
|
|
|
|
const codeBlock = markdownDocument.querySelectorAll('code')[4];
|
|
|
|
|
expect(codeBlock).toBeTruthy();
|
|
|
|
|
});
|
2024-07-23 16:50:12 +00:00
|
|
|
});
|