summaryrefslogtreecommitdiff
path: root/cli/tests/node_compat/test/parallel/test-path-extname.js
diff options
context:
space:
mode:
authorMatt Mastracci <matthew@mastracci.com>2024-02-10 13:22:13 -0700
committerGitHub <noreply@github.com>2024-02-10 20:22:13 +0000
commitf5e46c9bf2f50d66a953fa133161fc829cecff06 (patch)
tree8faf2f5831c1c7b11d842cd9908d141082c869a5 /cli/tests/node_compat/test/parallel/test-path-extname.js
parentd2477f780630a812bfd65e3987b70c0d309385bb (diff)
chore: move cli/tests/ -> tests/ (#22369)
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.
Diffstat (limited to 'cli/tests/node_compat/test/parallel/test-path-extname.js')
-rw-r--r--cli/tests/node_compat/test/parallel/test-path-extname.js106
1 files changed, 0 insertions, 106 deletions
diff --git a/cli/tests/node_compat/test/parallel/test-path-extname.js b/cli/tests/node_compat/test/parallel/test-path-extname.js
deleted file mode 100644
index d1ed0342b..000000000
--- a/cli/tests/node_compat/test/parallel/test-path-extname.js
+++ /dev/null
@@ -1,106 +0,0 @@
-// 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.\\\\'), '.\\\\');