From 524c855075bb75696500445fdc31cb2c69b09627 Mon Sep 17 00:00:00 2001 From: Emanuele Stoppa Date: Thu, 2 Jan 2025 11:55:48 +0000 Subject: [PATCH] fix(core): add error log for server islands (#12768) Co-authored-by: Sarah Rainsberger <5098874+sarah11918@users.noreply.github.com> Co-authored-by: Matt Kane --- .changeset/khaki-tools-live.md | 5 +++++ .changeset/silver-cars-confess.md | 5 +++++ .changeset/spotty-timers-shake.md | 5 +++++ packages/astro/src/core/build/index.ts | 6 +++--- packages/astro/src/core/build/static-build.ts | 2 +- packages/astro/src/core/create-vite.ts | 2 +- packages/astro/src/core/logger/core.ts | 1 + .../core/server-islands/vite-plugin-server-islands.ts | 11 +++++++++-- packages/underscore-redirects/src/astro.ts | 5 ++++- 9 files changed, 34 insertions(+), 8 deletions(-) create mode 100644 .changeset/khaki-tools-live.md create mode 100644 .changeset/silver-cars-confess.md create mode 100644 .changeset/spotty-timers-shake.md diff --git a/.changeset/khaki-tools-live.md b/.changeset/khaki-tools-live.md new file mode 100644 index 0000000000..9d76b620d6 --- /dev/null +++ b/.changeset/khaki-tools-live.md @@ -0,0 +1,5 @@ +--- +'astro': patch +--- + +Fixes an issue where Astro didn't print error logs when Astro Islands were used in incorrect cases. diff --git a/.changeset/silver-cars-confess.md b/.changeset/silver-cars-confess.md new file mode 100644 index 0000000000..5362dfa536 --- /dev/null +++ b/.changeset/silver-cars-confess.md @@ -0,0 +1,5 @@ +--- +'astro': patch +--- + +Fixes an issue where Astro was printing the incorrect output format when running the `astro build` command diff --git a/.changeset/spotty-timers-shake.md b/.changeset/spotty-timers-shake.md new file mode 100644 index 0000000000..1bb6c91cb9 --- /dev/null +++ b/.changeset/spotty-timers-shake.md @@ -0,0 +1,5 @@ +--- +'@astrojs/underscore-redirects': minor +--- + +Adds a new `buildOutput` property to the API `createRedirectsFromAstroRoutes` diff --git a/packages/astro/src/core/build/index.ts b/packages/astro/src/core/build/index.ts index a31b34ce84..cc00172af5 100644 --- a/packages/astro/src/core/build/index.ts +++ b/packages/astro/src/core/build/index.ts @@ -12,7 +12,7 @@ import { runHookConfigSetup, } from '../../integrations/hooks.js'; import type { AstroSettings, ManifestData } from '../../types/astro.js'; -import type { AstroConfig, AstroInlineConfig, RuntimeMode } from '../../types/public/config.js'; +import type { AstroInlineConfig, RuntimeMode } from '../../types/public/config.js'; import { resolveConfig } from '../config/config.js'; import { createNodeLogger } from '../config/logging.js'; import { createSettings } from '../config/settings.js'; @@ -163,7 +163,7 @@ class AstroBuilder { await runHookBuildStart({ config: this.settings.config, logging: this.logger }); this.validateConfig(); - this.logger.info('build', `output: ${blue('"' + this.settings.config.output + '"')}`); + this.logger.info('build', `output: ${blue('"' + this.settings.buildOutput + '"')}`); this.logger.info('build', `directory: ${blue(fileURLToPath(this.settings.config.outDir))}`); if (this.settings.adapter) { this.logger.info('build', `adapter: ${green(this.settings.adapter.name)}`); @@ -283,7 +283,7 @@ class AstroBuilder { logger: Logger; timeStart: number; pageCount: number; - buildMode: AstroConfig['output']; + buildMode: AstroSettings['buildOutput']; }) { const total = getTimeStat(timeStart, performance.now()); diff --git a/packages/astro/src/core/build/static-build.ts b/packages/astro/src/core/build/static-build.ts index 935b4a2d5d..ba0811c840 100644 --- a/packages/astro/src/core/build/static-build.ts +++ b/packages/astro/src/core/build/static-build.ts @@ -63,7 +63,7 @@ export async function viteBuild(opts: StaticBuildOptions) { registerAllPlugins(container); // Build your project (SSR application code, assets, client JS, etc.) const ssrTime = performance.now(); - opts.logger.info('build', `Building ${settings.config.output} entrypoints...`); + opts.logger.info('build', `Building ${settings.buildOutput} entrypoints...`); const ssrOutput = await ssrBuild(opts, internals, pageInput, container); opts.logger.info('build', green(`✓ Completed in ${getTimeStat(ssrTime, performance.now())}.`)); diff --git a/packages/astro/src/core/create-vite.ts b/packages/astro/src/core/create-vite.ts index 5d9e77b3d9..cad0dbc3c3 100644 --- a/packages/astro/src/core/create-vite.ts +++ b/packages/astro/src/core/create-vite.ts @@ -170,7 +170,7 @@ export async function createVite( astroInternationalization({ settings }), vitePluginActions({ fs, settings }), vitePluginUserActions({ settings }), - vitePluginServerIslands({ settings }), + vitePluginServerIslands({ settings, logger }), astroContainer(), astroHmrReloadPlugin(), ], diff --git a/packages/astro/src/core/logger/core.ts b/packages/astro/src/core/logger/core.ts index 9ab12f0ac3..e5c91f6537 100644 --- a/packages/astro/src/core/logger/core.ts +++ b/packages/astro/src/core/logger/core.ts @@ -33,6 +33,7 @@ export type LoggerLabel = | 'env' | 'update' | 'adapter' + | 'islands' // SKIP_FORMAT: A special label that tells the logger not to apply any formatting. // Useful for messages that are already formatted, like the server start message. | 'SKIP_FORMAT'; diff --git a/packages/astro/src/core/server-islands/vite-plugin-server-islands.ts b/packages/astro/src/core/server-islands/vite-plugin-server-islands.ts index 8bc79e087d..ddc0653faf 100644 --- a/packages/astro/src/core/server-islands/vite-plugin-server-islands.ts +++ b/packages/astro/src/core/server-islands/vite-plugin-server-islands.ts @@ -1,12 +1,12 @@ import type { ConfigEnv, ViteDevServer, Plugin as VitePlugin } from 'vite'; -import type { AstroSettings } from '../../types/astro.js'; +import type { AstroPluginOptions } from '../../types/astro.js'; import type { AstroPluginMetadata } from '../../vite-plugin-astro/index.js'; export const VIRTUAL_ISLAND_MAP_ID = '@astro-server-islands'; export const RESOLVED_VIRTUAL_ISLAND_MAP_ID = '\0' + VIRTUAL_ISLAND_MAP_ID; const serverIslandPlaceholder = "'$$server-islands$$'"; -export function vitePluginServerIslands({ settings }: { settings: AstroSettings }): VitePlugin { +export function vitePluginServerIslands({ settings, logger }: AstroPluginOptions): VitePlugin { let command: ConfigEnv['command'] = 'serve'; let viteServer: ViteDevServer | null = null; const referenceIdMap = new Map(); @@ -37,6 +37,13 @@ export function vitePluginServerIslands({ settings }: { settings: AstroSettings if (astro?.serverComponents.length) { for (const comp of astro.serverComponents) { if (!settings.serverIslandNameMap.has(comp.resolvedPath)) { + if (!settings.adapter) { + logger.error( + 'islands', + "You tried to render a server island without an adapter added to your project. An adapter is required to use the `server:defer` attribute on any component. Your project will fail to build unless you add an adapter or remove the attribute.", + ); + } + let name = comp.localName; let idx = 1; diff --git a/packages/underscore-redirects/src/astro.ts b/packages/underscore-redirects/src/astro.ts index 251de499b5..b76e1b52a6 100644 --- a/packages/underscore-redirects/src/astro.ts +++ b/packages/underscore-redirects/src/astro.ts @@ -18,6 +18,7 @@ interface CreateRedirectsFromAstroRoutesParams { */ routeToDynamicTargetMap: Map; dir: URL; + buildOutput: 'static' | 'server'; } /** @@ -27,6 +28,7 @@ export function createRedirectsFromAstroRoutes({ config, routeToDynamicTargetMap, dir, + buildOutput, }: CreateRedirectsFromAstroRoutesParams) { const base = config.base && config.base !== '/' @@ -34,7 +36,8 @@ export function createRedirectsFromAstroRoutes({ ? config.base.slice(0, -1) : config.base : ''; - const output = config.output; + // TODO: the use of `config.output` is deprecated. We need to update the adapters that use this package to pass the new buildOutput + const output = buildOutput ?? config.output; const _redirects = new Redirects(); for (const [route, dynamicTarget = ''] of routeToDynamicTargetMap) {