mirror of
https://github.com/withastro/astro.git
synced 2025-01-06 22:10:10 -05:00
fix: missing log (#12814)
This commit is contained in:
parent
e109002c3d
commit
f12f1118bc
2 changed files with 25 additions and 8 deletions
5
.changeset/red-schools-marry.md
Normal file
5
.changeset/red-schools-marry.md
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
---
|
||||||
|
'astro': patch
|
||||||
|
---
|
||||||
|
|
||||||
|
Fixes an issue where Astro didn't log anything in case a file isn't created during the build.
|
|
@ -1,6 +1,6 @@
|
||||||
import fs from 'node:fs';
|
import fs from 'node:fs';
|
||||||
import os from 'node:os';
|
import os from 'node:os';
|
||||||
import { bgGreen, black, blue, bold, dim, green, magenta, red } from 'kleur/colors';
|
import { bgGreen, black, blue, bold, dim, green, magenta, red, yellow } from 'kleur/colors';
|
||||||
import PLimit from 'p-limit';
|
import PLimit from 'p-limit';
|
||||||
import PQueue from 'p-queue';
|
import PQueue from 'p-queue';
|
||||||
import {
|
import {
|
||||||
|
@ -191,16 +191,18 @@ async function generatePage(
|
||||||
logger.info(null, ` ${blue(lineIcon)} ${dim(filePath)}`, false);
|
logger.info(null, ` ${blue(lineIcon)} ${dim(filePath)}`, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
await generatePath(path, pipeline, generationOptions, route);
|
const created = await generatePath(path, pipeline, generationOptions, route);
|
||||||
|
|
||||||
const timeEnd = performance.now();
|
const timeEnd = performance.now();
|
||||||
const isSlow = timeEnd - timeStart > THRESHOLD_SLOW_RENDER_TIME_MS;
|
const isSlow = timeEnd - timeStart > THRESHOLD_SLOW_RENDER_TIME_MS;
|
||||||
const timeIncrease = (isSlow ? red : dim)(`(+${getTimeStat(timeStart, timeEnd)})`);
|
const timeIncrease = (isSlow ? red : dim)(`(+${getTimeStat(timeStart, timeEnd)})`);
|
||||||
|
const notCreated =
|
||||||
|
created === false ? yellow('(file not created, response body was empty)') : '';
|
||||||
|
|
||||||
if (isConcurrent) {
|
if (isConcurrent) {
|
||||||
logger.info(null, ` ${blue(lineIcon)} ${dim(filePath)} ${timeIncrease}`);
|
logger.info(null, ` ${blue(lineIcon)} ${dim(filePath)} ${timeIncrease} ${notCreated}`);
|
||||||
} else {
|
} else {
|
||||||
logger.info('SKIP_FORMAT', ` ${timeIncrease}`);
|
logger.info('SKIP_FORMAT', ` ${timeIncrease} ${notCreated}`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -395,12 +397,20 @@ interface GeneratePathOptions {
|
||||||
mod: ComponentInstance;
|
mod: ComponentInstance;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param pathname
|
||||||
|
* @param pipeline
|
||||||
|
* @param gopts
|
||||||
|
* @param route
|
||||||
|
* @return {Promise<boolean | undefined>} If `false` the file hasn't been created. If `undefined` it's expected to not be created.
|
||||||
|
*/
|
||||||
async function generatePath(
|
async function generatePath(
|
||||||
pathname: string,
|
pathname: string,
|
||||||
pipeline: BuildPipeline,
|
pipeline: BuildPipeline,
|
||||||
gopts: GeneratePathOptions,
|
gopts: GeneratePathOptions,
|
||||||
route: RouteData,
|
route: RouteData,
|
||||||
) {
|
): Promise<boolean | undefined> {
|
||||||
const { mod } = gopts;
|
const { mod } = gopts;
|
||||||
const { config, logger, options } = pipeline;
|
const { config, logger, options } = pipeline;
|
||||||
logger.debug('build', `Generating: ${pathname}`);
|
logger.debug('build', `Generating: ${pathname}`);
|
||||||
|
@ -420,7 +430,7 @@ async function generatePath(
|
||||||
// Check if there is a translated page with the same path
|
// Check if there is a translated page with the same path
|
||||||
Object.values(options.allPages).some((val) => val.route.pattern.test(pathname))
|
Object.values(options.allPages).some((val) => val.route.pattern.test(pathname))
|
||||||
) {
|
) {
|
||||||
return;
|
return undefined;
|
||||||
}
|
}
|
||||||
|
|
||||||
const url = getUrlForPath(
|
const url = getUrlForPath(
|
||||||
|
@ -462,7 +472,7 @@ async function generatePath(
|
||||||
// Adapters may handle redirects themselves, turning off Astro's redirect handling using `config.build.redirects` in the process.
|
// Adapters may handle redirects themselves, turning off Astro's redirect handling using `config.build.redirects` in the process.
|
||||||
// In that case, we skip rendering static files for the redirect routes.
|
// In that case, we skip rendering static files for the redirect routes.
|
||||||
if (routeIsRedirect(route) && !config.build.redirects) {
|
if (routeIsRedirect(route) && !config.build.redirects) {
|
||||||
return;
|
return undefined;
|
||||||
}
|
}
|
||||||
const locationSite = getRedirectLocationOrThrow(response.headers);
|
const locationSite = getRedirectLocationOrThrow(response.headers);
|
||||||
const siteURL = config.site;
|
const siteURL = config.site;
|
||||||
|
@ -478,7 +488,7 @@ async function generatePath(
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// If there's no body, do nothing
|
// If there's no body, do nothing
|
||||||
if (!response.body) return;
|
if (!response.body) return false;
|
||||||
body = Buffer.from(await response.arrayBuffer());
|
body = Buffer.from(await response.arrayBuffer());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -495,6 +505,8 @@ async function generatePath(
|
||||||
|
|
||||||
await fs.promises.mkdir(outFolder, { recursive: true });
|
await fs.promises.mkdir(outFolder, { recursive: true });
|
||||||
await fs.promises.writeFile(outFile, body);
|
await fs.promises.writeFile(outFile, body);
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function getPrettyRouteName(route: RouteData): string {
|
function getPrettyRouteName(route: RouteData): string {
|
||||||
|
|
Loading…
Reference in a new issue