fix: middleware entry point to not be set (#8036)

* fix: middleware entry point to not be set

* chore: update tests
This commit is contained in:
Emanuele Stoppa 2023-08-11 12:24:12 +01:00 committed by GitHub
parent fa3e839843
commit 87d4b18437
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 22 additions and 8 deletions

View file

@ -0,0 +1,5 @@
---
'astro': patch
---
Fix a bug where the middleware entry point was passed to integrations even though the configuration `build.excludeMiddleware` was set to `false`.

View file

@ -56,7 +56,7 @@ export function vitePluginMiddleware(
if (chunk.type === 'asset') { if (chunk.type === 'asset') {
continue; continue;
} }
if (chunk.fileName === 'middleware.mjs') { if (chunk.fileName === 'middleware.mjs' && opts.settings.config.build.excludeMiddleware) {
internals.middlewareEntryPoint = new URL(chunkName, opts.settings.config.build.server); internals.middlewareEntryPoint = new URL(chunkName, opts.settings.config.build.server);
} }
} }

View file

@ -118,13 +118,7 @@ describe('Middleware API in PROD mode, SSR', () => {
fixture = await loadFixture({ fixture = await loadFixture({
root: './fixtures/middleware-dev/', root: './fixtures/middleware-dev/',
output: 'server', output: 'server',
adapter: testAdapter({ adapter: testAdapter({}),
setEntryPoints(entryPointsOrMiddleware) {
if (entryPointsOrMiddleware instanceof URL) {
middlewarePath = entryPointsOrMiddleware;
}
},
}),
}); });
await fixture.build(); await fixture.build();
}); });
@ -218,6 +212,21 @@ describe('Middleware API in PROD mode, SSR', () => {
}); });
it('the integration should receive the path to the middleware', async () => { it('the integration should receive the path to the middleware', async () => {
fixture = await loadFixture({
root: './fixtures/middleware-dev/',
output: 'server',
build: {
excludeMiddleware: true,
},
adapter: testAdapter({
setEntryPoints(entryPointsOrMiddleware) {
if (entryPointsOrMiddleware instanceof URL) {
middlewarePath = entryPointsOrMiddleware;
}
},
}),
});
await fixture.build();
expect(middlewarePath).to.not.be.undefined; expect(middlewarePath).to.not.be.undefined;
try { try {
const path = fileURLToPath(middlewarePath); const path = fileURLToPath(middlewarePath);