summaryrefslogtreecommitdiff
path: root/packages/integrations/markdoc/test/content-collections.test.js
diff options
context:
space:
mode:
Diffstat (limited to 'packages/integrations/markdoc/test/content-collections.test.js')
-rw-r--r--packages/integrations/markdoc/test/content-collections.test.js120
1 files changed, 120 insertions, 0 deletions
diff --git a/packages/integrations/markdoc/test/content-collections.test.js b/packages/integrations/markdoc/test/content-collections.test.js
new file mode 100644
index 000000000..48e97d45d
--- /dev/null
+++ b/packages/integrations/markdoc/test/content-collections.test.js
@@ -0,0 +1,120 @@
+import assert from 'node:assert/strict';
+import { after, before, describe, it } from 'node:test';
+import { parse as parseDevalue } from 'devalue';
+import { fixLineEndings, loadFixture } from '../../../astro/test/test-utils.js';
+import markdoc from '../dist/index.js';
+
+function formatPost(post) {
+ return {
+ ...post,
+ body: fixLineEndings(post.body),
+ };
+}
+
+const root = new URL('./fixtures/content-collections/', import.meta.url);
+
+const sortById = (a, b) => a.id.localeCompare(b.id);
+
+describe('Markdoc - Content Collections', () => {
+ let baseFixture;
+
+ before(async () => {
+ baseFixture = await loadFixture({
+ root,
+ integrations: [markdoc()],
+ });
+ });
+
+ describe('dev', () => {
+ let devServer;
+
+ before(async () => {
+ devServer = await baseFixture.startDevServer();
+ });
+
+ after(async () => {
+ await devServer.stop();
+ });
+
+ it('loads entry', async () => {
+ const res = await baseFixture.fetch('/entry.json');
+ const post = parseDevalue(await res.text());
+ assert.deepEqual(formatPost(post), post1Entry);
+ });
+
+ it('loads collection', async () => {
+ const res = await baseFixture.fetch('/collection.json');
+ const posts = parseDevalue(await res.text());
+ assert.notEqual(posts, null);
+
+ assert.deepEqual(
+ posts.sort(sortById).map((post) => formatPost(post)),
+ [post1Entry, post2Entry, post3Entry],
+ );
+ });
+ });
+
+ describe('build', () => {
+ before(async () => {
+ await baseFixture.build();
+ });
+
+ it('loads entry', async () => {
+ const res = await baseFixture.readFile('/entry.json');
+ const post = parseDevalue(res);
+ assert.deepEqual(formatPost(post), post1Entry);
+ });
+
+ it('loads collection', async () => {
+ const res = await baseFixture.readFile('/collection.json');
+ const posts = parseDevalue(res);
+ assert.notEqual(posts, null);
+ assert.deepEqual(
+ posts.sort(sortById).map((post) => formatPost(post)),
+ [post1Entry, post2Entry, post3Entry],
+ );
+ });
+ });
+});
+
+const post1Entry = {
+ id: 'post-1.mdoc',
+ slug: 'post-1',
+ collection: 'blog',
+ data: {
+ schemaWorks: true,
+ title: 'Post 1',
+ },
+ body: '## Post 1\n\nThis is the contents of post 1.',
+ deferredRender: true,
+ filePath: 'src/content/blog/post-1.mdoc',
+ digest: '5d5bd98d949e2b9a',
+};
+
+const post2Entry = {
+ id: 'post-2.mdoc',
+ slug: 'post-2',
+ collection: 'blog',
+ data: {
+ schemaWorks: true,
+ title: 'Post 2',
+ },
+ body: '## Post 2\n\nThis is the contents of post 2.',
+ deferredRender: true,
+ filePath: 'src/content/blog/post-2.mdoc',
+ digest: '595af4b93a4af072',
+};
+
+const post3Entry = {
+ id: 'post-3.mdoc',
+ slug: 'post-3',
+ collection: 'blog',
+ data: {
+ schemaWorks: true,
+ title: 'Post 3',
+ },
+ body: '## Post 3\n\nThis is the contents of post 3.',
+ deferredRender: true,
+ filePath: 'src/content/blog/post-3.mdoc',
+ digest: 'ef589606e542247e',
+};