0
Fork 0
mirror of https://github.com/withastro/astro.git synced 2024-12-30 22:03:56 -05:00

Clean sourcemaps from static output (#12749)

* Clean sourcemaps from static output

* Add changeset

* Update test to look at frontend sourcemaps
This commit is contained in:
Matthew Phillips 2024-12-16 14:19:11 -05:00
parent 11c52c0b77
commit 780a41f616
5 changed files with 37 additions and 14 deletions

View file

@ -0,0 +1,5 @@
---
'astro': patch
---
Clean server sourcemaps from static output

View file

@ -111,10 +111,6 @@ export async function viteBuild(opts: StaticBuildOptions) {
const ssrOutputs = viteBuildReturnToRollupOutputs(ssrOutput);
const clientOutputs = viteBuildReturnToRollupOutputs(clientOutput ?? []);
await runPostBuildHooks(container, ssrOutputs, clientOutputs);
let contentFileNames: string[] | undefined = undefined;
if (opts.settings.config.experimental.contentCollectionCache) {
contentFileNames = await copyContentToCache(opts);
}
settings.timer.end('Client build');
// Free up memory
@ -134,20 +130,19 @@ export async function viteBuild(opts: StaticBuildOptions) {
}
}
return { internals, ssrOutputChunkNames, contentFileNames };
return { internals, ssrOutputChunkNames };
}
export async function staticBuild(
opts: StaticBuildOptions,
internals: BuildInternals,
ssrOutputChunkNames: string[],
contentFileNames?: string[],
) {
const { settings } = opts;
if (settings.config.output === 'static') {
settings.timer.start('Static generate');
await generatePages(opts, internals);
await cleanServerOutput(opts, ssrOutputChunkNames, contentFileNames, internals);
await cleanServerOutput(opts, ssrOutputChunkNames, internals);
settings.timer.end('Static generate');
} else if (isServerLikeOutput(settings.config)) {
settings.timer.start('Server generate');
@ -411,14 +406,12 @@ async function cleanStaticOutput(opts: StaticBuildOptions, internals: BuildInter
async function cleanServerOutput(
opts: StaticBuildOptions,
ssrOutputChunkNames: string[],
contentFileNames: string[] | undefined,
internals: BuildInternals,
) {
const out = getOutDirWithinCwd(opts.settings.config.outDir);
// The SSR output chunks for Astro are all .mjs files
const files = ssrOutputChunkNames
.filter((f) => f.endsWith('.mjs'))
.concat(contentFileNames ?? []);
.filter((f) => f.endsWith('.mjs'));
if (internals.manifestFileName) {
files.push(internals.manifestFileName);
}
@ -427,7 +420,11 @@ async function cleanServerOutput(
await Promise.all(
files.map(async (filename) => {
const url = new URL(filename, out);
await fs.promises.rm(url);
const map = new URL(url + '.map');
await Promise.all([
fs.promises.rm(url),
fs.promises.rm(new URL(map)).catch((e) => {})
]);
}),
);
@ -483,6 +480,8 @@ async function ssrMoveAssets(opts: StaticBuildOptions) {
cwd: fileURLToPath(serverAssets),
});
console.log("FILES2", files);
if (files.length > 0) {
await Promise.all(
files.map(async function moveAsset(filename) {

View file

@ -172,6 +172,14 @@ describe('Astro basic build', () => {
assert.doesNotMatch(otherHtml, /<style/);
});
it('server sourcemaps not included in output', async () => {
const files = await fixture.readdir('/');
const hasSourcemaps = files.some(fileName => {
return fileName.endsWith('.map');
});
assert.equal(hasSourcemaps, false, 'no sourcemap files in output');
});
describe('preview', () => {
it('returns 200 for valid URLs', async () => {
const result = await fixture.fetch('/');

View file

@ -6,5 +6,10 @@ import { defineConfig } from 'astro/config';
export default defineConfig({
integrations: [preact(), mdx()],
// make sure CLI flags have precedence
server: () => ({ port: 4321 })
server: () => ({ port: 4321 }),
vite: {
build: {
sourcemap: true,
}
}
});

View file

@ -17,7 +17,13 @@ describe('Sourcemap', async () => {
});
it('Builds non-empty sourcemap', async () => {
const map = await fixture.readFile('renderers.mjs.map');
const assets = await fixture.readdir('/_astro');
const maps = assets.filter(file => file.endsWith('.map'));
assert.ok(maps.length > 0, 'got source maps');
for(const mapName of maps) {
const filename = `/_astro/${mapName}`;
const map = await fixture.readFile(filename);
assert.equal(map.includes('"sources":[]'), false);
}
});
});