Fixes index page with build.format=file (#5123)
* Fixes index page with build.format=file * Adding a changeset
This commit is contained in:
parent
9d4716f5ad
commit
9745009ae0
8 changed files with 93 additions and 30 deletions
5
.changeset/many-lions-relate.md
Normal file
5
.changeset/many-lions-relate.md
Normal file
|
@ -0,0 +1,5 @@
|
|||
---
|
||||
'astro': patch
|
||||
---
|
||||
|
||||
Fixes index page with build.format=file
|
|
@ -30,7 +30,8 @@ export function getOutFolder(
|
|||
return new URL('.' + appendForwardSlash(pathname), outRoot);
|
||||
}
|
||||
case 'file': {
|
||||
return new URL('.' + appendForwardSlash(npath.dirname(pathname)), outRoot);
|
||||
const d = pathname === '' ? pathname : npath.dirname(pathname);
|
||||
return new URL('.' + appendForwardSlash(d), outRoot);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -34,35 +34,6 @@ import { eachPageData, getPageDataByComponent, sortedCSS } from './internal.js';
|
|||
import type { PageBuildData, SingleFileBuiltModule, StaticBuildOptions } from './types';
|
||||
import { getTimeStat } from './util.js';
|
||||
|
||||
// Render is usually compute, which Node.js can't parallelize well.
|
||||
// In real world testing, dropping from 10->1 showed a notiable perf
|
||||
// improvement. In the future, we can revisit a smarter parallel
|
||||
// system, possibly one that parallelizes if async IO is detected.
|
||||
const MAX_CONCURRENT_RENDERS = 1;
|
||||
|
||||
// Throttle the rendering a paths to prevents creating too many Promises on the microtask queue.
|
||||
function* throttle(max: number, inPaths: string[]) {
|
||||
let tmp = [];
|
||||
let i = 0;
|
||||
for (let path of inPaths) {
|
||||
tmp.push(path);
|
||||
if (i === max) {
|
||||
yield tmp;
|
||||
// Empties the array, to avoid allocating a new one.
|
||||
tmp.length = 0;
|
||||
i = 0;
|
||||
} else {
|
||||
i++;
|
||||
}
|
||||
}
|
||||
|
||||
// If tmp has items in it, that means there were less than {max} paths remaining
|
||||
// at the end, so we need to yield these too.
|
||||
if (tmp.length) {
|
||||
yield tmp;
|
||||
}
|
||||
}
|
||||
|
||||
function shouldSkipDraft(pageModule: ComponentInstance, settings: AstroSettings): boolean {
|
||||
return (
|
||||
// Drafts are disabled
|
||||
|
|
24
packages/astro/test/dynamic-route-build-file.test.js
Normal file
24
packages/astro/test/dynamic-route-build-file.test.js
Normal file
|
@ -0,0 +1,24 @@
|
|||
import { expect } from 'chai';
|
||||
import * as cheerio from 'cheerio';
|
||||
import { loadFixture } from './test-utils.js';
|
||||
|
||||
describe('build.format=file with dynamic routes', () => {
|
||||
/** @type {import('./test-utils').Fixture} */
|
||||
let fixture;
|
||||
|
||||
before(async () => {
|
||||
fixture = await loadFixture({
|
||||
root: './fixtures/dynamic-route-build-file',
|
||||
build: {
|
||||
format: 'file'
|
||||
}
|
||||
});
|
||||
await fixture.build();
|
||||
});
|
||||
|
||||
it('Outputs a slug of undefined as the index.html', async () => {
|
||||
const html = await fixture.readFile('/index.html');
|
||||
const $ = cheerio.load(html);
|
||||
expect($('h1').text()).to.equal('Astro Store');
|
||||
});
|
||||
});
|
10
packages/astro/test/fixtures/dynamic-route-build-file/index.html
vendored
Normal file
10
packages/astro/test/fixtures/dynamic-route-build-file/index.html
vendored
Normal file
|
@ -0,0 +1,10 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<title>Astro Store</title>
|
||||
</head>
|
||||
<body>
|
||||
<h1>Astro Store</h1>
|
||||
<p>Welcome to the Astro store!</p>
|
||||
</body>
|
||||
</html>
|
8
packages/astro/test/fixtures/dynamic-route-build-file/package.json
vendored
Normal file
8
packages/astro/test/fixtures/dynamic-route-build-file/package.json
vendored
Normal file
|
@ -0,0 +1,8 @@
|
|||
{
|
||||
"name": "@test/dynamic-route-build-file",
|
||||
"version": "0.0.0",
|
||||
"private": true,
|
||||
"dependencies": {
|
||||
"astro": "workspace:*"
|
||||
}
|
||||
}
|
38
packages/astro/test/fixtures/dynamic-route-build-file/src/pages/[...slug].astro
vendored
Normal file
38
packages/astro/test/fixtures/dynamic-route-build-file/src/pages/[...slug].astro
vendored
Normal file
|
@ -0,0 +1,38 @@
|
|||
---
|
||||
export async function getStaticPaths() {
|
||||
const pages = [
|
||||
{
|
||||
slug: undefined,
|
||||
title: "Astro Store",
|
||||
text: "Welcome to the Astro store!",
|
||||
},
|
||||
{
|
||||
slug: "products",
|
||||
title: "Astro products",
|
||||
text: "We have lots of products for you",
|
||||
},
|
||||
{
|
||||
slug: "products/astro-handbook",
|
||||
title: "The ultimative Astro handbook",
|
||||
text: "If you want to learn Astro, you must read this book.",
|
||||
},
|
||||
];
|
||||
return pages.map(({ slug, title, text }) => {
|
||||
return {
|
||||
params: { slug },
|
||||
props: { title, text },
|
||||
};
|
||||
});
|
||||
}
|
||||
|
||||
const { title, text } = Astro.props;
|
||||
---
|
||||
<html>
|
||||
<head>
|
||||
<title>{title}</title>
|
||||
</head>
|
||||
<body>
|
||||
<h1>{title}</h1>
|
||||
<p>{text}</p>
|
||||
</body>
|
||||
</html>
|
|
@ -1676,6 +1676,12 @@ importers:
|
|||
dependencies:
|
||||
astro: link:../../..
|
||||
|
||||
packages/astro/test/fixtures/dynamic-route-build-file:
|
||||
specifiers:
|
||||
astro: workspace:*
|
||||
dependencies:
|
||||
astro: link:../../..
|
||||
|
||||
packages/astro/test/fixtures/entry-file-names:
|
||||
specifiers:
|
||||
'@astrojs/preact': 'workspace:'
|
||||
|
|
Loading…
Reference in a new issue