diff --git a/lib/repl.js b/lib/repl.js index 0d237997c8f801..a29e0af66e5a9d 100644 --- a/lib/repl.js +++ b/lib/repl.js @@ -792,7 +792,7 @@ function complete(line, callback) { completeOn = match[1]; var subdir = match[2] || ''; filter = match[1]; - var dir, files, f, name, base, ext, abs, subfiles, s; + var dir, files, f, name, base, ext, abs, subfiles, s, isDirectory; group = []; let paths = []; @@ -821,23 +821,26 @@ function complete(line, callback) { // Exclude versioned names that 'npm' installs. continue; } - if (exts.indexOf(ext) !== -1) { - if (!subdir || base !== 'index') { - group.push(subdir + base); - } - } else { - abs = path.resolve(dir, name); + abs = path.resolve(dir, name); + try { + isDirectory = fs.statSync(abs).isDirectory(); + } catch (e) { + continue; + } + if (isDirectory) { + group.push(subdir + name + '/'); try { - if (fs.statSync(abs).isDirectory()) { - group.push(subdir + name + '/'); - subfiles = fs.readdirSync(abs); - for (s = 0; s < subfiles.length; s++) { - if (indexRe.test(subfiles[s])) { - group.push(subdir + name); - } - } + subfiles = fs.readdirSync(abs); + } catch (e) { + continue; + } + for (s = 0; s < subfiles.length; s++) { + if (indexRe.test(subfiles[s])) { + group.push(subdir + name); } - } catch (e) {} + } + } else if (exts.includes(ext) && (!subdir || base !== 'index')) { + group.push(subdir + base); } } } diff --git a/test/fixtures/repl-folder-extensions/foo.js/index.js b/test/fixtures/repl-folder-extensions/foo.js/index.js new file mode 100644 index 00000000000000..e69de29bb2d1d6 diff --git a/test/parallel/test-repl-tab-complete.js b/test/parallel/test-repl-tab-complete.js index 85bcaf9e618ebc..da8db7a57b43ef 100644 --- a/test/parallel/test-repl-tab-complete.js +++ b/test/parallel/test-repl-tab-complete.js @@ -279,6 +279,16 @@ testMe.complete('require(\'n', common.mustCall(function(error, data) { }); }); + { + const path = '../fixtures/repl-folder-extensions/f'; + testMe.complete(`require('${path}`, common.mustCall((err, data) => { + assert.ifError(err); + assert.strictEqual(data.length, 2); + assert.strictEqual(data[1], path); + assert.ok(data[0].includes('../fixtures/repl-folder-extensions/foo.js')); + })); + } + process.chdir(cwd); }