mirror of
https://github.com/shelljs/shelljs.git
synced 2026-01-18 16:03:37 +00:00
* chore: switch to eslint * fix: works on older versions of NodeJS now * chore: fix curly braces * chore: fix indents and remove jshint references
175 lines
5.8 KiB
JavaScript
175 lines
5.8 KiB
JavaScript
var shell = require('..');
|
|
|
|
var assert = require('assert');
|
|
var util = require('util');
|
|
var path = require('path');
|
|
var os = require('os');
|
|
|
|
shell.config.silent = true;
|
|
|
|
//
|
|
// Invalids
|
|
//
|
|
|
|
shell.exec();
|
|
assert.ok(shell.error());
|
|
|
|
var result = shell.exec('asdfasdf'); // could not find command
|
|
assert.ok(result.code > 0);
|
|
|
|
// Test 'fatal' mode for exec, temporarily overriding process.exit
|
|
var oldFatal = shell.config.fatal;
|
|
|
|
shell.config.fatal = true;
|
|
|
|
assert.throws(function () {
|
|
shell.exec('asdfasdf'); // could not find command
|
|
}, /exec: internal error/);
|
|
|
|
shell.config.fatal = oldFatal;
|
|
|
|
//
|
|
// Valids
|
|
//
|
|
|
|
//
|
|
// sync
|
|
//
|
|
|
|
// check if stdout goes to output
|
|
result = shell.exec(JSON.stringify(process.execPath) + ' -e "console.log(1234);"');
|
|
assert.equal(shell.error(), null);
|
|
assert.equal(result.code, 0);
|
|
assert.ok(result.stdout === '1234\n' || result.stdout === '1234\nundefined\n'); // 'undefined' for v0.4
|
|
|
|
// check if stderr goes to output
|
|
result = shell.exec(JSON.stringify(process.execPath) + ' -e "console.error(1234);"');
|
|
assert.equal(shell.error(), null);
|
|
assert.equal(result.code, 0);
|
|
assert.ok(result.stdout === '' || result.stdout === 'undefined\n'); // 'undefined' for v0.4
|
|
assert.ok(result.stderr === '1234\n' || result.stderr === '1234\nundefined\n'); // 'undefined' for v0.4
|
|
|
|
// check if stdout + stderr go to output
|
|
result = shell.exec(JSON.stringify(process.execPath) + ' -e "console.error(1234); console.log(666);"');
|
|
assert.equal(shell.error(), null);
|
|
assert.equal(result.code, 0);
|
|
assert.ok(result.stdout === '666\n' || result.stdout === '666\nundefined\n'); // 'undefined' for v0.4
|
|
assert.ok(result.stderr === '1234\n' || result.stderr === '1234\nundefined\n'); // 'undefined' for v0.4
|
|
|
|
// check exit code
|
|
result = shell.exec(JSON.stringify(process.execPath) + ' -e "process.exit(12);"');
|
|
assert.ok(shell.error());
|
|
assert.equal(result.code, 12);
|
|
|
|
// interaction with cd
|
|
shell.cd('resources/external');
|
|
result = shell.exec(JSON.stringify(process.execPath) + ' node_script.js');
|
|
assert.equal(shell.error(), null);
|
|
assert.equal(result.code, 0);
|
|
assert.equal(result.stdout, 'node_script_1234\n');
|
|
shell.cd('../..');
|
|
|
|
// check quotes escaping
|
|
result = shell.exec(util.format(JSON.stringify(process.execPath) + ' -e "console.log(%s);"', "\\\"\\'+\\'_\\'+\\'\\\""));
|
|
assert.equal(shell.error(), null);
|
|
assert.equal(result.code, 0);
|
|
assert.equal(result.stdout, "'+'_'+'\n");
|
|
|
|
// set cwd
|
|
var cmdString = process.platform === 'win32' ? 'cd' : 'pwd';
|
|
result = shell.exec(cmdString, { cwd: '..' });
|
|
assert.equal(shell.error(), null);
|
|
assert.equal(result.code, 0);
|
|
assert.equal(result.stdout, path.resolve('..') + os.EOL);
|
|
|
|
// set maxBuffer (very small)
|
|
result = shell.exec('echo 1234567890'); // default maxBuffer is ok
|
|
assert.equal(shell.error(), null);
|
|
assert.equal(result.code, 0);
|
|
assert.equal(result.stdout, '1234567890' + os.EOL);
|
|
if (process.version >= 'v0.11') { // this option doesn't work on v0.10
|
|
shell.exec('echo 1234567890', { maxBuffer: 6 });
|
|
assert.ok(shell.error());
|
|
}
|
|
|
|
// set timeout option
|
|
result = shell.exec(JSON.stringify(process.execPath) + ' resources/exec/slow.js 100'); // default timeout is ok
|
|
assert.ok(!shell.error());
|
|
assert.equal(result.code, 0);
|
|
if (process.version >= 'v0.11') { // this option doesn't work on v0.10
|
|
result = shell.exec(JSON.stringify(process.execPath) + ' resources/exec/slow.js 100', { timeout: 10 }); // times out
|
|
assert.ok(shell.error());
|
|
}
|
|
|
|
// check process.env works
|
|
assert.ok(!shell.env.FOO);
|
|
shell.env.FOO = 'Hello world';
|
|
result = shell.exec(process.platform !== 'win32' ? 'echo $FOO' : 'echo %FOO%');
|
|
assert.ok(!shell.error());
|
|
assert.equal(result.code, 0);
|
|
assert.equal(result.stdout, 'Hello world' + os.EOL);
|
|
assert.equal(result.stderr, '');
|
|
|
|
// set shell option (TODO: add tests for Windows)
|
|
if (process.platform !== 'win32') {
|
|
result = shell.exec('echo $0');
|
|
assert.ok(!shell.error());
|
|
assert.equal(result.code, 0);
|
|
assert.equal(result.stdout, '/bin/sh\n'); // sh by default
|
|
var bashPath = shell.which('bash').trim();
|
|
// this option doesn't work on v0.10
|
|
if (bashPath && process.version >= 'v0.11') {
|
|
result = shell.exec('echo $0', { shell: '/bin/bash' });
|
|
assert.ok(!shell.error());
|
|
assert.equal(result.code, 0);
|
|
assert.equal(result.stdout, '/bin/bash\n');
|
|
}
|
|
}
|
|
|
|
// exec returns a ShellString
|
|
result = shell.exec('echo foo');
|
|
assert.ok(typeof result === 'object');
|
|
assert.ok(result instanceof String);
|
|
assert.ok(typeof result.stdout === 'string');
|
|
assert.strictEqual(result.toString(), result.stdout);
|
|
|
|
//
|
|
// async
|
|
//
|
|
|
|
// no callback
|
|
var c = shell.exec(JSON.stringify(process.execPath) + ' -e "console.log(1234)"', { async: true });
|
|
assert.equal(shell.error(), null);
|
|
assert.ok('stdout' in c, 'async exec returns child process object');
|
|
|
|
//
|
|
// callback as 2nd argument
|
|
//
|
|
shell.exec(JSON.stringify(process.execPath) + ' -e "console.log(5678);"', function (code, stdout, stderr) {
|
|
assert.equal(code, 0);
|
|
assert.ok(stdout === '5678\n' || stdout === '5678\nundefined\n'); // 'undefined' for v0.4
|
|
assert.ok(stderr === '' || stderr === 'undefined\n'); // 'undefined' for v0.4
|
|
|
|
//
|
|
// callback as 3rd argument
|
|
//
|
|
shell.exec(JSON.stringify(process.execPath) + ' -e "console.log(5566);"', { async: true }, function (code2, stdout2, stderr2) {
|
|
assert.equal(code2, 0);
|
|
assert.ok(stdout2 === '5566\n' || stdout2 === '5566\nundefined\n'); // 'undefined' for v0.4
|
|
assert.ok(stderr2 === '' || stderr2 === 'undefined\n'); // 'undefined' for v0.4
|
|
|
|
//
|
|
// callback as 3rd argument (slient:true)
|
|
//
|
|
shell.exec(JSON.stringify(process.execPath) + ' -e "console.log(5678);"', { silent: true }, function (code3, stdout3, stderr3) {
|
|
assert.equal(code3, 0);
|
|
assert.ok(stdout3 === '5678\n' || stdout3 === '5678\nundefined\n'); // 'undefined' for v0.4
|
|
assert.ok(stderr3 === '' || stderr3 === 'undefined\n'); // 'undefined' for v0.4
|
|
|
|
shell.exit(123);
|
|
});
|
|
});
|
|
});
|
|
|
|
assert.equal(shell.error(), null);
|