mirror of
https://github.com/withastro/astro.git
synced 2025-01-06 22:10:10 -05:00
fix: regression when calculating params and pattern (#9051)
* fix: regression when calculating params and pattern * changeset
This commit is contained in:
parent
fb94d575af
commit
15b84ccb98
6 changed files with 58 additions and 30 deletions
5
.changeset/grumpy-cobras-attend.md
Normal file
5
.changeset/grumpy-cobras-attend.md
Normal file
|
@ -0,0 +1,5 @@
|
|||
---
|
||||
'astro': patch
|
||||
---
|
||||
|
||||
Fix a regression where endpoints were incorrectly processed during SSG build when `trailingSlash: "always"`
|
|
@ -31,11 +31,14 @@ export async function callGetStaticPaths({
|
|||
ssr,
|
||||
}: CallGetStaticPathsOptions): Promise<GetStaticPathsResultKeyed> {
|
||||
const cached = routeCache.get(route);
|
||||
if (cached?.staticPaths) return cached.staticPaths;
|
||||
|
||||
if (mod) {
|
||||
validateDynamicRouteModule(mod, { ssr, route });
|
||||
if (!mod) {
|
||||
throw new Error('This is an error caused by Astro and not your code. Please file an issue.');
|
||||
}
|
||||
if (cached?.staticPaths) {
|
||||
return cached.staticPaths;
|
||||
}
|
||||
|
||||
validateDynamicRouteModule(mod, { ssr, route });
|
||||
|
||||
// No static paths in SSR mode. Return an empty RouteCacheEntry.
|
||||
if (ssr && !route.prerender) {
|
||||
|
@ -47,24 +50,20 @@ export async function callGetStaticPaths({
|
|||
let staticPaths: GetStaticPathsResult = [];
|
||||
// Add a check here to make TypeScript happy.
|
||||
// This is already checked in validateDynamicRouteModule().
|
||||
if (mod) {
|
||||
if (!mod.getStaticPaths) {
|
||||
throw new Error('Unexpected Error.');
|
||||
}
|
||||
|
||||
if (mod) {
|
||||
// Calculate your static paths.
|
||||
staticPaths = await mod.getStaticPaths({
|
||||
// Q: Why the cast?
|
||||
// A: So users downstream can have nicer typings, we have to make some sacrifice in our internal typings, which necessitate a cast here
|
||||
paginate: generatePaginateFunction(route) as PaginateFunction,
|
||||
rss() {
|
||||
throw new AstroError(AstroErrorData.GetStaticPathsRemovedRSSHelper);
|
||||
},
|
||||
});
|
||||
}
|
||||
if (!mod.getStaticPaths) {
|
||||
throw new Error('Unexpected Error.');
|
||||
}
|
||||
|
||||
// Calculate your static paths.
|
||||
staticPaths = await mod.getStaticPaths({
|
||||
// Q: Why the cast?
|
||||
// A: So users downstream can have nicer typings, we have to make some sacrifice in our internal typings, which necessitate a cast here
|
||||
paginate: generatePaginateFunction(route) as PaginateFunction,
|
||||
rss() {
|
||||
throw new AstroError(AstroErrorData.GetStaticPathsRemovedRSSHelper);
|
||||
},
|
||||
});
|
||||
|
||||
validateGetStaticPathsResult(staticPaths, logger, route);
|
||||
|
||||
const keyedStaticPaths = staticPaths as GetStaticPathsResultKeyed;
|
||||
|
|
|
@ -60,9 +60,12 @@ function getParts(part: string, file: string) {
|
|||
return result;
|
||||
}
|
||||
|
||||
function getPattern(segments: RoutePart[][], config: AstroConfig) {
|
||||
function getPattern(
|
||||
segments: RoutePart[][],
|
||||
config: AstroConfig,
|
||||
addTrailingSlash: AstroConfig['trailingSlash']
|
||||
) {
|
||||
const base = config.base;
|
||||
const addTrailingSlash = config.trailingSlash;
|
||||
const pathname = segments
|
||||
.map((segment) => {
|
||||
if (segment.length === 1 && segment[0].spread) {
|
||||
|
@ -325,7 +328,7 @@ export function createRouteManifest(
|
|||
components.push(item.file);
|
||||
const component = item.file;
|
||||
const trailingSlash = item.isPage ? settings.config.trailingSlash : 'never';
|
||||
const pattern = getPattern(segments, settings.config);
|
||||
const pattern = getPattern(segments, settings.config, trailingSlash);
|
||||
const generate = getRouteGenerator(segments, trailingSlash);
|
||||
const pathname = segments.every((segment) => segment.length === 1 && !segment[0].dynamic)
|
||||
? `/${segments.map((segment) => segment[0].content).join('/')}`
|
||||
|
@ -386,7 +389,7 @@ export function createRouteManifest(
|
|||
const isPage = type === 'page';
|
||||
const trailingSlash = isPage ? config.trailingSlash : 'never';
|
||||
|
||||
const pattern = getPattern(segments, settings.config);
|
||||
const pattern = getPattern(segments, settings.config, trailingSlash);
|
||||
const generate = getRouteGenerator(segments, trailingSlash);
|
||||
const pathname = segments.every((segment) => segment.length === 1 && !segment[0].dynamic)
|
||||
? `/${segments.map((segment) => segment[0].content).join('/')}`
|
||||
|
@ -433,7 +436,7 @@ export function createRouteManifest(
|
|||
return getParts(s, from);
|
||||
});
|
||||
|
||||
const pattern = getPattern(segments, settings.config);
|
||||
const pattern = getPattern(segments, settings.config, trailingSlash);
|
||||
const generate = getRouteGenerator(segments, trailingSlash);
|
||||
const pathname = segments.every((segment) => segment.length === 1 && !segment[0].dynamic)
|
||||
? `/${segments.map((segment) => segment[0].content).join('/')}`
|
||||
|
@ -551,7 +554,7 @@ export function createRouteManifest(
|
|||
pathname,
|
||||
route,
|
||||
segments,
|
||||
pattern: getPattern(segments, config),
|
||||
pattern: getPattern(segments, config, config.trailingSlash),
|
||||
type: 'fallback',
|
||||
});
|
||||
}
|
||||
|
@ -624,7 +627,7 @@ export function createRouteManifest(
|
|||
pathname,
|
||||
route,
|
||||
segments,
|
||||
pattern: getPattern(segments, config),
|
||||
pattern: getPattern(segments, config, config.trailingSlash),
|
||||
type: 'fallback',
|
||||
});
|
||||
}
|
||||
|
|
|
@ -4,7 +4,7 @@ import sitemap from '@astrojs/sitemap';
|
|||
export default defineConfig({
|
||||
integrations: [sitemap()],
|
||||
site: 'http://example.com',
|
||||
redirects: {
|
||||
'/redirect': '/'
|
||||
},
|
||||
redirects: {
|
||||
'/redirect': '/'
|
||||
},
|
||||
})
|
||||
|
|
15
packages/integrations/sitemap/test/fixtures/static/src/pages/[lang]/manifest.ts
vendored
Normal file
15
packages/integrations/sitemap/test/fixtures/static/src/pages/[lang]/manifest.ts
vendored
Normal file
|
@ -0,0 +1,15 @@
|
|||
export const GET: APIRoute = async ({ params }) => {
|
||||
const { lang } = params;
|
||||
|
||||
return new Response(`I'm a route in the "${lang}" language.`);
|
||||
};
|
||||
|
||||
export async function getStaticPaths() {
|
||||
return ['it', 'en'].map((language) => {
|
||||
return {
|
||||
params: {
|
||||
lang: language,
|
||||
},
|
||||
};
|
||||
});
|
||||
}
|
|
@ -10,6 +10,7 @@ describe('getStaticPaths support', () => {
|
|||
before(async () => {
|
||||
fixture = await loadFixture({
|
||||
root: './fixtures/static/',
|
||||
trailingSlash: 'always',
|
||||
});
|
||||
await fixture.build();
|
||||
|
||||
|
@ -33,4 +34,9 @@ describe('getStaticPaths support', () => {
|
|||
it('includes numerical pages', () => {
|
||||
expect(urls).to.include('http://example.com/123/');
|
||||
});
|
||||
|
||||
it('should render the endpoint', async () => {
|
||||
const page = await fixture.readFile('./it/manifest');
|
||||
expect(page).to.contain('I\'m a route in the "it" language.');
|
||||
});
|
||||
});
|
||||
|
|
Loading…
Reference in a new issue