mirror of
https://github.com/withastro/astro.git
synced 2024-12-23 21:53:55 -05:00
bccd88f0eb
* Move the Markdown component to its own package * Update the examples * Updated lockfile * Use is:raw * Add a main field * Update the formatting of the readme * Rename to @astrojs/markdown-component
37 lines
990 B
JavaScript
37 lines
990 B
JavaScript
import { expect } from 'chai';
|
|
import * as cheerio from 'cheerio';
|
|
import { loadFixture } from './test-utils.js';
|
|
import addClasses from './fixtures/astro-markdown-plugins/add-classes.mjs';
|
|
|
|
describe('Astro Markdown plugins', () => {
|
|
let fixture;
|
|
|
|
before(async () => {
|
|
fixture = await loadFixture({
|
|
root: './fixtures/astro-markdown-plugins/',
|
|
markdown: {
|
|
remarkPlugins: [
|
|
'remark-code-titles',
|
|
['rehype-autolink-headings', { behavior: 'prepend' }],
|
|
],
|
|
rehypePlugins: [
|
|
'rehype-slug',
|
|
['rehype-toc', { headings: ['h2', 'h3'] }],
|
|
[addClasses, { 'h1,h2,h3': 'title' }],
|
|
],
|
|
},
|
|
});
|
|
await fixture.build();
|
|
});
|
|
|
|
it('Can render Astro <Markdown> with plugins', async () => {
|
|
const html = await fixture.readFile('/astro/index.html');
|
|
const $ = cheerio.load(html);
|
|
|
|
// test 1: Added a TOC
|
|
expect($('.toc')).to.have.lengthOf(1);
|
|
|
|
// teste 2: Added .title to h1
|
|
expect($('#hello-world').hasClass('title')).to.equal(true);
|
|
});
|
|
});
|