Skip to content

Commit

Permalink
Merge pull request backstage#7947 from backstage/freben/service-build…
Browse files Browse the repository at this point in the history
…er-errors

Make sure that the server builder propagates init errors properly
  • Loading branch information
freben authored Nov 12, 2021
2 parents 2375361 + 6f27670 commit c3ffbd6
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 16 deletions.
12 changes: 12 additions & 0 deletions .changeset/rich-pillows-cough.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
---
'@backstage/backend-common': patch
---

Make sure that server builder `start()` propagates errors (such as failing to bind to the required port) properly and doesn't resolve the promise prematurely.

After this change, the backend logger will be able to actually capture the error as it happens:

```
2021-11-11T10:54:21.334Z backstage info Initializing http server
2021-11-11T10:54:21.335Z backstage error listen EADDRINUSE: address already in use :::7000 code=EADDRINUSE errno=-48 syscall=listen address=:: port=7000
```
32 changes: 16 additions & 16 deletions packages/backend-common/src/service/lib/ServiceBuilderImpl.ts
Original file line number Diff line number Diff line change
Expand Up @@ -174,27 +174,27 @@ export class ServiceBuilderImpl implements ServiceBuilder {
const server: http.Server = httpsSettings
? await createHttpsServer(app, httpsSettings, logger)
: createHttpServer(app, logger);
const stoppableServer = stoppable(server, 0);

useHotCleanup(this.module, () =>
stoppableServer.stop((e: any) => {
if (e) console.error(e);
}),
);

return new Promise((resolve, reject) => {
app.on('error', e => {
logger.error(`Failed to start up on port ${port}, ${e}`);
function handleStartupError(e: unknown) {
server.close();
reject(e);
});

const stoppableServer = stoppable(
server.listen(port, host, () => {
logger.info(`Listening on ${host}:${port}`);
}),
0,
);
}

useHotCleanup(this.module, () =>
stoppableServer.stop((e: any) => {
if (e) console.error(e);
}),
);
server.on('error', handleStartupError);

resolve(stoppableServer);
server.listen(port, host, () => {
server.off('error', handleStartupError);
logger.info(`Listening on ${host}:${port}`);
resolve(stoppableServer);
});
});
}

Expand Down

0 comments on commit c3ffbd6

Please sign in to comment.