Browse Source

test: refactor test-init.js

1. Lot of repeating code has been refactored to a function
2. Errors in async calls are properly asserted
3. Fail the test if the callbacks are not fired

PR-URL: https://github.com/nodejs/node/pull/10384
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Anna Henningsen <anna@addaleax.net>
Reviewed-By: Julian Duque <julianduquej@gmail.com>
v6
Sakthipriyan Vairamani (thefourtheye) 8 years ago
committed by Julian Duque
parent
commit
bf2c49cf71
No known key found for this signature in database GPG Key ID: D2F1394777BDB2E2
  1. 58
      test/sequential/test-init.js

58
test/sequential/test-init.js

@ -2,46 +2,40 @@
const common = require('../common'); const common = require('../common');
const assert = require('assert'); const assert = require('assert');
const child = require('child_process'); const child = require('child_process');
const util = require('util'); const path = require('path');
if (process.env['TEST_INIT']) { if (process.env['TEST_INIT']) {
util.print('Loaded successfully!'); return process.stdout.write('Loaded successfully!');
} else { }
// change CWD as we do this test so its not dependant on current CWD
// being in the test folder process.env.TEST_INIT = 1;
process.chdir(__dirname);
// slow but simple function test(file, expected) {
var envCopy = JSON.parse(JSON.stringify(process.env)); const path = `"${process.execPath}" ${file}`;
envCopy.TEST_INIT = 1; child.exec(path, {env: process.env}, common.mustCall((err, out) => {
assert.ifError(err);
assert.strictEqual(out, expected, `'node ${file}' failed!`);
}));
}
child.exec('"' + process.execPath + '" test-init', {env: envCopy}, {
function(err, stdout, stderr) { // change CWD as we do this test so it's not dependent on current CWD
assert.equal(stdout, 'Loaded successfully!', // being in the test folder
'`node test-init` failed!'); process.chdir(__dirname);
}); test('test-init', 'Loaded successfully!');
child.exec('"' + process.execPath + '" test-init.js', {env: envCopy}, test('test-init.js', 'Loaded successfully!');
function(err, stdout, stderr) { }
assert.equal(stdout, 'Loaded successfully!',
'`node test-init.js` failed!');
});
{
// test-init-index is in fixtures dir as requested by ry, so go there // test-init-index is in fixtures dir as requested by ry, so go there
process.chdir(common.fixturesDir); process.chdir(common.fixturesDir);
test('test-init-index', 'Loaded successfully!');
}
child.exec('"' + process.execPath + '" test-init-index', {env: envCopy}, {
function(err, stdout, stderr) {
assert.equal(stdout, 'Loaded successfully!',
'`node test-init-index failed!');
});
// ensures that `node fs` does not mistakenly load the native 'fs' module // ensures that `node fs` does not mistakenly load the native 'fs' module
// instead of the desired file and that the fs module loads as // instead of the desired file and that the fs module loads as
// expected in node // expected in node
process.chdir(common.fixturesDir + '/test-init-native/'); process.chdir(path.join(common.fixturesDir, 'test-init-native'));
test('fs', 'fs loaded successfully');
child.exec('"' + process.execPath + '" fs', {env: envCopy},
function(err, stdout, stderr) {
assert.equal(stdout, 'fs loaded successfully',
'`node fs` failed!');
});
} }

Loading…
Cancel
Save