2015-05-19 19:00:06 +08:00
|
|
|
'use strict';
|
2016-02-09 08:32:13 +08:00
|
|
|
require('../common');
|
2010-12-05 07:20:34 +08:00
|
|
|
var assert = require('assert');
|
2010-12-05 06:45:52 +08:00
|
|
|
var path = require('path');
|
|
|
|
var fs = require('fs');
|
2009-09-28 18:06:30 +08:00
|
|
|
|
2015-09-27 06:49:04 +08:00
|
|
|
console.error('load test-module-loading.js');
|
2009-09-28 18:06:30 +08:00
|
|
|
|
2011-02-03 01:56:32 +08:00
|
|
|
// assert that this is the main module.
|
|
|
|
assert.equal(require.main.id, '.', 'main module should have id of \'.\'');
|
|
|
|
assert.equal(require.main, module, 'require.main should === module');
|
|
|
|
assert.equal(process.mainModule, module,
|
|
|
|
'process.mainModule should === module');
|
|
|
|
// assert that it's *not* the main module in the required module.
|
|
|
|
require('../fixtures/not-main-module.js');
|
|
|
|
|
2010-12-02 06:31:20 +08:00
|
|
|
// require a file with a request that includes the extension
|
2010-12-05 06:45:52 +08:00
|
|
|
var a_js = require('../fixtures/a.js');
|
2010-12-02 06:31:20 +08:00
|
|
|
assert.equal(42, a_js.number);
|
|
|
|
|
|
|
|
// require a file without any extensions
|
2010-12-05 06:45:52 +08:00
|
|
|
var foo_no_ext = require('../fixtures/foo');
|
|
|
|
assert.equal('ok', foo_no_ext.foo);
|
2010-12-02 06:31:20 +08:00
|
|
|
|
2010-12-05 06:45:52 +08:00
|
|
|
var a = require('../fixtures/a');
|
|
|
|
var c = require('../fixtures/b/c');
|
|
|
|
var d = require('../fixtures/b/d');
|
|
|
|
var d2 = require('../fixtures/b/d');
|
2009-11-03 04:21:02 +08:00
|
|
|
// Absolute
|
2010-12-05 06:45:52 +08:00
|
|
|
var d3 = require(path.join(__dirname, '../fixtures/b/d'));
|
2009-11-03 04:21:02 +08:00
|
|
|
// Relative
|
2010-12-05 06:45:52 +08:00
|
|
|
var d4 = require('../fixtures/b/d');
|
2009-06-08 21:30:10 +08:00
|
|
|
|
2010-12-05 06:45:52 +08:00
|
|
|
assert.equal(false, false, 'testing the test program.');
|
2009-06-08 21:30:10 +08:00
|
|
|
|
2016-02-09 08:32:13 +08:00
|
|
|
assert.ok(a.A instanceof Function);
|
2010-12-05 06:45:52 +08:00
|
|
|
assert.equal('A', a.A());
|
2009-06-08 21:30:10 +08:00
|
|
|
|
2016-02-09 08:32:13 +08:00
|
|
|
assert.ok(a.C instanceof Function);
|
2010-12-05 06:45:52 +08:00
|
|
|
assert.equal('C', a.C());
|
2009-06-08 21:30:10 +08:00
|
|
|
|
2016-02-09 08:32:13 +08:00
|
|
|
assert.ok(a.D instanceof Function);
|
2010-12-05 06:45:52 +08:00
|
|
|
assert.equal('D', a.D());
|
2009-06-08 21:30:10 +08:00
|
|
|
|
2016-02-09 08:32:13 +08:00
|
|
|
assert.ok(d.D instanceof Function);
|
2010-12-05 06:45:52 +08:00
|
|
|
assert.equal('D', d.D());
|
2009-06-08 21:30:10 +08:00
|
|
|
|
2016-02-09 08:32:13 +08:00
|
|
|
assert.ok(d2.D instanceof Function);
|
2010-12-05 06:45:52 +08:00
|
|
|
assert.equal('D', d2.D());
|
2009-06-08 22:17:33 +08:00
|
|
|
|
2016-02-09 08:32:13 +08:00
|
|
|
assert.ok(d3.D instanceof Function);
|
2010-12-05 06:45:52 +08:00
|
|
|
assert.equal('D', d3.D());
|
2009-11-02 07:34:16 +08:00
|
|
|
|
2016-02-09 08:32:13 +08:00
|
|
|
assert.ok(d4.D instanceof Function);
|
2010-12-05 06:45:52 +08:00
|
|
|
assert.equal('D', d4.D());
|
2009-11-03 04:21:02 +08:00
|
|
|
|
2015-05-19 19:00:06 +08:00
|
|
|
assert.ok((new a.SomeClass()) instanceof c.SomeClass);
|
2010-02-11 19:09:46 +08:00
|
|
|
|
2015-09-27 06:49:04 +08:00
|
|
|
console.error('test index.js modules ids and relative loading');
|
2016-01-14 04:42:45 +08:00
|
|
|
const one = require('../fixtures/nested-index/one');
|
|
|
|
const two = require('../fixtures/nested-index/two');
|
2009-12-22 23:24:32 +08:00
|
|
|
assert.notEqual(one.hello, two.hello);
|
|
|
|
|
2015-09-27 06:49:04 +08:00
|
|
|
console.error('test index.js in a folder with a trailing slash');
|
2016-01-14 04:42:45 +08:00
|
|
|
const three = require('../fixtures/nested-index/three');
|
|
|
|
const threeFolder = require('../fixtures/nested-index/three/');
|
|
|
|
const threeIndex = require('../fixtures/nested-index/three/index.js');
|
2011-01-28 05:14:47 +08:00
|
|
|
assert.equal(threeFolder, threeIndex);
|
|
|
|
assert.notEqual(threeFolder, three);
|
|
|
|
|
2015-09-27 06:49:04 +08:00
|
|
|
console.error('test package.json require() loading');
|
2016-10-19 20:18:33 +08:00
|
|
|
assert.equal(require('../fixtures/packages/index').ok, 'ok',
|
|
|
|
'Failed loading package');
|
2011-01-28 09:57:45 +08:00
|
|
|
assert.equal(require('../fixtures/packages/main').ok, 'ok',
|
|
|
|
'Failed loading package');
|
2011-02-18 04:00:39 +08:00
|
|
|
assert.equal(require('../fixtures/packages/main-index').ok, 'ok',
|
|
|
|
'Failed loading package with index.js in main subdir');
|
2011-01-28 09:57:45 +08:00
|
|
|
|
2015-09-27 06:49:04 +08:00
|
|
|
console.error('test cycles containing a .. path');
|
2016-01-14 04:42:45 +08:00
|
|
|
const root = require('../fixtures/cycles/root');
|
|
|
|
const foo = require('../fixtures/cycles/folder/foo');
|
2010-02-11 19:09:46 +08:00
|
|
|
assert.equal(root.foo, foo);
|
2009-12-22 23:24:32 +08:00
|
|
|
assert.equal(root.sayHello(), root.hello);
|
|
|
|
|
2015-09-27 06:49:04 +08:00
|
|
|
console.error('test node_modules folders');
|
2011-02-10 05:28:30 +08:00
|
|
|
// asserts are in the fixtures files themselves,
|
|
|
|
// since they depend on the folder structure.
|
|
|
|
require('../fixtures/node_modules/foo');
|
|
|
|
|
2015-09-27 06:49:04 +08:00
|
|
|
console.error('test name clashes');
|
2010-07-02 02:19:54 +08:00
|
|
|
// this one exists and should import the local module
|
2014-12-17 21:30:04 +08:00
|
|
|
var my_path = require('../fixtures/path');
|
2016-02-09 08:32:13 +08:00
|
|
|
assert.ok(my_path.path_func instanceof Function);
|
2010-07-02 02:19:54 +08:00
|
|
|
// this one does not exist and should throw
|
2015-05-19 19:00:06 +08:00
|
|
|
assert.throws(function() { require('./utils'); });
|
2010-07-02 02:19:54 +08:00
|
|
|
|
2009-12-19 06:58:04 +08:00
|
|
|
var errorThrown = false;
|
|
|
|
try {
|
2010-12-05 06:45:52 +08:00
|
|
|
require('../fixtures/throws_error');
|
2009-12-19 06:58:04 +08:00
|
|
|
} catch (e) {
|
|
|
|
errorThrown = true;
|
2010-12-05 06:45:52 +08:00
|
|
|
assert.equal('blah', e.message);
|
2009-12-19 06:58:04 +08:00
|
|
|
}
|
|
|
|
|
2010-01-16 20:51:57 +08:00
|
|
|
assert.equal(require('path').dirname(__filename), __dirname);
|
|
|
|
|
2015-09-27 06:49:04 +08:00
|
|
|
console.error('load custom file types with extensions');
|
2010-12-05 06:45:52 +08:00
|
|
|
require.extensions['.test'] = function(module, filename) {
|
2010-09-20 09:50:26 +08:00
|
|
|
var content = fs.readFileSync(filename).toString();
|
2010-12-05 06:45:52 +08:00
|
|
|
assert.equal('this is custom source\n', content);
|
|
|
|
content = content.replace('this is custom source',
|
|
|
|
'exports.test = \'passed\'');
|
2010-09-20 09:50:26 +08:00
|
|
|
module._compile(content, filename);
|
|
|
|
};
|
2010-03-08 12:35:39 +08:00
|
|
|
|
2010-12-05 06:45:52 +08:00
|
|
|
assert.equal(require('../fixtures/registerExt').test, 'passed');
|
2010-09-22 07:51:55 +08:00
|
|
|
// unknown extension, load as .js
|
2010-12-05 06:45:52 +08:00
|
|
|
assert.equal(require('../fixtures/registerExt.hello.world').test, 'passed');
|
2010-03-08 12:35:39 +08:00
|
|
|
|
2015-09-27 06:49:04 +08:00
|
|
|
console.error('load custom file types that return non-strings');
|
2010-12-05 06:45:52 +08:00
|
|
|
require.extensions['.test'] = function(module, filename) {
|
2010-09-20 09:50:26 +08:00
|
|
|
module.exports = {
|
2010-03-08 12:35:39 +08:00
|
|
|
custom: 'passed'
|
|
|
|
};
|
2010-09-20 09:50:26 +08:00
|
|
|
};
|
2010-03-08 12:35:39 +08:00
|
|
|
|
|
|
|
assert.equal(require('../fixtures/registerExt2').custom, 'passed');
|
|
|
|
|
2010-07-20 08:54:49 +08:00
|
|
|
assert.equal(require('../fixtures/foo').foo, 'ok',
|
2010-12-05 06:45:52 +08:00
|
|
|
'require module with no extension');
|
2010-07-20 08:54:49 +08:00
|
|
|
|
2010-08-05 04:45:52 +08:00
|
|
|
// Should not attempt to load a directory
|
|
|
|
try {
|
2010-12-05 06:45:52 +08:00
|
|
|
require('../fixtures/empty');
|
|
|
|
} catch (err) {
|
|
|
|
assert.equal(err.message, 'Cannot find module \'../fixtures/empty\'');
|
2010-08-05 04:45:52 +08:00
|
|
|
}
|
|
|
|
|
2010-08-05 05:55:24 +08:00
|
|
|
// Check load order is as expected
|
2015-09-27 06:49:04 +08:00
|
|
|
console.error('load order');
|
2010-08-05 05:55:24 +08:00
|
|
|
|
2016-01-14 04:42:45 +08:00
|
|
|
const loadOrder = '../fixtures/module-load-order/';
|
|
|
|
const msg = 'Load order incorrect.';
|
2010-08-05 05:55:24 +08:00
|
|
|
|
2010-09-20 09:50:26 +08:00
|
|
|
require.extensions['.reg'] = require.extensions['.js'];
|
|
|
|
require.extensions['.reg2'] = require.extensions['.js'];
|
2010-08-05 05:55:24 +08:00
|
|
|
|
2010-12-05 06:45:52 +08:00
|
|
|
assert.equal(require(loadOrder + 'file1').file1, 'file1', msg);
|
|
|
|
assert.equal(require(loadOrder + 'file2').file2, 'file2.js', msg);
|
2010-08-05 05:55:24 +08:00
|
|
|
try {
|
|
|
|
require(loadOrder + 'file3');
|
|
|
|
} catch (e) {
|
|
|
|
// Not a real .node module, but we know we require'd the right thing.
|
2011-11-05 08:48:24 +08:00
|
|
|
assert.ok(e.message.replace(/\\/g, '/').match(/file3\.node/));
|
2010-08-05 05:55:24 +08:00
|
|
|
}
|
2010-12-05 06:45:52 +08:00
|
|
|
assert.equal(require(loadOrder + 'file4').file4, 'file4.reg', msg);
|
|
|
|
assert.equal(require(loadOrder + 'file5').file5, 'file5.reg2', msg);
|
|
|
|
assert.equal(require(loadOrder + 'file6').file6, 'file6/index.js', msg);
|
2010-08-05 05:55:24 +08:00
|
|
|
try {
|
|
|
|
require(loadOrder + 'file7');
|
|
|
|
} catch (e) {
|
2011-11-05 08:48:24 +08:00
|
|
|
assert.ok(e.message.replace(/\\/g, '/').match(/file7\/index\.node/));
|
2010-08-05 05:55:24 +08:00
|
|
|
}
|
2010-12-05 06:45:52 +08:00
|
|
|
assert.equal(require(loadOrder + 'file8').file8, 'file8/index.reg', msg);
|
2010-08-05 05:55:24 +08:00
|
|
|
assert.equal(require(loadOrder + 'file9').file9, 'file9/index.reg2', msg);
|
|
|
|
|
2011-06-13 01:36:05 +08:00
|
|
|
|
2011-07-15 04:55:51 +08:00
|
|
|
// make sure that module.require() is the same as
|
|
|
|
// doing require() inside of that module.
|
|
|
|
var parent = require('../fixtures/module-require/parent/');
|
|
|
|
var child = require('../fixtures/module-require/child/');
|
|
|
|
assert.equal(child.loaded, parent.loaded);
|
|
|
|
|
|
|
|
|
2011-07-21 08:39:23 +08:00
|
|
|
// #1357 Loading JSON files with require()
|
|
|
|
var json = require('../fixtures/packages/main/package.json');
|
2016-04-20 06:37:45 +08:00
|
|
|
assert.deepStrictEqual(json, {
|
2011-10-05 06:08:18 +08:00
|
|
|
name: 'package-name',
|
|
|
|
version: '1.2.3',
|
|
|
|
main: 'package-main-module'
|
|
|
|
});
|
2011-07-21 08:39:23 +08:00
|
|
|
|
|
|
|
|
2012-03-13 01:18:29 +08:00
|
|
|
// now verify that module.children contains all the different
|
|
|
|
// modules that we've required, and that all of them contain
|
|
|
|
// the appropriate children, and so on.
|
|
|
|
|
|
|
|
var children = module.children.reduce(function red(set, child) {
|
2015-05-19 19:00:06 +08:00
|
|
|
var id = path.relative(path.dirname(__dirname), child.id);
|
2012-06-12 08:04:44 +08:00
|
|
|
id = id.replace(/\\/g, '/');
|
2012-03-13 01:18:29 +08:00
|
|
|
set[id] = child.children.reduce(red, {});
|
|
|
|
return set;
|
|
|
|
}, {});
|
|
|
|
|
2016-04-20 06:37:45 +08:00
|
|
|
assert.deepStrictEqual(children, {
|
2012-03-13 01:18:29 +08:00
|
|
|
'common.js': {},
|
|
|
|
'fixtures/not-main-module.js': {},
|
|
|
|
'fixtures/a.js': {
|
|
|
|
'fixtures/b/c.js': {
|
|
|
|
'fixtures/b/d.js': {},
|
|
|
|
'fixtures/b/package/index.js': {}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'fixtures/foo': {},
|
|
|
|
'fixtures/nested-index/one/index.js': {
|
|
|
|
'fixtures/nested-index/one/hello.js': {}
|
|
|
|
},
|
|
|
|
'fixtures/nested-index/two/index.js': {
|
|
|
|
'fixtures/nested-index/two/hello.js': {}
|
|
|
|
},
|
|
|
|
'fixtures/nested-index/three.js': {},
|
|
|
|
'fixtures/nested-index/three/index.js': {},
|
2016-10-19 20:18:33 +08:00
|
|
|
'fixtures/packages/index/index.js': {},
|
2012-03-13 01:18:29 +08:00
|
|
|
'fixtures/packages/main/package-main-module.js': {},
|
|
|
|
'fixtures/packages/main-index/package-main-module/index.js': {},
|
|
|
|
'fixtures/cycles/root.js': {
|
|
|
|
'fixtures/cycles/folder/foo.js': {}
|
|
|
|
},
|
|
|
|
'fixtures/node_modules/foo.js': {
|
|
|
|
'fixtures/node_modules/baz/index.js': {
|
|
|
|
'fixtures/node_modules/bar.js': {},
|
|
|
|
'fixtures/node_modules/baz/node_modules/asdf.js': {}
|
|
|
|
}
|
|
|
|
},
|
2014-12-17 21:30:04 +08:00
|
|
|
'fixtures/path.js': {},
|
2012-03-13 01:18:29 +08:00
|
|
|
'fixtures/throws_error.js': {},
|
|
|
|
'fixtures/registerExt.test': {},
|
|
|
|
'fixtures/registerExt.hello.world': {},
|
|
|
|
'fixtures/registerExt2.test': {},
|
|
|
|
'fixtures/empty.js': {},
|
|
|
|
'fixtures/module-load-order/file1': {},
|
|
|
|
'fixtures/module-load-order/file2.js': {},
|
|
|
|
'fixtures/module-load-order/file3.node': {},
|
|
|
|
'fixtures/module-load-order/file4.reg': {},
|
|
|
|
'fixtures/module-load-order/file5.reg2': {},
|
|
|
|
'fixtures/module-load-order/file6/index.js': {},
|
|
|
|
'fixtures/module-load-order/file7/index.node': {},
|
|
|
|
'fixtures/module-load-order/file8/index.reg': {},
|
|
|
|
'fixtures/module-load-order/file9/index.reg2': {},
|
|
|
|
'fixtures/module-require/parent/index.js': {
|
|
|
|
'fixtures/module-require/child/index.js': {
|
|
|
|
'fixtures/module-require/child/node_modules/target.js': {}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'fixtures/packages/main/package.json': {}
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2013-01-17 04:27:53 +08:00
|
|
|
// require() must take string, and must be truthy
|
|
|
|
assert.throws(function() {
|
|
|
|
console.error('require non-string');
|
|
|
|
require({ foo: 'bar' });
|
2016-04-01 10:50:29 +08:00
|
|
|
}, /path must be a string/);
|
2013-01-17 04:27:53 +08:00
|
|
|
|
|
|
|
assert.throws(function() {
|
|
|
|
console.error('require empty string');
|
|
|
|
require('');
|
2016-04-01 10:50:29 +08:00
|
|
|
}, /missing path/);
|
2013-01-17 04:27:53 +08:00
|
|
|
|
2011-10-15 07:08:36 +08:00
|
|
|
process.on('exit', function() {
|
2016-02-09 08:32:13 +08:00
|
|
|
assert.ok(a.A instanceof Function);
|
2010-12-05 06:45:52 +08:00
|
|
|
assert.equal('A done', a.A());
|
2009-06-08 22:17:33 +08:00
|
|
|
|
2016-02-09 08:32:13 +08:00
|
|
|
assert.ok(a.C instanceof Function);
|
2010-12-05 06:45:52 +08:00
|
|
|
assert.equal('C done', a.C());
|
2009-06-08 22:17:33 +08:00
|
|
|
|
2016-02-09 08:32:13 +08:00
|
|
|
assert.ok(a.D instanceof Function);
|
2010-12-05 06:45:52 +08:00
|
|
|
assert.equal('D done', a.D());
|
2009-06-08 22:17:33 +08:00
|
|
|
|
2016-02-09 08:32:13 +08:00
|
|
|
assert.ok(d.D instanceof Function);
|
2010-12-05 06:45:52 +08:00
|
|
|
assert.equal('D done', d.D());
|
2009-06-08 22:17:33 +08:00
|
|
|
|
2016-02-09 08:32:13 +08:00
|
|
|
assert.ok(d2.D instanceof Function);
|
2010-12-05 06:45:52 +08:00
|
|
|
assert.equal('D done', d2.D());
|
2009-09-18 21:45:47 +08:00
|
|
|
|
2009-12-19 06:58:04 +08:00
|
|
|
assert.equal(true, errorThrown);
|
|
|
|
|
2010-12-05 06:45:52 +08:00
|
|
|
console.log('exit');
|
2009-08-27 00:51:04 +08:00
|
|
|
});
|
2011-08-03 05:18:18 +08:00
|
|
|
|
|
|
|
|
|
|
|
// #1440 Loading files with a byte order marker.
|
|
|
|
assert.equal(42, require('../fixtures/utf8-bom.js'));
|
|
|
|
assert.equal(42, require('../fixtures/utf8-bom.json'));
|
2015-09-15 06:26:59 +08:00
|
|
|
|
|
|
|
// Error on the first line of a module should
|
2015-12-16 06:37:16 +08:00
|
|
|
// have the correct line number
|
2015-09-15 06:26:59 +08:00
|
|
|
assert.throws(function() {
|
|
|
|
require('../fixtures/test-error-first-line-offset.js');
|
|
|
|
}, function(err) {
|
2015-12-16 06:37:16 +08:00
|
|
|
return /test-error-first-line-offset.js:1:/.test(err.stack);
|
2015-09-15 06:26:59 +08:00
|
|
|
}, 'Expected appearance of proper offset in Error stack');
|