module: fix module preloading when cwd is ENOENT
authorBradley Meck <bradley.meck@gmail.com>
Wed, 12 Aug 2015 00:25:49 +0000 (20:25 -0400)
committerJeremiah Senkpiel <fishrock123@rocketmail.com>
Mon, 24 Aug 2015 14:46:14 +0000 (10:46 -0400)
Fixes a regression from 5759722cfacf17cc79651c81801a5e03521db053
that prevented modules from being preloaded if the cwd does not exist.
Absolute and builtin modules now preload correctly again.

Refs: https://github.com/nodejs/node/issues/1803
PR-URL: https://github.com/nodejs/node/pull/2353
Reviewed-By: Jeremiah Senkpiel <fishrock123@rockemail.com>
lib/module.js
test/parallel/test-cwd-enoent-preload.js [new file with mode: 0644]

index fa7d5eb..aaa6220 100644 (file)
@@ -515,9 +515,16 @@ Module._preloadModules = function(requests) {
   // in the current working directory. This seeds the search path for
   // preloaded modules.
   var parent = new Module('internal/preload', null);
-  parent.paths = Module._nodeModulePaths(process.cwd());
+  try {
+    parent.paths = Module._nodeModulePaths(process.cwd());
+  }
+  catch (e) {
+    if (e.code !== 'ENOENT') {
+      throw e;
+    }
+  }
   requests.forEach(function(request) {
-    Module._load(request, parent, false);
+    parent.require(request);
   });
 };
 
diff --git a/test/parallel/test-cwd-enoent-preload.js b/test/parallel/test-cwd-enoent-preload.js
new file mode 100644 (file)
index 0000000..2dde3f0
--- /dev/null
@@ -0,0 +1,28 @@
+'use strict';
+const common = require('../common');
+const assert = require('assert');
+const fs = require('fs');
+const spawn = require('child_process').spawn;
+
+// Fails with EINVAL on SmartOS, EBUSY on Windows.
+if (process.platform === 'sunos' || common.isWindows) {
+  console.log('1..0 # Skipped: cannot rmdir current working directory');
+  return;
+}
+
+const dirname = common.tmpDir + '/cwd-does-not-exist-' + process.pid;
+const abspathFile = require('path').join(common.fixturesDir, 'a.js');
+common.refreshTmpDir();
+fs.mkdirSync(dirname);
+process.chdir(dirname);
+fs.rmdirSync(dirname);
+
+
+const proc = spawn(process.execPath, ['-r', abspathFile, '-e', '0']);
+proc.stdout.pipe(process.stdout);
+proc.stderr.pipe(process.stderr);
+
+proc.once('exit', common.mustCall(function(exitCode, signalCode) {
+  assert.strictEqual(exitCode, 0);
+  assert.strictEqual(signalCode, null);
+}));