From e7c926212f77a3b42e28d7246506d2269a9c1586 Mon Sep 17 00:00:00 2001 From: bholmesdev Date: Mon, 27 Feb 2023 17:04:50 -0500 Subject: [PATCH] feat: test simple and with-components cases --- packages/astro/fixtures/md/src/env.d.ts | 2 + .../astro/performance/content-benchmark.mjs | 80 ++++++++++++ .../fixtures/md/src/ContentRenderer.astro | 12 ++ .../performance/fixtures/md/src/env.d.ts | 1 + .../fixtures/md/src/pages/index.astro | 6 +- .../fixtures/mdoc/src/ContentRenderer.astro | 26 ++++ .../performance/fixtures/mdoc/src/env.d.ts | 2 +- .../fixtures/mdoc/src/pages/index.astro | 6 +- .../fixtures/mdx/src/ContentRenderer.astro | 16 +++ .../performance/fixtures/mdx/src/env.d.ts | 2 +- .../fixtures/mdx/src/pages/index.astro | 6 +- .../performance/fixtures/utils/Aside.astro | 116 ++++++++++++++++++ .../fixtures/utils/RenderContent.astro | 8 +- .../performance/fixtures/utils/Title.astro | 8 ++ .../astro/performance/fixtures/utils/index.ts | 4 +- packages/astro/performance/package.json | 14 +-- .../scripts/generate-posts.cli.mjs | 16 +++ .../performance/scripts/generate-posts.mjs | 30 +++++ .../{write-posts.mjs => templates/simple.md} | 37 +----- .../scripts/templates/with-components.mdoc | 25 ++++ .../scripts/templates/with-components.mdx | 15 +++ pnpm-lock.yaml | 6 + 22 files changed, 385 insertions(+), 53 deletions(-) create mode 100644 packages/astro/fixtures/md/src/env.d.ts create mode 100644 packages/astro/performance/content-benchmark.mjs create mode 100644 packages/astro/performance/fixtures/md/src/ContentRenderer.astro create mode 100644 packages/astro/performance/fixtures/mdoc/src/ContentRenderer.astro create mode 100644 packages/astro/performance/fixtures/mdx/src/ContentRenderer.astro create mode 100644 packages/astro/performance/fixtures/utils/Aside.astro create mode 100644 packages/astro/performance/fixtures/utils/Title.astro create mode 100644 packages/astro/performance/scripts/generate-posts.cli.mjs create mode 100644 packages/astro/performance/scripts/generate-posts.mjs rename packages/astro/performance/scripts/{write-posts.mjs => templates/simple.md} (92%) create mode 100644 packages/astro/performance/scripts/templates/with-components.mdoc create mode 100644 packages/astro/performance/scripts/templates/with-components.mdx diff --git a/packages/astro/fixtures/md/src/env.d.ts b/packages/astro/fixtures/md/src/env.d.ts new file mode 100644 index 000000000..2da76ba24 --- /dev/null +++ b/packages/astro/fixtures/md/src/env.d.ts @@ -0,0 +1,2 @@ +/// +/// \ No newline at end of file diff --git a/packages/astro/performance/content-benchmark.mjs b/packages/astro/performance/content-benchmark.mjs new file mode 100644 index 000000000..2b6d73b8a --- /dev/null +++ b/packages/astro/performance/content-benchmark.mjs @@ -0,0 +1,80 @@ +import { fileURLToPath } from 'url'; +import { loadFixture } from '../test/test-utils.js'; +import { generatePosts } from './scripts/generate-posts.mjs'; +import yargs from 'yargs-parser'; +import { cyan, bold, dim } from 'kleur/colors'; + +// Skip nonessential remark / rehype plugins for a fair comparison. +// This includes heading ID generation, syntax highlighting, GFM, and Smartypants. +process.env.ASTRO_CI_PERFORMANCE_RUN = true; + +const extByFixture = { + md: '.md', + mdx: '.mdx', + mdoc: '.mdoc', +}; + +const NUM_POSTS = 1000; + +async function benchmark({ fixtures, templates }) { + for (const fixture of fixtures) { + const root = new URL(`./fixtures/${fixture}/`, import.meta.url); + await generatePosts({ + postsDir: fileURLToPath(new URL('./src/content/generated/', root)), + numPosts: NUM_POSTS, + ext: extByFixture[fixture], + template: templates[fixture], + }); + console.log(`[${fixture}] Generated posts`); + + const { build } = await loadFixture({ + root, + }); + const now = performance.now(); + console.log(`[${fixture}] Building...`); + await build(); + console.log(cyan(`[${fixture}] Built in ${bold(getTimeStat(now, performance.now()))}.`)); + } +} + +// Test the build performance for content collections across multiple file types (md, mdx, mdoc) +(async function benchmarkAll() { + try { + const flags = yargs(process.argv.slice(2)); + const test = Array.isArray(flags.test) + ? flags.test + : typeof flags.test === 'string' + ? [flags.test] + : ['simple', 'with-components']; + + if (test.includes('simple')) { + console.log(`\n${bold('Simple')} ${dim(`${NUM_POSTS} posts (md, mdx, mdoc)`)}`); + await benchmark({ + fixtures: ['md', 'mdx', 'mdoc'], + templates: { + md: 'simple.md', + mdx: 'simple.md', + mdoc: 'simple.md', + }, + }); + } + + if (test.includes('with-components')) { + console.log(`\n${bold('With components')} ${dim(`${NUM_POSTS} posts (mdx, mdoc)`)}`); + await benchmark({ + fixtures: ['mdx', 'mdoc'], + templates: { + mdx: 'with-components.mdx', + mdoc: 'with-components.mdoc', + }, + }); + } + } finally { + process.env.ASTRO_CI_PERFORMANCE_RUN = false; + } +})(); + +function getTimeStat(timeStart, timeEnd) { + const buildTime = timeEnd - timeStart; + return buildTime < 750 ? `${Math.round(buildTime)}ms` : `${(buildTime / 1000).toFixed(2)}s`; +} diff --git a/packages/astro/performance/fixtures/md/src/ContentRenderer.astro b/packages/astro/performance/fixtures/md/src/ContentRenderer.astro new file mode 100644 index 000000000..307541fcf --- /dev/null +++ b/packages/astro/performance/fixtures/md/src/ContentRenderer.astro @@ -0,0 +1,12 @@ +--- +import type { CollectionEntry } from 'astro:content'; + +type Props = { + entry: CollectionEntry<'generated'>; +} + +const { entry } = Astro.props as Props; +const { Content } = await entry.render(); +--- + + diff --git a/packages/astro/performance/fixtures/md/src/env.d.ts b/packages/astro/performance/fixtures/md/src/env.d.ts index c13bd73c7..4b38f4e5c 100644 --- a/packages/astro/performance/fixtures/md/src/env.d.ts +++ b/packages/astro/performance/fixtures/md/src/env.d.ts @@ -1,2 +1,3 @@ +/// /// /// \ No newline at end of file diff --git a/packages/astro/performance/fixtures/md/src/pages/index.astro b/packages/astro/performance/fixtures/md/src/pages/index.astro index e76157139..efb43284e 100644 --- a/packages/astro/performance/fixtures/md/src/pages/index.astro +++ b/packages/astro/performance/fixtures/md/src/pages/index.astro @@ -1,8 +1,12 @@ --- import { getCollection } from 'astro:content'; import { RenderContent } from '@performance/utils'; +import ContentRenderer from '../ContentRenderer.astro'; const posts = await getCollection('generated'); --- - + diff --git a/packages/astro/performance/fixtures/mdoc/src/ContentRenderer.astro b/packages/astro/performance/fixtures/mdoc/src/ContentRenderer.astro new file mode 100644 index 000000000..a0bbbb3d6 --- /dev/null +++ b/packages/astro/performance/fixtures/mdoc/src/ContentRenderer.astro @@ -0,0 +1,26 @@ +--- +import { Title, Aside } from '@performance/utils'; +import type { CollectionEntry } from 'astro:content'; + +type Props = { + entry: CollectionEntry<'generated'>; +} + +const { entry } = Astro.props as Props; +const { Content } = await entry.render(); +--- + +{entry.data.type === 'with-components' + ? + : +} diff --git a/packages/astro/performance/fixtures/mdoc/src/env.d.ts b/packages/astro/performance/fixtures/mdoc/src/env.d.ts index c13bd73c7..acef35f17 100644 --- a/packages/astro/performance/fixtures/mdoc/src/env.d.ts +++ b/packages/astro/performance/fixtures/mdoc/src/env.d.ts @@ -1,2 +1,2 @@ /// -/// \ No newline at end of file +/// diff --git a/packages/astro/performance/fixtures/mdoc/src/pages/index.astro b/packages/astro/performance/fixtures/mdoc/src/pages/index.astro index e76157139..efb43284e 100644 --- a/packages/astro/performance/fixtures/mdoc/src/pages/index.astro +++ b/packages/astro/performance/fixtures/mdoc/src/pages/index.astro @@ -1,8 +1,12 @@ --- import { getCollection } from 'astro:content'; import { RenderContent } from '@performance/utils'; +import ContentRenderer from '../ContentRenderer.astro'; const posts = await getCollection('generated'); --- - + diff --git a/packages/astro/performance/fixtures/mdx/src/ContentRenderer.astro b/packages/astro/performance/fixtures/mdx/src/ContentRenderer.astro new file mode 100644 index 000000000..1bf61b199 --- /dev/null +++ b/packages/astro/performance/fixtures/mdx/src/ContentRenderer.astro @@ -0,0 +1,16 @@ +--- +import { Title } from '@performance/utils'; +import type { CollectionEntry } from 'astro:content'; + +type Props = { + entry: CollectionEntry<'generated'>; +} + +const { entry } = Astro.props as Props; +const { Content } = await entry.render(); +--- + +{entry.data.type === 'with-components' + ? + : +} diff --git a/packages/astro/performance/fixtures/mdx/src/env.d.ts b/packages/astro/performance/fixtures/mdx/src/env.d.ts index c13bd73c7..acef35f17 100644 --- a/packages/astro/performance/fixtures/mdx/src/env.d.ts +++ b/packages/astro/performance/fixtures/mdx/src/env.d.ts @@ -1,2 +1,2 @@ /// -/// \ No newline at end of file +/// diff --git a/packages/astro/performance/fixtures/mdx/src/pages/index.astro b/packages/astro/performance/fixtures/mdx/src/pages/index.astro index e76157139..efb43284e 100644 --- a/packages/astro/performance/fixtures/mdx/src/pages/index.astro +++ b/packages/astro/performance/fixtures/mdx/src/pages/index.astro @@ -1,8 +1,12 @@ --- import { getCollection } from 'astro:content'; import { RenderContent } from '@performance/utils'; +import ContentRenderer from '../ContentRenderer.astro'; const posts = await getCollection('generated'); --- - + diff --git a/packages/astro/performance/fixtures/utils/Aside.astro b/packages/astro/performance/fixtures/utils/Aside.astro new file mode 100644 index 000000000..5d92a0993 --- /dev/null +++ b/packages/astro/performance/fixtures/utils/Aside.astro @@ -0,0 +1,116 @@ +--- +// Inspired by the `Aside` component from docs.astro.build +// https://github.com/withastro/docs/blob/main/src/components/Aside.astro + +export interface Props { + type?: 'note' | 'tip' | 'caution' | 'danger'; + title?: string; +} + +const labelByType = { + note: 'Note', + tip: 'Tip', + caution: 'Caution', + danger: 'Danger', +}; +const { type = 'note' } = Astro.props as Props; +const title = Astro.props.title ?? labelByType[type] ?? ''; + +// SVG icon paths based on GitHub Octicons +const icons: Record, { viewBox: string; d: string }> = { + note: { + viewBox: '0 0 18 18', + d: 'M0 3.75C0 2.784.784 2 1.75 2h12.5c.966 0 1.75.784 1.75 1.75v8.5A1.75 1.75 0 0114.25 14H1.75A1.75 1.75 0 010 12.25v-8.5zm1.75-.25a.25.25 0 00-.25.25v8.5c0 .138.112.25.25.25h12.5a.25.25 0 00.25-.25v-8.5a.25.25 0 00-.25-.25H1.75zM3.5 6.25a.75.75 0 01.75-.75h7a.75.75 0 010 1.5h-7a.75.75 0 01-.75-.75zm.75 2.25a.75.75 0 000 1.5h4a.75.75 0 000-1.5h-4z', + }, + tip: { + viewBox: '0 0 18 18', + d: 'M14 0a8.8 8.8 0 0 0-6 2.6l-.5.4-.9 1H3.3a1.8 1.8 0 0 0-1.5.8L.1 7.6a.8.8 0 0 0 .4 1.1l3.1 1 .2.1 2.4 2.4.1.2 1 3a.8.8 0 0 0 1 .5l2.9-1.7a1.8 1.8 0 0 0 .8-1.5V9.5l1-1 .4-.4A8.8 8.8 0 0 0 16 2v-.1A1.8 1.8 0 0 0 14.2 0h-.1zm-3.5 10.6-.3.2L8 12.3l.5 1.8 2-1.2a.3.3 0 0 0 .1-.2v-2zM3.7 8.1l1.5-2.3.2-.3h-2a.3.3 0 0 0-.3.1l-1.2 2 1.8.5zm5.2-4.5a7.3 7.3 0 0 1 5.2-2.1h.1a.3.3 0 0 1 .3.3v.1a7.3 7.3 0 0 1-2.1 5.2l-.5.4a15.2 15.2 0 0 1-2.5 2L7.1 11 5 9l1.5-2.3a15.3 15.3 0 0 1 2-2.5l.4-.5zM12 5a1 1 0 1 1-2 0 1 1 0 0 1 2 0zm-8.4 9.6a1.5 1.5 0 1 0-2.2-2.2 7 7 0 0 0-1.1 3 .2.2 0 0 0 .3.3c.6 0 2.2-.4 3-1.1z', + }, + caution: { + viewBox: '-1 1 18 18', + d: 'M8.9 1.5C8.7 1.2 8.4 1 8 1s-.7.2-.9.5l-7 12a1 1 0 0 0 0 1c.2.3.6.5 1 .5H15c.4 0 .7-.2.9-.5a1 1 0 0 0 0-1l-7-12zM9 13H7v-2h2v2zm0-3H7V6h2v4z', + }, + danger: { + viewBox: '0 1 14 17', + d: 'M5 .3c.9 2.2.5 3.4-.5 4.3C3.5 5.6 2 6.5 1 8c-1.5 2-1.7 6.5 3.5 7.7-2.2-1.2-2.6-4.5-.3-6.6-.6 2 .6 3.3 2 2.8 1.4-.4 2.3.6 2.2 1.7 0 .8-.3 1.4-1 1.8A5.6 5.6 0 0 0 12 10c0-2.9-2.5-3.3-1.3-5.7-1.5.2-2 1.2-1.8 2.8 0 1-1 1.8-2 1.3-.6-.4-.6-1.2 0-1.8C8.2 5.3 8.7 2.5 5 .3z', + }, +}; +const { viewBox, d } = icons[type]; +--- + + + + diff --git a/packages/astro/performance/fixtures/utils/RenderContent.astro b/packages/astro/performance/fixtures/utils/RenderContent.astro index ae0d45f4b..e9cfcf9a6 100644 --- a/packages/astro/performance/fixtures/utils/RenderContent.astro +++ b/packages/astro/performance/fixtures/utils/RenderContent.astro @@ -1,9 +1,10 @@ --- type Props = { posts: any[]; + renderer: any; } -const { posts } = Astro.props; +const { posts, renderer: ContentRenderer } = Astro.props; --- @@ -16,13 +17,12 @@ const { posts } = Astro.props; { - posts.map(async (entry) => { - const { Content } = await entry.render(); + posts.map((entry) => { return (

