mirror of
https://github.com/withastro/astro.git
synced 2025-01-06 22:10:10 -05:00
9b5f3a702d
* refactor: use `vitest` for benchmarks * increase timeout * increase timeout * Restore correct label
132 lines
2.9 KiB
JavaScript
132 lines
2.9 KiB
JavaScript
import fs from 'node:fs/promises';
|
|
import { loremIpsumHtml, loremIpsumMd } from './_util.js';
|
|
|
|
// Map of files to be generated and tested for rendering.
|
|
// Ideally each content should be similar for comparison.
|
|
const renderFiles = {
|
|
'components/ListItem.astro': `\
|
|
---
|
|
const { className, item, attrs } = Astro.props;
|
|
const nested = item !== 0;
|
|
---
|
|
<li class={className}>
|
|
<a
|
|
href={item}
|
|
aria-current={item === 0}
|
|
class:list={[{ large: !nested }, className]}
|
|
{...attrs}
|
|
>
|
|
<span>{item}</span>
|
|
</a>
|
|
</li>
|
|
`,
|
|
'components/Sublist.astro': `\
|
|
---
|
|
import ListItem from '../components/ListItem.astro';
|
|
const { items } = Astro.props;
|
|
const className = "text-red-500";
|
|
const style = { color: "red" };
|
|
---
|
|
<ul style={style}>
|
|
{items.map((item) => (
|
|
<ListItem className={className} item={item} attrs={{}} />
|
|
))}
|
|
</ul>
|
|
`,
|
|
'pages/astro.astro': `\
|
|
---
|
|
const className = "text-red-500";
|
|
const style = { color: "red" };
|
|
const items = Array.from({ length: 10000 }, (_, i) => ({i}));
|
|
---
|
|
<html>
|
|
<head>
|
|
<title>My Site</title>
|
|
</head>
|
|
<body>
|
|
<h1 class={className + ' text-lg'}>List</h1>
|
|
<ul style={style}>
|
|
{items.map((item) => (
|
|
<li class={className}>
|
|
<a
|
|
href={item.i}
|
|
aria-current={item.i === 0}
|
|
class:list={[{ large: item.i === 0 }, className]}
|
|
{...({})}
|
|
>
|
|
<span>{item.i}</span>
|
|
</a>
|
|
</li>
|
|
))}
|
|
</ul>
|
|
${Array.from({ length: 1000 })
|
|
.map(() => `<p>${loremIpsumHtml}</p>`)
|
|
.join('\n')}
|
|
</body>
|
|
</html>`,
|
|
'pages/md.md': `\
|
|
# List
|
|
|
|
${Array.from({ length: 1000 }, (_, i) => i)
|
|
.map((v) => `- ${v}`)
|
|
.join('\n')}
|
|
|
|
${Array.from({ length: 1000 })
|
|
.map(() => loremIpsumMd)
|
|
.join('\n\n')}
|
|
`,
|
|
'pages/mdx.mdx': `\
|
|
export const className = "text-red-500";
|
|
export const style = { color: "red" };
|
|
export const items = Array.from({ length: 1000 }, (_, i) => i);
|
|
|
|
# List
|
|
|
|
<ul style={style}>
|
|
{items.map((item) => (
|
|
<li class={className}>{item}</li>
|
|
))}
|
|
</ul>
|
|
|
|
${Array.from({ length: 1000 })
|
|
.map(() => loremIpsumMd)
|
|
.join('\n\n')}
|
|
`,
|
|
};
|
|
|
|
export const renderPages = [];
|
|
for (const file of Object.keys(renderFiles)) {
|
|
if (file.startsWith('pages/')) {
|
|
renderPages.push(file.replace('pages/', ''));
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param {URL} projectDir
|
|
*/
|
|
export async function run(projectDir) {
|
|
await fs.rm(projectDir, { recursive: true, force: true });
|
|
await fs.mkdir(new URL('./src/pages', projectDir), { recursive: true });
|
|
await fs.mkdir(new URL('./src/components', projectDir), { recursive: true });
|
|
|
|
await Promise.all(
|
|
Object.entries(renderFiles).map(([name, content]) => {
|
|
return fs.writeFile(new URL(`./src/${name}`, projectDir), content, 'utf-8');
|
|
}),
|
|
);
|
|
|
|
await fs.writeFile(
|
|
new URL('./astro.config.js', projectDir),
|
|
`\
|
|
import { defineConfig } from 'astro/config';
|
|
import adapter from '@benchmark/adapter';
|
|
import mdx from '@astrojs/mdx';
|
|
|
|
export default defineConfig({
|
|
integrations: [mdx()],
|
|
output: 'server',
|
|
adapter: adapter(),
|
|
});`,
|
|
'utf-8',
|
|
);
|
|
}
|