diff options
| author | 2022-08-30 13:38:35 -0400 | |
|---|---|---|
| committer | 2022-08-30 13:38:35 -0400 | |
| commit | 8f8dff4d339a3a12ee155d81a97132032ef3b622 (patch) | |
| tree | 0581df292a1003288b0dbd7a3f9246f25b5a3cce /packages/integrations/mdx/test/mdx-plugins.test.js | |
| parent | e905784bf12ef45093078404d3d07f01e32638ca (diff) | |
| download | astro-8f8dff4d339a3a12ee155d81a97132032ef3b622.tar.gz astro-8f8dff4d339a3a12ee155d81a97132032ef3b622.tar.zst astro-8f8dff4d339a3a12ee155d81a97132032ef3b622.zip | |
[MDX] Extend Markdown plugin config, with customization options (#4504)
* test: new combined remark / rehype suite
* fix: use with-plugins fixture
* chore: remove old mdx plugin tests
* docs: add JS docs
* docs: update README with thorough example
* chore: changeset
* fix: add "extends" error message
* fix: ignore string-based plugins in md
* feat: add warning log for string plugins
* docs: highlight `extendPlugins`
Co-authored-by: Sarah Rainsberger <sarah@rainsberger.ca>
* nit: highlight "extendPlugins"
* fix: md plugins type check
* chore: "defaults" -> "astroDefaults"
* nit: info log when inheriting markdown plugins
* refactor: one big log on new behavior
* dan: dan nit
Co-authored-by: Sarah Rainsberger <sarah@rainsberger.ca>
Diffstat (limited to 'packages/integrations/mdx/test/mdx-plugins.test.js')
| -rw-r--r-- | packages/integrations/mdx/test/mdx-plugins.test.js | 206 | 
1 files changed, 206 insertions, 0 deletions
| diff --git a/packages/integrations/mdx/test/mdx-plugins.test.js b/packages/integrations/mdx/test/mdx-plugins.test.js new file mode 100644 index 000000000..45f69116d --- /dev/null +++ b/packages/integrations/mdx/test/mdx-plugins.test.js @@ -0,0 +1,206 @@ +import mdx from '@astrojs/mdx'; + +import { expect } from 'chai'; +import { parseHTML } from 'linkedom'; +import { loadFixture } from '../../../astro/test/test-utils.js'; +import remarkToc from 'remark-toc'; + +const FIXTURE_ROOT = new URL('./fixtures/mdx-plugins/', import.meta.url); +const FILE = '/with-plugins/index.html'; + +describe('MDX plugins', () => { +	it('supports custom remark plugins - TOC', async () => { +		const fixture = await buildFixture({ +			integrations: [ +				mdx({ +					remarkPlugins: [remarkToc], +				}), +			], +		}); + +		const html = await fixture.readFile(FILE); +		const { document } = parseHTML(html); + +		expect(selectTocLink(document)).to.not.be.null; +	}); + +	it('supports custom rehype plugins', async () => { +		const fixture = await buildFixture({ +			integrations: [ +				mdx({ +					rehypePlugins: [rehypeExamplePlugin], +				}), +			], +		}); +		const html = await fixture.readFile(FILE); +		const { document } = parseHTML(html); + +		expect(selectRehypeExample(document)).to.not.be.null; +	}); + +	it('extends markdown config by default', async () => { +		const fixture = await buildFixture({ +			markdown: { +				remarkPlugins: [remarkExamplePlugin], +				rehypePlugins: [rehypeExamplePlugin], +			}, +			integrations: [ +				mdx(), +			], +		}); + +		const html = await fixture.readFile(FILE); +		const { document } = parseHTML(html); + +		expect(selectRemarkExample(document)).to.not.be.null; +		expect(selectRehypeExample(document)).to.not.be.null; +	}); + +	it('ignores string-based plugins in markdown config', async () => { +		const fixture = await buildFixture({ +			markdown: { +				remarkPlugins: [['remark-toc']], +			}, +			integrations: [ +				mdx(), +			], +		}); + +		const html = await fixture.readFile(FILE); +		const { document } = parseHTML(html); + +		expect(selectTocLink(document)).to.be.null; +	}); + +	it('respects "extendDefaultPlugins" when extending markdown', async () => { +		const fixture = await buildFixture({ +			markdown: { +				remarkPlugins: [remarkExamplePlugin], +				rehypePlugins: [rehypeExamplePlugin], +				extendDefaultPlugins: true, +			}, +			integrations: [ +				mdx(), +			], +		}); + +		const html = await fixture.readFile(FILE); +		const { document } = parseHTML(html); + +		expect(selectRemarkExample(document)).to.not.be.null; +		expect(selectRehypeExample(document)).to.not.be.null; +		expect(selectGfmLink(document)).to.not.be.null; +	}); + +	it('extends markdown config with extendPlugins: "markdown"', async () => { +		const fixture = await buildFixture({ +			markdown: { +				remarkPlugins: [remarkExamplePlugin], +				rehypePlugins: [rehypeExamplePlugin], +			}, +			integrations: [ +				mdx({ +					extendPlugins: 'markdown', +					remarkPlugins: [remarkToc], +				}), +			], +		}); + +		const html = await fixture.readFile(FILE); +		const { document } = parseHTML(html); + +		expect(selectRemarkExample(document)).to.not.be.null; +		expect(selectRehypeExample(document)).to.not.be.null; +		expect(selectTocLink(document)).to.not.be.null; +	}); + +	it('extends default plugins with extendPlugins: "astroDefaults"', async () => { +		const fixture = await buildFixture({ +			markdown: { +				// should NOT be applied to MDX +				remarkPlugins: [remarkToc], +			}, +			integrations: [ +				mdx({ +					remarkPlugins: [remarkExamplePlugin], +					rehypePlugins: [rehypeExamplePlugin], +					extendPlugins: 'astroDefaults', +				}), +			], +		}); + +		const html = await fixture.readFile(FILE); +		const { document } = parseHTML(html); + +		expect(selectGfmLink(document)).to.not.be.null; +		// remark and rehype plugins still respected +		expect(selectRemarkExample(document)).to.not.be.null; +		expect(selectRehypeExample(document)).to.not.be.null; +		// Does NOT inherit TOC from markdown config +		expect(selectTocLink(document)).to.be.null; +	}); + +	it('does not extend default plugins with extendPlugins: false', async () => { +		const fixture = await buildFixture({ +			markdown: { +				remarkPlugins: [remarkExamplePlugin], +			}, +			integrations: [ +				mdx({ +					remarkPlugins: [], +					extendPlugins: false, +				}), +			], +		}); + +		const html = await fixture.readFile(FILE); +		const { document } = parseHTML(html); + +		expect(selectGfmLink(document)).to.be.null; +		expect(selectRemarkExample(document)).to.be.null; +	}); +}); + +async function buildFixture(config) { +	const fixture = await loadFixture({ +		root: FIXTURE_ROOT, +		...config, +	}); +	await fixture.build(); +	return fixture; +} + +function remarkExamplePlugin() { +	return (tree) => { +		tree.children.push({ +			type: 'html', +			value: '<div data-remark-plugin-works="true"></div>', +		}); +	}; +} + +function rehypeExamplePlugin() { +	return (tree) => { +		tree.children.push({ +			type: 'element', +			tagName: 'div', +			properties: { 'data-rehype-plugin-works': 'true' }, +		}); +	}; +} + +function selectTocLink(document) { +	return document.querySelector('ul a[href="#section-1"]'); +} + +function selectGfmLink(document) { +	return document.querySelector('a[href="https://handle-me-gfm.com"]'); +} + +function selectRemarkExample(document) { +	return document.querySelector('div[data-remark-plugin-works]'); +} + +function selectRehypeExample(document) { +	return document.querySelector('div[data-rehype-plugin-works]'); +} | 
