mirror of
https://github.com/denoland/deno.git
synced 2025-01-07 22:58:24 -05:00
f5e46c9bf2
This looks like a massive PR, but it's only a move from cli/tests -> tests, and updates of relative paths for files. This is the first step towards aggregate all of the integration test files under tests/, which will lead to a set of integration tests that can run without the CLI binary being built. While we could leave these tests under `cli`, it would require us to keep a more complex directory structure for the various test runners. In addition, we have a lot of complexity to ignore various test files in the `cli` project itself (cargo publish exclusion rules, autotests = false, etc). And finally, the `tests/` folder will eventually house the `test_ffi`, `test_napi` and other testing code, reducing the size of the root repo directory. For easier review, the extremely large and noisy "move" is in the first commit (with no changes -- just a move), while the remainder of the changes to actual files is in the second commit.
106 lines
3.3 KiB
JavaScript
106 lines
3.3 KiB
JavaScript
// deno-fmt-ignore-file
|
|
// deno-lint-ignore-file
|
|
|
|
// Copyright Joyent and Node contributors. All rights reserved. MIT license.
|
|
// Taken from Node 18.12.1
|
|
// This file is automatically generated by `tools/node_compat/setup.ts`. Do not modify this file manually.
|
|
|
|
'use strict';
|
|
require('../common');
|
|
const assert = require('assert');
|
|
const path = require('path');
|
|
|
|
const failures = [];
|
|
const slashRE = /\//g;
|
|
|
|
[
|
|
[__filename, '.js'],
|
|
['', ''],
|
|
['/path/to/file', ''],
|
|
['/path/to/file.ext', '.ext'],
|
|
['/path.to/file.ext', '.ext'],
|
|
['/path.to/file', ''],
|
|
['/path.to/.file', ''],
|
|
['/path.to/.file.ext', '.ext'],
|
|
['/path/to/f.ext', '.ext'],
|
|
['/path/to/..ext', '.ext'],
|
|
['/path/to/..', ''],
|
|
['file', ''],
|
|
['file.ext', '.ext'],
|
|
['.file', ''],
|
|
['.file.ext', '.ext'],
|
|
['/file', ''],
|
|
['/file.ext', '.ext'],
|
|
['/.file', ''],
|
|
['/.file.ext', '.ext'],
|
|
['.path/file.ext', '.ext'],
|
|
['file.ext.ext', '.ext'],
|
|
['file.', '.'],
|
|
['.', ''],
|
|
['./', ''],
|
|
['.file.ext', '.ext'],
|
|
['.file', ''],
|
|
['.file.', '.'],
|
|
['.file..', '.'],
|
|
['..', ''],
|
|
['../', ''],
|
|
['..file.ext', '.ext'],
|
|
['..file', '.file'],
|
|
['..file.', '.'],
|
|
['..file..', '.'],
|
|
['...', '.'],
|
|
['...ext', '.ext'],
|
|
['....', '.'],
|
|
['file.ext/', '.ext'],
|
|
['file.ext//', '.ext'],
|
|
['file/', ''],
|
|
['file//', ''],
|
|
['file./', '.'],
|
|
['file.//', '.'],
|
|
].forEach((test) => {
|
|
const expected = test[1];
|
|
[path.posix.extname, path.win32.extname].forEach((extname) => {
|
|
let input = test[0];
|
|
let os;
|
|
if (extname === path.win32.extname) {
|
|
input = input.replace(slashRE, '\\');
|
|
os = 'win32';
|
|
} else {
|
|
os = 'posix';
|
|
}
|
|
const actual = extname(input);
|
|
const message = `path.${os}.extname(${JSON.stringify(input)})\n expect=${
|
|
JSON.stringify(expected)}\n actual=${JSON.stringify(actual)}`;
|
|
if (actual !== expected)
|
|
failures.push(`\n${message}`);
|
|
});
|
|
{
|
|
const input = `C:${test[0].replace(slashRE, '\\')}`;
|
|
const actual = path.win32.extname(input);
|
|
const message = `path.win32.extname(${JSON.stringify(input)})\n expect=${
|
|
JSON.stringify(expected)}\n actual=${JSON.stringify(actual)}`;
|
|
if (actual !== expected)
|
|
failures.push(`\n${message}`);
|
|
}
|
|
});
|
|
assert.strictEqual(failures.length, 0, failures.join(''));
|
|
|
|
// On Windows, backslash is a path separator.
|
|
assert.strictEqual(path.win32.extname('.\\'), '');
|
|
assert.strictEqual(path.win32.extname('..\\'), '');
|
|
assert.strictEqual(path.win32.extname('file.ext\\'), '.ext');
|
|
assert.strictEqual(path.win32.extname('file.ext\\\\'), '.ext');
|
|
assert.strictEqual(path.win32.extname('file\\'), '');
|
|
assert.strictEqual(path.win32.extname('file\\\\'), '');
|
|
assert.strictEqual(path.win32.extname('file.\\'), '.');
|
|
assert.strictEqual(path.win32.extname('file.\\\\'), '.');
|
|
|
|
// On *nix, backslash is a valid name component like any other character.
|
|
assert.strictEqual(path.posix.extname('.\\'), '');
|
|
assert.strictEqual(path.posix.extname('..\\'), '.\\');
|
|
assert.strictEqual(path.posix.extname('file.ext\\'), '.ext\\');
|
|
assert.strictEqual(path.posix.extname('file.ext\\\\'), '.ext\\\\');
|
|
assert.strictEqual(path.posix.extname('file\\'), '');
|
|
assert.strictEqual(path.posix.extname('file\\\\'), '');
|
|
assert.strictEqual(path.posix.extname('file.\\'), '.\\');
|
|
assert.strictEqual(path.posix.extname('file.\\\\'), '.\\\\');
|