End metro server gracefully when there are some edge errors

Summary: This diff fixes a couple of edge cases that caused Metro to keep the process running when there were some specific errors (specially around the `dependencies` command and the transformer path).

Reviewed By: jrwats

Differential Revision: D9551834

fbshipit-source-id: 959cefcec9e2687dff89c94a871ae74c50d2dd77
This commit is contained in:
Rafael Oleza 2018-08-30 03:22:17 -07:00 committed by Facebook Github Bot
parent f9e823fb5a
commit f661e0fb6e

View File

@ -44,19 +44,18 @@ async function dependencies(argv, configPromise, args, packagerInstance) {
? fs.createWriteStream(args.output) ? fs.createWriteStream(args.output)
: process.stdout; : process.stdout;
return Promise.resolve( const deps = packagerInstance
(packagerInstance ? await packagerInstance.getOrderedDependencyPaths(options)
? packagerInstance.getOrderedDependencyPaths(options) : await Metro.getOrderedDependencyPaths(config, options);
: Metro.getOrderedDependencyPaths(config, options)
).then(deps => {
deps.forEach(modulePath => { deps.forEach(modulePath => {
// Temporary hack to disable listing dependencies not under this directory. // Temporary hack to disable listing dependencies not under this directory.
// Long term, we need either // Long term, we need either
// (a) JS code to not depend on anything outside this directory, or // (a) JS code to not depend on anything outside this directory, or
// (b) Come up with a way to declare this dependency in Buck. // (b) Come up with a way to declare this dependency in Buck.
const isInsideProjectRoots = const isInsideProjectRoots =
config.watchFolders.filter(root => modulePath.startsWith(root)) config.watchFolders.filter(root => modulePath.startsWith(root)).length >
.length > 0; 0;
if (isInsideProjectRoots) { if (isInsideProjectRoots) {
outStream.write(modulePath + '\n'); outStream.write(modulePath + '\n');
@ -65,8 +64,6 @@ async function dependencies(argv, configPromise, args, packagerInstance) {
return writeToFile return writeToFile
? denodeify(outStream.end).bind(outStream)() ? denodeify(outStream.end).bind(outStream)()
: Promise.resolve(); : Promise.resolve();
}),
);
} }
module.exports = { module.exports = {