diff --git a/.changeset/chatty-walls-happen.md b/.changeset/chatty-walls-happen.md new file mode 100644 index 0000000000..58fe5e6edb --- /dev/null +++ b/.changeset/chatty-walls-happen.md @@ -0,0 +1,5 @@ +--- +'astro': patch +--- + +Fixed a case where dynamic imports tried to preload inlined stylesheets. diff --git a/.changeset/fair-countries-admire.md b/.changeset/fair-countries-admire.md new file mode 100644 index 0000000000..1868ab0166 --- /dev/null +++ b/.changeset/fair-countries-admire.md @@ -0,0 +1,5 @@ +--- +'@astrojs/svelte': patch +--- + +Removed vite warnings. diff --git a/.eslintrc.cjs b/.eslintrc.cjs index 2e31d2fa76..9a6436767e 100644 --- a/.eslintrc.cjs +++ b/.eslintrc.cjs @@ -13,7 +13,7 @@ module.exports = { rules: { // These off/configured-differently-by-default rules fit well for us '@typescript-eslint/array-type': ['error', { default: 'array-simple' }], - '@typescript-eslint/no-unused-vars': ['error', { ignoreRestSiblings: true }], + '@typescript-eslint/no-unused-vars': ['error', { argsIgnorePattern: "^_", ignoreRestSiblings: true }], 'no-only-tests/no-only-tests': 'error', '@typescript-eslint/no-shadow': ['error'], 'no-console': 'warn', diff --git a/packages/astro/src/core/app/index.ts b/packages/astro/src/core/app/index.ts index a3af4bcdd5..1c0b131482 100644 --- a/packages/astro/src/core/app/index.ts +++ b/packages/astro/src/core/app/index.ts @@ -121,8 +121,6 @@ export class App { } return pathname; } - // Disable no-unused-vars to avoid breaking signature change - // eslint-disable-next-line @typescript-eslint/no-unused-vars match(request: Request, _opts: MatchOptions = {}): RouteData | undefined { const url = new URL(request.url); // ignore requests matching public assets diff --git a/packages/astro/src/core/build/plugins/plugin-css.ts b/packages/astro/src/core/build/plugins/plugin-css.ts index 87b52cbdb2..b72acd27e8 100644 --- a/packages/astro/src/core/build/plugins/plugin-css.ts +++ b/packages/astro/src/core/build/plugins/plugin-css.ts @@ -200,7 +200,7 @@ function rollupPluginAstroBuildCSS(options: PluginOptions): VitePlugin[] { const inlineConfig = settings.config.build.inlineStylesheets; const { assetsInlineLimit = 4096 } = settings.config.vite?.build ?? {}; - Object.entries(bundle).forEach(([id, stylesheet]) => { + Object.entries(bundle).forEach(([_, stylesheet]) => { if ( stylesheet.type !== 'asset' || stylesheet.name?.endsWith('.css') !== true || @@ -217,8 +217,6 @@ function rollupPluginAstroBuildCSS(options: PluginOptions): VitePlugin[] { ? false : assetSize <= assetsInlineLimit; - if (toBeInlined) delete bundle[id]; - // there should be a single js object for each stylesheet, // allowing the single reference to be shared and checked for duplicates const sheet: StylesheetAsset = toBeInlined diff --git a/packages/astro/test/css-dangling-references.test.js b/packages/astro/test/css-dangling-references.test.js new file mode 100644 index 0000000000..4f3c6e77d5 --- /dev/null +++ b/packages/astro/test/css-dangling-references.test.js @@ -0,0 +1,36 @@ +import { expect } from 'chai'; +import { loadFixture } from './test-utils.js'; + +const cssAssetReferenceRegExp = /_astro\/[A-Za-z0-9\-]+\.[a0-9a-f]{8}\.css/g + +describe("When Vite's preloadModule polyfill is used", async () => { + + let fixture; + + before(async () => { + fixture = await loadFixture({ + root: './fixtures/css-dangling-references/' + }); + await fixture.build(); + }); + + it('there are no references to deleted CSS chunks', async () => { + + const fileNames = await fixture.readdir('/_astro/') + const filePaths = fileNames.map(filename => '_astro/' + filename) + + const expectations = + filePaths + .filter(filePath => filePath.endsWith('js')) + .map(async filePath => { + const contents = await fixture.readFile(filePath) + const cssReferences = contents.match(cssAssetReferenceRegExp) + + if (cssReferences === null) return + + expect(filePaths).to.contain.members(cssReferences, filePath + ' contains a reference to a deleted css asset: ' + cssReferences) + }) + + await Promise.all(expectations) + }) +}) \ No newline at end of file diff --git a/packages/astro/test/fixtures/css-dangling-references/astro.config.ts b/packages/astro/test/fixtures/css-dangling-references/astro.config.ts new file mode 100644 index 0000000000..5c49c2fd0b --- /dev/null +++ b/packages/astro/test/fixtures/css-dangling-references/astro.config.ts @@ -0,0 +1,8 @@ +import { defineConfig } from 'astro/config'; +import svelte from '@astrojs/svelte'; + +// https://astro.build/config +export default defineConfig({ + integrations: [svelte()], +}); + diff --git a/packages/astro/test/fixtures/css-dangling-references/package.json b/packages/astro/test/fixtures/css-dangling-references/package.json new file mode 100644 index 0000000000..9ac28d2822 --- /dev/null +++ b/packages/astro/test/fixtures/css-dangling-references/package.json @@ -0,0 +1,11 @@ +{ + "name": "@test/css-dangling-references", + "version": "0.0.0", + "private": true, + "dependencies": { + "astro": "workspace:*", + "@astrojs/svelte": "workspace:*", + "svelte": "4" + } + } + \ No newline at end of file diff --git a/packages/astro/test/fixtures/css-dangling-references/src/components/DynamicallyImportedComponent1.svelte b/packages/astro/test/fixtures/css-dangling-references/src/components/DynamicallyImportedComponent1.svelte new file mode 100644 index 0000000000..3ac8a03af7 --- /dev/null +++ b/packages/astro/test/fixtures/css-dangling-references/src/components/DynamicallyImportedComponent1.svelte @@ -0,0 +1,6 @@ + +
This sentence should have a lavender background color.
diff --git a/packages/astro/test/fixtures/css-dangling-references/src/components/Wrapper.svelte b/packages/astro/test/fixtures/css-dangling-references/src/components/Wrapper.svelte new file mode 100644 index 0000000000..083040742c --- /dev/null +++ b/packages/astro/test/fixtures/css-dangling-references/src/components/Wrapper.svelte @@ -0,0 +1,15 @@ + + +{#await AppModule() then Mod} +