Unify a command-line entry point module (#344)

Summary:
For now, this contains the logic to register an `unhandledRejection`
error. I’ve removed all instances of those handlers, and `require`d this
module at every top-level entry point. (The individual CLI commands had
the handler before, but didn’t need it; conversely, the top-level CLI
entry point did not have the handler, but should have.)

Test Plan:
To test that the CLI commands still error on unhandled rejections, apply
the following patch:

```diff
diff --git a/src/v1/cli/commands/combine.js b/src/v1/cli/commands/combine.js
index b60f91e..d55b965 100644
--- a/src/v1/cli/commands/combine.js
+++ b/src/v1/cli/commands/combine.js
@@ -24,6 +24,7 @@ export default class CombineCommand extends Command {
     "  where each GRAPH is a JSON file generated by plugin-graph";

   async run() {
+    Promise.reject("wat");
     const {argv} = this.parse(CombineCommand);
     combine(argv);
   }
```

Then run `yarn backend` and `node bin/sourcecred.js`, and note that the
rejection handler is triggered.

wchargin-branch: unify-entry
This commit is contained in:
William Chargin 2018-06-05 11:11:48 -07:00 committed by GitHub
parent 540bd860c6
commit 2be413b77c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
10 changed files with 16 additions and 52 deletions

View File

@ -6,12 +6,7 @@ process.env.NODE_ENV = process.env.NODE_ENV || "development";
process.env.BABEL_ENV = process.env.NODE_ENV; process.env.BABEL_ENV = process.env.NODE_ENV;
process.env.SOURCECRED_BACKEND = "true"; process.env.SOURCECRED_BACKEND = "true";
// Makes the script crash on unhandled rejections instead of silently require("../src/tools/entry");
// ignoring them. In the future, promise rejections that are not handled will
// terminate the Node.js process with a non-zero exit code.
process.on("unhandledRejection", (err) => {
throw err;
});
// Ensure environment variables are read. // Ensure environment variables are read.
require("../config/env"); require("../config/env");

View File

@ -5,12 +5,7 @@
process.env.BABEL_ENV = "production"; process.env.BABEL_ENV = "production";
process.env.NODE_ENV = "production"; process.env.NODE_ENV = "production";
// Makes the script crash on unhandled rejections instead of silently require("../src/tools/entry");
// ignoring them. In the future, promise rejections that are not handled will
// terminate the Node.js process with a non-zero exit code.
process.on("unhandledRejection", (err) => {
throw err;
});
// Ensure environment variables are read. // Ensure environment variables are read.
require("../config/env"); require("../config/env");

View File

@ -5,12 +5,7 @@
process.env.BABEL_ENV = "development"; process.env.BABEL_ENV = "development";
process.env.NODE_ENV = "development"; process.env.NODE_ENV = "development";
// Makes the script crash on unhandled rejections instead of silently require("../src/tools/entry");
// ignoring them. In the future, promise rejections that are not handled will
// terminate the Node.js process with a non-zero exit code.
process.on("unhandledRejection", (err) => {
throw err;
});
// Ensure environment variables are read. // Ensure environment variables are read.
require("../config/env"); require("../config/env");

View File

@ -6,12 +6,7 @@ process.env.BABEL_ENV = "test";
process.env.NODE_ENV = "test"; process.env.NODE_ENV = "test";
process.env.PUBLIC_URL = ""; process.env.PUBLIC_URL = "";
// Makes the script crash on unhandled rejections instead of silently require("../src/tools/entry");
// ignoring them. In the future, promise rejections that are not handled will
// terminate the Node.js process with a non-zero exit code.
process.on("unhandledRejection", (err) => {
throw err;
});
// Ensure environment variables are read. // Ensure environment variables are read.
require("../config/env"); require("../config/env");

11
src/tools/entry.js Normal file
View File

@ -0,0 +1,11 @@
// @flow
//
// Common entry point module. This module should be required by every
// module that is intended to be run as a standalone application.
// Makes the script crash on unhandled rejections instead of silently
// ignoring them. In the future, promise rejections that are not handled will
// terminate the Node.js process with a non-zero exit code.
process.on("unhandledRejection", (err) => {
throw err;
});

View File

@ -7,13 +7,6 @@ import {promisify} from "util";
import {Graph} from "../../core/graph"; import {Graph} from "../../core/graph";
// Makes the script crash on unhandled rejections instead of silently
// ignoring them. In the future, promise rejections that are not handled will
// terminate the Node.js process with a non-zero exit code.
process.on("unhandledRejection", (err) => {
throw err;
});
export default class CombineCommand extends Command { export default class CombineCommand extends Command {
static description = static description =
"combine multiple contribution graphs into one big graph"; "combine multiple contribution graphs into one big graph";

View File

@ -13,13 +13,6 @@ import {
const execDependencyGraph = require("../../../tools/execDependencyGraph") const execDependencyGraph = require("../../../tools/execDependencyGraph")
.default; .default;
// Makes the script crash on unhandled rejections instead of silently
// ignoring them. In the future, promise rejections that are not handled will
// terminate the Node.js process with a non-zero exit code.
process.on("unhandledRejection", (err) => {
throw err;
});
export default class GraphCommand extends Command { export default class GraphCommand extends Command {
static description = `\ static description = `\
create the contribution graph for a repository create the contribution graph for a repository

View File

@ -9,13 +9,6 @@ import createGitGraph from "../../plugins/git/cloneGitGraph";
import createGithubGraph from "../../plugins/github/fetchGithubGraph"; import createGithubGraph from "../../plugins/github/fetchGithubGraph";
import {pluginNames} from "../common"; import {pluginNames} from "../common";
// Makes the script crash on unhandled rejections instead of silently
// ignoring them. In the future, promise rejections that are not handled will
// terminate the Node.js process with a non-zero exit code.
process.on("unhandledRejection", (err) => {
throw err;
});
export default class PluginGraphCommand extends Command { export default class PluginGraphCommand extends Command {
static description = "create the contribution graph for a single plugin"; static description = "create the contribution graph for a single plugin";

View File

@ -8,13 +8,6 @@ import {choosePort} from "react-dev-utils/WebpackDevServerUtils";
import apiApp from "../../app/apiApp"; import apiApp from "../../app/apiApp";
import {sourcecredDirectoryFlag} from "../common"; import {sourcecredDirectoryFlag} from "../common";
// Makes the script crash on unhandled rejections instead of silently
// ignoring them. In the future, promise rejections that are not handled will
// terminate the Node.js process with a non-zero exit code.
process.on("unhandledRejection", (err) => {
throw err;
});
const DEFAULT_PORT = parseInt(process.env.PORT, 10) || 4000; const DEFAULT_PORT = parseInt(process.env.PORT, 10) || 4000;
const HOST = process.env.HOST || "0.0.0.0"; const HOST = process.env.HOST || "0.0.0.0";

View File

@ -1,4 +1,5 @@
// @flow // @flow
require("../../tools/entry");
require("@oclif/command") require("@oclif/command")
.run() .run()
.catch(require("@oclif/errors/handle")); .catch(require("@oclif/errors/handle"));