Prevents automatic trailingSlash behavior with getStaticPaths (#4265)
* Prevents automatic trailingSlash behavior with getStaticPaths * Testing * weird change
This commit is contained in:
parent
c218100684
commit
8f845ca950
6 changed files with 60 additions and 3 deletions
5
.changeset/fluffy-otters-guess.md
Normal file
5
.changeset/fluffy-otters-guess.md
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
---
|
||||||
|
'astro': patch
|
||||||
|
---
|
||||||
|
|
||||||
|
Prevents automatic trailingSlash appending on getStaticPaths produced pages
|
|
@ -15,7 +15,7 @@ test.afterEach(async () => {
|
||||||
|
|
||||||
test.describe('Recursive elements with Solid', () => {
|
test.describe('Recursive elements with Solid', () => {
|
||||||
test('Counter', async ({ astro, page }) => {
|
test('Counter', async ({ astro, page }) => {
|
||||||
await page.goto(astro.resolveUrl('/'));
|
await page.goto('/');
|
||||||
|
|
||||||
const wrapper = page.locator('#case1');
|
const wrapper = page.locator('#case1');
|
||||||
await expect(wrapper, 'component is visible').toBeVisible();
|
await expect(wrapper, 'component is visible').toBeVisible();
|
||||||
|
|
|
@ -245,7 +245,7 @@ interface GeneratePathOptions {
|
||||||
}
|
}
|
||||||
|
|
||||||
function addPageName(pathname: string, opts: StaticBuildOptions): void {
|
function addPageName(pathname: string, opts: StaticBuildOptions): void {
|
||||||
opts.pageNames.push(pathname.replace(/\/?$/, '/').replace(/^\//, ''));
|
opts.pageNames.push(pathname.replace(/^\//, ''));
|
||||||
}
|
}
|
||||||
|
|
||||||
async function generatePath(
|
async function generatePath(
|
||||||
|
|
|
@ -28,7 +28,11 @@ export function getRouteGenerator(
|
||||||
})
|
})
|
||||||
.join('');
|
.join('');
|
||||||
|
|
||||||
const trailing = addTrailingSlash !== 'never' && segments.length ? '/' : '';
|
// Unless trailingSlash config is set to 'always', don't automatically append it.
|
||||||
|
let trailing: '/' | '' = '';
|
||||||
|
if(addTrailingSlash === 'always' && segments.length) {
|
||||||
|
trailing = '/';
|
||||||
|
}
|
||||||
const toPath = compile(template + trailing);
|
const toPath = compile(template + trailing);
|
||||||
return toPath;
|
return toPath;
|
||||||
}
|
}
|
||||||
|
|
|
@ -150,3 +150,25 @@ describe('getStaticPaths - numeric route params', () => {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('getStaticPaths - Astro.url', () => {
|
||||||
|
/** @type {import('./test-utils').Fixture} */
|
||||||
|
let fixture;
|
||||||
|
before(async () => {
|
||||||
|
// reset the flag used by [...calledTwiceTest].astro between each test
|
||||||
|
globalThis.isCalledOnce = false;
|
||||||
|
|
||||||
|
fixture = await loadFixture({
|
||||||
|
root: './fixtures/astro-get-static-paths/',
|
||||||
|
site: 'https://mysite.dev/',
|
||||||
|
});
|
||||||
|
await fixture.build();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('Sets the current pathname', async () => {
|
||||||
|
const html = await fixture.readFile('/food/tacos/index.html');
|
||||||
|
const $ = cheerio.load(html);
|
||||||
|
|
||||||
|
expect($('#url').text()).to.equal('/food/tacos');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
26
packages/astro/test/fixtures/astro-get-static-paths/src/pages/food/[name].astro
vendored
Normal file
26
packages/astro/test/fixtures/astro-get-static-paths/src/pages/food/[name].astro
vendored
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
---
|
||||||
|
export async function getStaticPaths() {
|
||||||
|
return [
|
||||||
|
{
|
||||||
|
params: { name: 'tacos' },
|
||||||
|
},
|
||||||
|
{
|
||||||
|
params: { name: 'potatoes' },
|
||||||
|
},
|
||||||
|
{
|
||||||
|
params: { name: 'spaghetti' }
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
---
|
||||||
|
|
||||||
|
<html lang="en">
|
||||||
|
<head>
|
||||||
|
<meta charset="utf-8" />
|
||||||
|
<meta name="viewport" content="width=device-width" />
|
||||||
|
<title>Food</title>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<p id="url">{ Astro.url.pathname }</p>
|
||||||
|
</body>
|
||||||
|
</html>
|
Loading…
Reference in a new issue