{entry.data.title}

{entry.data.description}

- +
); }) diff --git a/packages/astro/performance/fixtures/utils/Title.astro b/packages/astro/performance/fixtures/utils/Title.astro new file mode 100644 index 000000000..f956ed0b1 --- /dev/null +++ b/packages/astro/performance/fixtures/utils/Title.astro @@ -0,0 +1,8 @@ +

+ + diff --git a/packages/astro/performance/fixtures/utils/index.ts b/packages/astro/performance/fixtures/utils/index.ts index d906362a3..5749de490 100644 --- a/packages/astro/performance/fixtures/utils/index.ts +++ b/packages/astro/performance/fixtures/utils/index.ts @@ -1,2 +1,4 @@ -// @ts-ignore +// @ts-nocheck export { default as RenderContent } from './RenderContent.astro'; +export { default as Aside } from './Aside.astro'; +export { default as Title } from './Title.astro'; diff --git a/packages/astro/performance/package.json b/packages/astro/performance/package.json index c58ed0bcd..9069c0f86 100644 --- a/packages/astro/performance/package.json +++ b/packages/astro/performance/package.json @@ -4,20 +4,16 @@ "description": "", "main": "index.js", "scripts": { - "write": "run-p write:*", - "write:md": "node scripts/write-posts.mjs fixtures/md/src/content/generated 1000 md", - "write:mdx": "node scripts/write-posts.mjs fixtures/mdx/src/content/generated 1000 mdx", - "write:mdoc": "node scripts/write-posts.mjs fixtures/mdoc/src/content/generated 1000 mdoc", - "build": "cross-env ASTRO_CI_PERFORMANCE_RUN=true run-s build:*", - "build:md": "cd fixtures/md && run-s build", - "build:mdx": "cd fixtures/mdx && run-s build", - "build:mdoc": "cd fixtures/mdoc && run-s build" + "benchmark": "node ./content-benchmark.mjs" }, "keywords": [], "author": "", "license": "ISC", "devDependencies": { + "@types/yargs-parser": "^21.0.0", "cross-env": "^7.0.3", - "npm-run-all": "^4.1.5" + "kleur": "^4.1.5", + "npm-run-all": "^4.1.5", + "yargs-parser": "^21.0.1" } } diff --git a/packages/astro/performance/scripts/generate-posts.cli.mjs b/packages/astro/performance/scripts/generate-posts.cli.mjs new file mode 100644 index 000000000..298d32521 --- /dev/null +++ b/packages/astro/performance/scripts/generate-posts.cli.mjs @@ -0,0 +1,16 @@ +import { generatePosts } from './generate-posts.mjs'; + +(async () => { + const postsDir = process.argv[2]; + const numPosts = + typeof process.argv[3] === 'string' && process.argv[3].length > 0 + ? Number(process.argv[3]) + : undefined; + + const ext = process.argv[4]; + const template = process.argv[5]; + + await generatePosts({ postsDir, numPosts, ext, template }); + + console.log(`${numPosts} ${ext} posts written to ${JSON.stringify(postsDir)} 🚀`); +})(); diff --git a/packages/astro/performance/scripts/generate-posts.mjs b/packages/astro/performance/scripts/generate-posts.mjs new file mode 100644 index 000000000..421fbe5c2 --- /dev/null +++ b/packages/astro/performance/scripts/generate-posts.mjs @@ -0,0 +1,30 @@ +import fs from 'fs'; +import path from 'path'; + +const NUM_POSTS = 10; +const POSTS_DIR = './src/content/posts.generated'; +const EXT = '.md'; +const TEMPLATE = 'simple.md'; + +export async function generatePosts({ + postsDir = POSTS_DIR, + numPosts = NUM_POSTS, + ext = EXT, + template = TEMPLATE, +}) { + if (fs.existsSync(postsDir)) { + const files = await fs.promises.readdir(postsDir); + await Promise.all(files.map((file) => fs.promises.unlink(path.join(postsDir, file)))); + } else { + await fs.promises.mkdir(postsDir, { recursive: true }); + } + + await Promise.all( + Array.from(Array(numPosts).keys()).map((idx) => { + return fs.promises.writeFile( + `${postsDir}/post-${idx}${ext.startsWith('.') ? ext : `.${ext}`}`, + fs.readFileSync(new URL(`./templates/${template}`, import.meta.url), 'utf8') + ); + }) + ); +} diff --git a/packages/astro/performance/scripts/write-posts.mjs b/packages/astro/performance/scripts/templates/simple.md similarity index 92% rename from packages/astro/performance/scripts/write-posts.mjs rename to packages/astro/performance/scripts/templates/simple.md index 5d9023284..9ddbda079 100644 --- a/packages/astro/performance/scripts/write-posts.mjs +++ b/packages/astro/performance/scripts/templates/simple.md @@ -1,38 +1,8 @@ -import fs from 'fs'; -import path from 'path'; - -const NUM_POSTS = 10; -const POSTS_DIR = './src/content/posts.generated'; -const EXT = '.md'; - -(async function writePosts() { - const postsDir = process.argv[2] ?? POSTS_DIR; - const numPosts = Number(process.argv[3]) ?? NUM_POSTS; - const ext = process.argv[4] ?? EXT; - if (fs.existsSync(postsDir)) { - const files = await fs.promises.readdir(postsDir); - await Promise.all(files.map((file) => fs.promises.unlink(path.join(postsDir, file)))); - } else { - await fs.promises.mkdir(postsDir, { recursive: true }); - } - - await Promise.all( - Array.from(Array(numPosts).keys()).map((idx) => { - return fs.promises.writeFile( - `${postsDir}/post-${idx}${ext.startsWith('.') ? ext : `.${ext}`}`, - toMdContents(idx) - ); - }) - ); - - console.log(`${numPosts} ${ext} posts written to ${JSON.stringify(postsDir)} 🚀`); -})(); - -const toMdContents = (idx) => `--- -title: Example ${idx} +--- +title: Simple --- -# Post ${idx} +# Simple post Lorem ipsum dolor sit amet, consectetur adipiscing elit. Curabitur interdum quam vitae est dapibus auctor. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Vivamus id purus vel ante interdum eleifend non sed magna. Nullam aliquet metus eget nunc pretium, ac malesuada elit ultricies. Quisque fermentum tellus sed risus tristique tincidunt. Interdum et malesuada fames ac ante ipsum primis in faucibus. Maecenas eleifend odio sed tortor rhoncus venenatis. Maecenas dignissim convallis sem et sagittis. Aliquam facilisis auctor consectetur. Morbi vulputate fermentum lobortis. Aenean luctus risus erat, sit amet imperdiet lectus tempor et. @@ -71,4 +41,3 @@ Vestibulum sit amet lorem arcu. Integer sed nisl ut turpis dapibus mollis sit am Curabitur quis mi ac massa hendrerit ornare id eget velit. Nulla dui lacus, hendrerit et fringilla sed, eleifend ut erat. Nunc ut fringilla ex, sit amet fringilla libero. Maecenas non ullamcorper orci. Duis posuere erat et urna rhoncus iaculis. Proin pellentesque porttitor nulla, non blandit ante semper vitae. Phasellus ut augue venenatis, tempus purus eu, efficitur massa. Etiam vel egestas tellus, ac pharetra lectus. Aliquam non commodo turpis. Quisque pharetra nunc et mauris bibendum, id vestibulum tellus fringilla. Nullam enim massa, porta id nisi at, accumsan sollicitudin elit. Morbi auctor lectus vitae orci cursus, et hendrerit odio accumsan. Pellentesque quis libero auctor, tempor dolor tempor, finibus arcu. Aliquam non cursus ex. Aliquam quis lacus ut purus pellentesque ultrices in a augue. Morbi nunc diam, egestas sed condimentum a, interdum suscipit ligula. Morbi interdum dignissim imperdiet. Interdum et malesuada fames ac ante ipsum primis in faucibus. Mauris egestas, nulla nec feugiat porttitor, ex magna sodales nisl, ac volutpat tortor mauris vitae nibh. Cras cursus dignissim pretium. Nunc faucibus dui at lectus pellentesque vehicula. Maecenas tincidunt, libero quis hendrerit aliquet, tortor leo iaculis enim, sit amet ullamcorper tellus risus a orci. Donec dignissim metus in nulla eleifend molestie. Nunc at turpis et sem laoreet rutrum. Nulla facilisi. Sed luctus nisi sed egestas cursus. -`; diff --git a/packages/astro/performance/scripts/templates/with-components.mdoc b/packages/astro/performance/scripts/templates/with-components.mdoc new file mode 100644 index 000000000..f7a969545 --- /dev/null +++ b/packages/astro/performance/scripts/templates/with-components.mdoc @@ -0,0 +1,25 @@ +--- +type: with-components +title: Post with components +--- + +# This should be rendered with a title component + +{% aside type="tip" %} +This is a tip component +{% /aside %} +{% aside type="tip" %} +This is a tip component +{% /aside %} +{% aside type="tip" %} +This is a tip component +{% /aside %} +{% aside type="tip" %} +This is a tip component +{% /aside %} +{% aside type="tip" %} +This is a tip component +{% /aside %} +{% aside type="tip" %} +This is a tip component +{% /aside %} diff --git a/packages/astro/performance/scripts/templates/with-components.mdx b/packages/astro/performance/scripts/templates/with-components.mdx new file mode 100644 index 000000000..2b40e85a4 --- /dev/null +++ b/packages/astro/performance/scripts/templates/with-components.mdx @@ -0,0 +1,15 @@ +--- +type: with-components +title: Post with components +--- + +import { Aside } from '@performance/utils'; + +# This should be rendered with a title component + + + + + + + diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index abf9bc1f0..027c014b0 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -1130,11 +1130,17 @@ importers: packages/astro/performance: specifiers: + '@types/yargs-parser': ^21.0.0 cross-env: ^7.0.3 + kleur: ^4.1.5 npm-run-all: ^4.1.5 + yargs-parser: ^21.0.1 devDependencies: + '@types/yargs-parser': 21.0.0 cross-env: 7.0.3 + kleur: 4.1.5 npm-run-all: 4.1.5 + yargs-parser: 21.1.1 packages/astro/performance/fixtures/md: specifiers: