diff options
author | Florian Dold <florian.dold@gmail.com> | 2017-05-28 00:38:50 +0200 |
---|---|---|
committer | Florian Dold <florian.dold@gmail.com> | 2017-05-28 00:40:43 +0200 |
commit | 7fff4499fd915bcea3fa93b1aa8b35f4fe7a6027 (patch) | |
tree | 6de9a1aebd150a23b7f8c273ec657a5d0a18fe3e /node_modules/resolve/test/resolver.js | |
parent | 963b7a41feb29cc4be090a2446bdfe0c1f1bcd81 (diff) |
add linting (and some initial fixes)
Diffstat (limited to 'node_modules/resolve/test/resolver.js')
-rw-r--r-- | node_modules/resolve/test/resolver.js | 316 |
1 files changed, 181 insertions, 135 deletions
diff --git a/node_modules/resolve/test/resolver.js b/node_modules/resolve/test/resolver.js index 5bbb05f90..adde54441 100644 --- a/node_modules/resolve/test/resolver.js +++ b/node_modules/resolve/test/resolver.js @@ -3,279 +3,325 @@ var test = require('tape'); var resolve = require('../'); test('async foo', function (t) { - t.plan(9); - var dir = __dirname + '/resolver'; - - resolve('./foo', { basedir : dir }, function (err, res, pkg) { + t.plan(10); + var dir = path.join(__dirname, 'resolver'); + + resolve('./foo', { basedir: dir }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/foo.js'); - t.equal(pkg.name, 'resolve'); + t.equal(res, path.join(dir, 'foo.js')); + t.equal(pkg && pkg.name, 'resolve'); }); - - resolve('./foo.js', { basedir : dir }, function (err, res, pkg) { + + resolve('./foo.js', { basedir: dir }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/foo.js'); - t.equal(pkg.name, 'resolve'); + t.equal(res, path.join(dir, 'foo.js')); + t.equal(pkg && pkg.name, 'resolve'); }); - - resolve('./foo', { basedir : dir, package: { main: 'resolver' } }, function (err, res, pkg) { + + resolve('./foo', { basedir: dir, 'package': { main: 'resolver' } }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/foo.js'); - t.equal(pkg.main, 'resolver'); + t.equal(res, path.join(dir, 'foo.js')); + t.equal(pkg && pkg.main, 'resolver'); }); - - resolve('./foo.js', { basedir : dir, package: { main: 'resolver' } }, function (err, res, pkg) { + + resolve('./foo.js', { basedir: dir, 'package': { main: 'resolver' } }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/foo.js'); + t.equal(res, path.join(dir, 'foo.js')); t.equal(pkg.main, 'resolver'); }); - - resolve('foo', { basedir : dir }, function (err) { + + resolve('foo', { basedir: dir }, function (err) { t.equal(err.message, "Cannot find module 'foo' from '" + path.resolve(dir) + "'"); + t.equal(err.code, 'MODULE_NOT_FOUND'); }); }); test('bar', function (t) { t.plan(6); - var dir = __dirname + '/resolver'; - - resolve('foo', { basedir : dir + '/bar' }, function (err, res, pkg) { + var dir = path.join(__dirname, 'resolver'); + + resolve('foo', { basedir: dir + '/bar' }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/bar/node_modules/foo/index.js'); + t.equal(res, path.join(dir, 'bar/node_modules/foo/index.js')); t.equal(pkg, undefined); }); - - resolve('foo', { basedir : dir + '/bar' }, function (err, res, pkg) { + + resolve('foo', { basedir: dir + '/bar' }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/bar/node_modules/foo/index.js'); + t.equal(res, path.join(dir, 'bar/node_modules/foo/index.js')); t.equal(pkg, undefined); }); - - resolve('foo', { basedir : dir + '/bar', package: { main: 'bar' } }, function (err, res, pkg) { + + resolve('foo', { basedir: dir + '/bar', 'package': { main: 'bar' } }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/bar/node_modules/foo/index.js'); + t.equal(res, path.join(dir, 'bar/node_modules/foo/index.js')); t.equal(pkg, undefined); }); }); test('baz', function (t) { t.plan(4); - var dir = __dirname + '/resolver'; - - resolve('./baz', { basedir : dir }, function (err, res, pkg) { + var dir = path.join(__dirname, 'resolver'); + + resolve('./baz', { basedir: dir }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/baz/quux.js'); + t.equal(res, path.join(dir, 'baz/quux.js')); t.equal(pkg.main, 'quux.js'); }); - - resolve('./baz', { basedir : dir, package: { main: 'resolver' } }, function (err, res, pkg) { + + resolve('./baz', { basedir: dir, 'package': { main: 'resolver' } }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/baz/quux.js'); + t.equal(res, path.join(dir, 'baz/quux.js')); t.equal(pkg.main, 'quux.js'); }); }); test('biz', function (t) { t.plan(24); - var dir = __dirname + '/resolver/biz/node_modules'; - - resolve('./grux', { basedir : dir }, function (err, res, pkg) { + var dir = path.join(__dirname, 'resolver/biz/node_modules'); + + resolve('./grux', { basedir: dir }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/grux/index.js'); + t.equal(res, path.join(dir, 'grux/index.js')); t.equal(pkg, undefined); }); - - resolve('./grux', { basedir : dir, package: { main: 'biz' } }, function (err, res, pkg) { + + resolve('./grux', { basedir: dir, 'package': { main: 'biz' } }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/grux/index.js'); + t.equal(res, path.join(dir, 'grux/index.js')); t.equal(pkg.main, 'biz'); }); - - resolve('./garply', { basedir : dir }, function (err, res, pkg) { + + resolve('./garply', { basedir: dir }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/garply/lib/index.js'); + t.equal(res, path.join(dir, 'garply/lib/index.js')); t.equal(pkg.main, './lib'); }); - - resolve('./garply', { basedir : dir, package: { main: 'biz' } }, function (err, res, pkg) { + + resolve('./garply', { basedir: dir, 'package': { main: 'biz' } }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/garply/lib/index.js'); + t.equal(res, path.join(dir, 'garply/lib/index.js')); t.equal(pkg.main, './lib'); }); - - resolve('tiv', { basedir : dir + '/grux' }, function (err, res, pkg) { + + resolve('tiv', { basedir: dir + '/grux' }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/tiv/index.js'); + t.equal(res, path.join(dir, 'tiv/index.js')); t.equal(pkg, undefined); }); - - resolve('tiv', { basedir : dir + '/grux', package: { main: 'grux' } }, function (err, res, pkg) { + + resolve('tiv', { basedir: dir + '/grux', 'package': { main: 'grux' } }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/tiv/index.js'); + t.equal(res, path.join(dir, 'tiv/index.js')); t.equal(pkg, undefined); }); - - resolve('tiv', { basedir : dir + '/garply' }, function (err, res, pkg) { + + resolve('tiv', { basedir: dir + '/garply' }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/tiv/index.js'); + t.equal(res, path.join(dir, 'tiv/index.js')); t.equal(pkg, undefined); }); - - resolve('tiv', { basedir : dir + '/garply', package: { main: './lib' } }, function (err, res, pkg) { + + resolve('tiv', { basedir: dir + '/garply', 'package': { main: './lib' } }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/tiv/index.js'); + t.equal(res, path.join(dir, 'tiv/index.js')); t.equal(pkg, undefined); }); - - resolve('grux', { basedir : dir + '/tiv' }, function (err, res, pkg) { + + resolve('grux', { basedir: dir + '/tiv' }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/grux/index.js'); + t.equal(res, path.join(dir, 'grux/index.js')); t.equal(pkg, undefined); }); - - resolve('grux', { basedir : dir + '/tiv', package: { main: 'tiv' } }, function (err, res, pkg) { + + resolve('grux', { basedir: dir + '/tiv', 'package': { main: 'tiv' } }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/grux/index.js'); + t.equal(res, path.join(dir, 'grux/index.js')); t.equal(pkg, undefined); }); - - resolve('garply', { basedir : dir + '/tiv' }, function (err, res, pkg) { + + resolve('garply', { basedir: dir + '/tiv' }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/garply/lib/index.js'); + t.equal(res, path.join(dir, 'garply/lib/index.js')); t.equal(pkg.main, './lib'); }); - - resolve('garply', { basedir : dir + '/tiv', package: { main: 'tiv' } }, function (err, res, pkg) { + + resolve('garply', { basedir: dir + '/tiv', 'package': { main: 'tiv' } }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/garply/lib/index.js'); + t.equal(res, path.join(dir, 'garply/lib/index.js')); t.equal(pkg.main, './lib'); }); }); test('quux', function (t) { t.plan(2); - var dir = __dirname + '/resolver/quux'; - - resolve('./foo', { basedir : dir, package: { main: 'quux' } }, function (err, res, pkg) { + var dir = path.join(__dirname, 'resolver/quux'); + + resolve('./foo', { basedir: dir, 'package': { main: 'quux' } }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/foo/index.js'); + t.equal(res, path.join(dir, 'foo/index.js')); t.equal(pkg.main, 'quux'); }); }); test('normalize', function (t) { t.plan(2); - var dir = __dirname + '/resolver/biz/node_modules/grux'; - - resolve('../grux', { basedir : dir }, function (err, res, pkg) { + var dir = path.join(__dirname, 'resolver/biz/node_modules/grux'); + + resolve('../grux', { basedir: dir }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/index.js'); + t.equal(res, path.join(dir, 'index.js')); t.equal(pkg, undefined); }); }); test('cup', function (t) { - t.plan(3); - var dir = __dirname + '/resolver'; - - resolve('./cup', { basedir : dir, extensions : [ '.js', '.coffee' ] }, - function (err, res) { + t.plan(4); + var dir = path.join(__dirname, 'resolver'); + + resolve('./cup', { basedir: dir, extensions: ['.js', '.coffee'] }, function (err, res) { if (err) t.fail(err); - t.equal(res, dir + '/cup.coffee'); + t.equal(res, path.join(dir, 'cup.coffee')); }); - - resolve('./cup.coffee', { basedir : dir }, function (err, res) { + + resolve('./cup.coffee', { basedir: dir }, function (err, res) { if (err) t.fail(err); - t.equal(res, dir + '/cup.coffee'); + t.equal(res, path.join(dir, 'cup.coffee')); }); - - resolve('./cup', { basedir : dir, extensions : [ '.js' ] }, - function (err, res) { + + resolve('./cup', { basedir: dir, extensions: ['.js'] }, function (err, res) { t.equal(err.message, "Cannot find module './cup' from '" + path.resolve(dir) + "'"); + t.equal(err.code, 'MODULE_NOT_FOUND'); }); }); test('mug', function (t) { t.plan(3); - var dir = __dirname + '/resolver'; - - resolve('./mug', { basedir : dir }, function (err, res) { + var dir = path.join(__dirname, 'resolver'); + + resolve('./mug', { basedir: dir }, function (err, res) { if (err) t.fail(err); - t.equal(res, dir + '/mug.js'); + t.equal(res, path.join(dir, 'mug.js')); }); - - resolve('./mug', { basedir : dir, extensions : [ '.coffee', '.js' ] }, - function (err, res) { + + resolve('./mug', { basedir: dir, extensions: ['.coffee', '.js'] }, function (err, res) { if (err) t.fail(err); - t.equal(res, dir + '/mug.coffee'); + t.equal(res, path.join(dir, '/mug.coffee')); }); - - resolve('./mug', { basedir : dir, extensions : [ '.js', '.coffee' ] }, - function (err, res) { - t.equal(res, dir + '/mug.js'); + + resolve('./mug', { basedir: dir, extensions: ['.js', '.coffee'] }, function (err, res) { + t.equal(res, path.join(dir, '/mug.js')); }); }); test('other path', function (t) { - t.plan(4); - var resolverDir = __dirname + '/resolver'; - var dir = resolverDir + '/bar'; - var otherDir = resolverDir + '/other_path'; - - resolve('root', { basedir : dir, paths: [otherDir] }, function (err, res) { + t.plan(6); + var resolverDir = path.join(__dirname, 'resolver'); + var dir = path.join(resolverDir, 'bar'); + var otherDir = path.join(resolverDir, 'other_path'); + + resolve('root', { basedir: dir, paths: [otherDir] }, function (err, res) { if (err) t.fail(err); - t.equal(res, resolverDir + '/other_path/root.js'); + t.equal(res, path.join(resolverDir, 'other_path/root.js')); }); - - resolve('lib/other-lib', { basedir : dir, paths: [otherDir] }, - function (err, res) { + + resolve('lib/other-lib', { basedir: dir, paths: [otherDir] }, function (err, res) { if (err) t.fail(err); - t.equal(res, resolverDir + '/other_path/lib/other-lib.js'); + t.equal(res, path.join(resolverDir, 'other_path/lib/other-lib.js')); }); - - resolve('root', { basedir : dir, }, function (err, res) { + + resolve('root', { basedir: dir }, function (err, res) { t.equal(err.message, "Cannot find module 'root' from '" + path.resolve(dir) + "'"); + t.equal(err.code, 'MODULE_NOT_FOUND'); }); - - resolve('zzz', { basedir : dir, paths: [otherDir] }, function (err, res) { + + resolve('zzz', { basedir: dir, paths: [otherDir] }, function (err, res) { t.equal(err.message, "Cannot find module 'zzz' from '" + path.resolve(dir) + "'"); + t.equal(err.code, 'MODULE_NOT_FOUND'); }); }); test('incorrect main', function (t) { - t.plan(1) + t.plan(1); - var resolverDir = __dirname + '/resolver'; - var dir = resolverDir + '/incorrect_main'; + var resolverDir = path.join(__dirname, 'resolver'); + var dir = path.join(resolverDir, 'incorrect_main'); - resolve('./incorrect_main', { basedir : resolverDir }, function (err, res, pkg) { + resolve('./incorrect_main', { basedir: resolverDir }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, dir + '/index.js'); + t.equal(res, path.join(dir, 'index.js')); }); }); test('without basedir', function (t) { t.plan(1); - var dir = __dirname + '/resolver/without_basedir'; - var tester = require(dir + '/main.js'); + var dir = path.join(__dirname, 'resolver/without_basedir'); + var tester = require(path.join(dir, 'main.js')); - tester(t, function (err, res, pkg){ + tester(t, function (err, res, pkg) { if (err) { - t.fail(err); - } else { - t.equal(res, dir + '/node_modules/mymodule.js'); - } + t.fail(err); + } else { + t.equal(res, path.join(dir, 'node_modules/mymodule.js')); + } }); }); test('#25: node modules with the same name as node stdlib modules', function (t) { t.plan(1); - var resolverDir = __dirname + '/resolver/punycode'; + var resolverDir = path.join(__dirname, 'resolver/punycode'); - resolve('punycode', { basedir : resolverDir }, function (err, res, pkg) { + resolve('punycode', { basedir: resolverDir }, function (err, res, pkg) { if (err) t.fail(err); - t.equal(res, resolverDir + '/node_modules/punycode/index.js'); + t.equal(res, path.join(resolverDir, 'node_modules/punycode/index.js')); }); }); + +test('#52 - incorrectly resolves module-paths like "./someFolder/" when there is a file of the same name', function (t) { + t.plan(2); + + var dir = path.join(__dirname, 'resolver'); + + resolve('./foo', { basedir: path.join(dir, 'same_names') }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'same_names/foo.js')); + }); + + resolve('./foo/', { basedir: path.join(dir, 'same_names') }, function (err, res, pkg) { + if (err) t.fail(err); + t.equal(res, path.join(dir, 'same_names/foo/index.js')); + }); +}); + +test('async: #121 - treating an existing file as a dir when no basedir', function (t) { + var testFile = path.basename(__filename); + + t.test('sanity check', function (st) { + st.plan(1); + resolve('./' + testFile, function (err, res, pkg) { + if (err) t.fail(err); + st.equal(res, __filename, 'sanity check'); + }); + }); + + t.test('with a fake directory', function (st) { + st.plan(4); + + resolve('./' + testFile + '/blah', function (err, res, pkg) { + st.ok(err, 'there is an error'); + st.notOk(res, 'no result'); + + st.equal(err && err.code, 'MODULE_NOT_FOUND', 'error code matches require.resolve'); + st.equal( + err && err.message, + 'Cannot find module \'./' + testFile + '/blah\' from \'' + __dirname + '\'', + 'can not find nonexistent module' + ); + st.end(); + }); + }); + + t.end(); +}); |