From e8a977f55b325fdbde3e9860ad78937818e0f0c5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Miroslav=20Bajto=C5=A1?= Date: Tue, 31 Jan 2017 10:31:54 +0100 Subject: [PATCH] Fix datasource to report connector-loading errors Before this change, when resolving full connector path, all errors were ignored. As a result, when the connector was installed but not correctly built (e.g. loopback-connector-db2 which uses a native addon), a very confusing message was reported by LoopBack. In this commit, I am fixing the code handling `require()` errors to ignore only MODULE_NOT_FOUND errors that contain the name of the required module. --- lib/datasource.js | 11 +++++++++- package.json | 1 + test/datasource.test.js | 20 +++++++++++++++++++ .../loopback-connector-throwing/index.js | 8 ++++++++ .../loopback-connector-throwing/package.json | 5 +++++ 5 files changed, 44 insertions(+), 1 deletion(-) create mode 100644 test/fixtures/loopback-connector-throwing/index.js create mode 100644 test/fixtures/loopback-connector-throwing/package.json diff --git a/lib/datasource.js b/lib/datasource.js index 7e4e9729..4ba6c15c 100644 --- a/lib/datasource.js +++ b/lib/datasource.js @@ -224,7 +224,16 @@ function tryModules(names, loader) { try { mod = loader(names[m]); } catch (e) { - /* ignore */ + var notFound = e.code === 'MODULE_NOT_FOUND' && + e.message && e.message.indexOf(names[m]) > 0; + + if (notFound) { + debug('Module %s not found, will try another candidate.', names[m]); + continue; + } + + debug('Cannot load connector %s: %s', names[m], e.stack || e); + throw e; } if (mod) { break; diff --git a/package.json b/package.json index 7826e7e5..70aec23f 100644 --- a/package.json +++ b/package.json @@ -34,6 +34,7 @@ "async-iterators": "^0.2.2", "eslint": "^3.12.2", "eslint-config-loopback": "^8.0.0", + "loopback-connector-throwing": "file:./test/fixtures/loopback-connector-throwing", "mocha": "^3.2.0", "should": "^8.4.0" }, diff --git a/test/datasource.test.js b/test/datasource.test.js index 55a92ce9..2a35f279 100644 --- a/test/datasource.test.js +++ b/test/datasource.test.js @@ -25,4 +25,24 @@ describe('DataSource', function() { }); }).should.throw(/loopback-connector-throwing/); }); + + it('reports helpful error when connector init via short name throws', function() { + (function() { + // this is what LoopBack does + return new DataSource({ + name: 'dsname', + connector: 'throwing', + }); + }).should.throw(/expected test error/); + }); + + it('reports helpful error when connector init via long name throws', function() { + (function() { + // this is what LoopBack does + return new DataSource({ + name: 'dsname', + connector: 'loopback-connector-throwing', + }); + }).should.throw(/expected test error/); + }); }); diff --git a/test/fixtures/loopback-connector-throwing/index.js b/test/fixtures/loopback-connector-throwing/index.js new file mode 100644 index 00000000..f1079a05 --- /dev/null +++ b/test/fixtures/loopback-connector-throwing/index.js @@ -0,0 +1,8 @@ +// Copyright IBM Corp. 2013,2016. All Rights Reserved. +// Node module: loopback-datasource-juggler +// This file is licensed under the MIT License. +// License text available at https://opensource.org/licenses/MIT + +'use strict'; + +throw new Error('expected test error'); diff --git a/test/fixtures/loopback-connector-throwing/package.json b/test/fixtures/loopback-connector-throwing/package.json new file mode 100644 index 00000000..e1ca8f24 --- /dev/null +++ b/test/fixtures/loopback-connector-throwing/package.json @@ -0,0 +1,5 @@ +{ + "name": "loopback-connector-throwing", + "version": "1.0.0", + "description": "A dummy connector that throws at initialization time." +}