0
Fork 0
mirror of https://github.com/withastro/astro.git synced 2025-01-20 22:12:38 -05:00

fix(#2007): astro preview port retry (#2050)

* fix(#2007): astro preview port retry

* docs: update preview comment
This commit is contained in:
Nate Moore 2021-11-29 17:39:38 -06:00 committed by GitHub
parent c491d1f423
commit 4e06767c01
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 46 additions and 24 deletions

View file

@ -0,0 +1,5 @@
---
'astro': patch
---
Fix `astro preview` port retry logic

View file

@ -38,38 +38,55 @@ export default async function preview(config: AstroConfig, { logging }: PreviewO
}).pipe(res); }).pipe(res);
}); });
// Start listening on `hostname:port`.
let port = config.devOptions.port; let port = config.devOptions.port;
const { hostname } = config.devOptions; const { hostname } = config.devOptions;
await new Promise<http.Server>((resolve, reject) => { let httpServer: http.Server;
/** Expose dev server to `port` */
function startServer(timerStart: number): Promise<void> {
let showedPortTakenMsg = false;
let showedListenMsg = false;
return new Promise<void>((resolve, reject) => {
const listen = () => {
httpServer = server.listen(port, hostname, () => {
if (!showedListenMsg) {
info(logging, 'astro', msg.devStart({ startupTime: performance.now() - timerStart }));
info(logging, 'astro', msg.devHost({ host: `http://${hostname}:${port}${base}` }));
}
showedListenMsg = true;
resolve();
});
httpServer?.on('error', onError);
};
const onError = (err: NodeJS.ErrnoException) => { const onError = (err: NodeJS.ErrnoException) => {
if (err.code && err.code === 'EADDRINUSE') { if (err.code && err.code === 'EADDRINUSE') {
if (!showedPortTakenMsg) {
info(logging, 'astro', msg.portInUse({ port })); info(logging, 'astro', msg.portInUse({ port }));
showedPortTakenMsg = true; // only print this once
}
port++; port++;
return listen(); // retry
} else { } else {
error(logging, 'preview', err.stack); error(logging, 'astro', err.stack);
server.removeListener('error', onError); httpServer?.removeListener('error', onError);
reject(err); reject(err); // reject
} }
}; };
server listen();
.listen(port, hostname, () => {
info(logging, 'preview', msg.devStart({ startupTime: performance.now() - startServerTime }));
info(logging, 'preview', msg.devHost({ host: `http://${hostname}:${port}${base}` }));
resolve(server);
})
.on('error', (err: NodeJS.ErrnoException) => {
process.exit(1);
});
}); });
}
// Start listening on `hostname:port`.
await startServer(startServerTime);
return { return {
hostname, hostname,
port, port,
server, server: httpServer!,
stop: async () => { stop: async () => {
server.close(); httpServer.close();
}, },
}; };
} }