mirror of
https://github.com/denoland/deno.git
synced 2024-11-30 16:40:57 -05:00
29934d558c
The intent is that those tests will be executed, but our check that the files are up to date won't overwrite the contents of the tests. This is useful when a test needs some manual edits to work. It turns out we weren't actually running them. --- This ended up turning into a couple of small bug fixes to get the tests passing: - We weren't canonicalizing the exec path properly (it sometimes still had `..` or `.` in it) - We weren't accepting strings in `process.exit` There was one failure I couldn't figure out quickly, so I disabled the test for now, and filed a follow up issue: #24694
59 lines
2 KiB
JavaScript
59 lines
2 KiB
JavaScript
// deno-fmt-ignore-file
|
|
// deno-lint-ignore-file
|
|
|
|
// Copyright Joyent and Node contributors. All rights reserved. MIT license.
|
|
// Taken from Node 18.8.0
|
|
// This file is automatically generated by "node/_tools/setup.ts". Do not modify this file manually
|
|
|
|
// TODO(PolarETech): The process.argv[3] check should be argv[2], and the
|
|
// command passed to exec() should not need to include "run", "-A",
|
|
// and "runner.ts".
|
|
|
|
'use strict';
|
|
const common = require('../common');
|
|
const stdoutData = 'foo';
|
|
const stderrData = 'bar';
|
|
|
|
if (process.argv[3] === 'child') {
|
|
// The following console calls are part of the test.
|
|
console.log(stdoutData);
|
|
console.error(stderrData);
|
|
} else {
|
|
const assert = require('assert');
|
|
const cp = require('child_process');
|
|
const expectedStdout = `${stdoutData}\n`;
|
|
const expectedStderr = `${stderrData}\n`;
|
|
function run(options, callback) {
|
|
const cmd = `"${process.execPath}" run -A runner.ts "${__filename}" child`;
|
|
|
|
cp.exec(cmd, options, common.mustSucceed((stdout, stderr) => {
|
|
callback(stdout, stderr);
|
|
}));
|
|
}
|
|
|
|
// Test default encoding, which should be utf8.
|
|
run({}, (stdout, stderr) => {
|
|
assert.strictEqual(typeof stdout, 'string');
|
|
assert.strictEqual(typeof stderr, 'string');
|
|
assert.strictEqual(stdout, expectedStdout);
|
|
assert.strictEqual(stderr, expectedStderr);
|
|
});
|
|
|
|
// Test explicit utf8 encoding.
|
|
run({ encoding: 'utf8' }, (stdout, stderr) => {
|
|
assert.strictEqual(typeof stdout, 'string');
|
|
assert.strictEqual(typeof stderr, 'string');
|
|
assert.strictEqual(stdout, expectedStdout);
|
|
assert.strictEqual(stderr, expectedStderr);
|
|
});
|
|
|
|
// Test cases that result in buffer encodings.
|
|
[undefined, null, 'buffer', 'invalid'].forEach((encoding) => {
|
|
run({ encoding }, (stdout, stderr) => {
|
|
assert(stdout instanceof Buffer);
|
|
assert(stdout instanceof Buffer);
|
|
assert.strictEqual(stdout.toString(), expectedStdout);
|
|
assert.strictEqual(stderr.toString(), expectedStderr);
|
|
});
|
|
});
|
|
}
|