summaryrefslogtreecommitdiff
path: root/packages/integrations/mdx/test
diff options
context:
space:
mode:
authorGravatar Nate Moore <natemoo-re@users.noreply.github.com> 2022-08-05 10:35:47 -0500
committerGravatar GitHub <noreply@github.com> 2022-08-05 10:35:47 -0500
commite569f0a5c7b56c4cce7afe95335b0aee6ac3d298 (patch)
tree9d008a74846e49fd7e13d3979c4db44162bdd8f4 /packages/integrations/mdx/test
parente7bee22d18c6f1299d99793da9bea00915d144a4 (diff)
downloadastro-e569f0a5c7b56c4cce7afe95335b0aee6ac3d298.tar.gz
astro-e569f0a5c7b56c4cce7afe95335b0aee6ac3d298.tar.zst
astro-e569f0a5c7b56c4cce7afe95335b0aee6ac3d298.zip
Handle edge case in jsx-runtime (#4158)
* fix(#4135): handle edge case in jsx-runtime * test: add mdx test case * chore: fix utils reference * test: fix mdx escape test Co-authored-by: Nate Moore <nate@astro.build>
Diffstat (limited to 'packages/integrations/mdx/test')
-rw-r--r--packages/integrations/mdx/test/fixtures/mdx-escape/src/components/Em.astro7
-rw-r--r--packages/integrations/mdx/test/fixtures/mdx-escape/src/components/P.astro1
-rw-r--r--packages/integrations/mdx/test/fixtures/mdx-escape/src/components/Title.astro1
-rw-r--r--packages/integrations/mdx/test/fixtures/mdx-escape/src/pages/html-tag.mdx5
-rw-r--r--packages/integrations/mdx/test/fixtures/mdx-escape/src/pages/index.mdx13
-rw-r--r--packages/integrations/mdx/test/mdx-escape.test.js32
6 files changed, 59 insertions, 0 deletions
diff --git a/packages/integrations/mdx/test/fixtures/mdx-escape/src/components/Em.astro b/packages/integrations/mdx/test/fixtures/mdx-escape/src/components/Em.astro
new file mode 100644
index 000000000..8166c0586
--- /dev/null
+++ b/packages/integrations/mdx/test/fixtures/mdx-escape/src/components/Em.astro
@@ -0,0 +1,7 @@
+<em><slot/></em>
+
+<style>
+ em {
+ color: red;
+ }
+</style>
diff --git a/packages/integrations/mdx/test/fixtures/mdx-escape/src/components/P.astro b/packages/integrations/mdx/test/fixtures/mdx-escape/src/components/P.astro
new file mode 100644
index 000000000..e29ac6d8f
--- /dev/null
+++ b/packages/integrations/mdx/test/fixtures/mdx-escape/src/components/P.astro
@@ -0,0 +1 @@
+<p><slot /></p>
diff --git a/packages/integrations/mdx/test/fixtures/mdx-escape/src/components/Title.astro b/packages/integrations/mdx/test/fixtures/mdx-escape/src/components/Title.astro
new file mode 100644
index 000000000..333ec04a2
--- /dev/null
+++ b/packages/integrations/mdx/test/fixtures/mdx-escape/src/components/Title.astro
@@ -0,0 +1 @@
+<h1><slot/></h1>
diff --git a/packages/integrations/mdx/test/fixtures/mdx-escape/src/pages/html-tag.mdx b/packages/integrations/mdx/test/fixtures/mdx-escape/src/pages/html-tag.mdx
new file mode 100644
index 000000000..e668c0dc7
--- /dev/null
+++ b/packages/integrations/mdx/test/fixtures/mdx-escape/src/pages/html-tag.mdx
@@ -0,0 +1,5 @@
+import P from '../components/P.astro';
+import Em from '../components/Em.astro';
+
+<P>Render <Em>Me</Em></P>
+<P><Em>Me</Em></P>
diff --git a/packages/integrations/mdx/test/fixtures/mdx-escape/src/pages/index.mdx b/packages/integrations/mdx/test/fixtures/mdx-escape/src/pages/index.mdx
new file mode 100644
index 000000000..d1c6cec9d
--- /dev/null
+++ b/packages/integrations/mdx/test/fixtures/mdx-escape/src/pages/index.mdx
@@ -0,0 +1,13 @@
+import P from '../components/P.astro';
+import Em from '../components/Em.astro';
+import Title from '../components/Title.astro';
+
+export const components = { p: P, em: Em, h1: Title };
+
+# Hello _there_
+
+# _there_
+
+Hello _there_
+
+_there_
diff --git a/packages/integrations/mdx/test/mdx-escape.test.js b/packages/integrations/mdx/test/mdx-escape.test.js
new file mode 100644
index 000000000..d2a4e79ca
--- /dev/null
+++ b/packages/integrations/mdx/test/mdx-escape.test.js
@@ -0,0 +1,32 @@
+import mdx from '@astrojs/mdx';
+
+import { expect } from 'chai';
+import { parseHTML } from 'linkedom';
+import { loadFixture } from '../../../astro/test/test-utils.js';
+
+const FIXTURE_ROOT = new URL('./fixtures/mdx-escape/', import.meta.url);
+
+describe('MDX frontmatter', () => {
+ let fixture;
+ before(async () => {
+ fixture = await loadFixture({
+ root: FIXTURE_ROOT,
+ integrations: [mdx()],
+ });
+ await fixture.build();
+ });
+
+ it('does not have unescaped HTML at top-level', async () => {
+ const html = await fixture.readFile('/index.html');
+ const { document } = parseHTML(html);
+
+ expect(document.body.textContent).to.not.include('<em');
+ });
+
+ it('does not have unescaped HTML inside html tags', async () => {
+ const html = await fixture.readFile('/html-tag/index.html');
+ const { document } = parseHTML(html);
+
+ expect(document.body.textContent).to.not.include('<em');
+ });
+});