1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-14 10:01:51 -05:00
denoland-deno/cli/tests/unit
2020-06-10 11:10:08 -04:00
..
abort_controller_test.ts
blob_test.ts fix DenoBlob name (#5879) 2020-05-29 02:27:57 -04:00
body_test.ts fix: Better use of @ts-expect-error (#6038) 2020-06-02 00:24:44 -04:00
buffer_test.ts Rename abbreviated assertions in std/testing (#6118) 2020-06-05 23:43:00 -04:00
build_test.ts
chmod_test.ts
chown_test.ts
console_test.ts console: Hide values for console.table if display not necessary (#5914) 2020-05-28 08:30:32 -04:00
copy_file_test.ts
custom_event_test.ts
dir_test.ts fix(cli/permissions): Fix CWD and exec path leaks (#5642) 2020-05-29 17:27:43 +02:00
dispatch_json_test.ts Revert "fix: Use # to denote line number in stack traces" (#6119) 2020-06-05 11:37:40 -04:00
dispatch_minimal_test.ts Revert "fix: Use # to denote line number in stack traces" (#6119) 2020-06-05 11:37:40 -04:00
dom_exception_test.ts
dom_iterable_test.ts Use ts-expect-error instead of ts-ignore. (#5869) 2020-05-26 10:02:16 -04:00
error_stack_test.ts Revert "fix: Use # to denote line number in stack traces" (#6119) 2020-06-05 11:37:40 -04:00
event_target_test.ts Use ts-expect-error instead of ts-ignore. (#5869) 2020-05-26 10:02:16 -04:00
event_test.ts
fetch_test.ts fix(cli/web/fetch): multipart/form-data request body support for binary files (#5886) 2020-06-08 18:08:26 +02:00
file_test.ts
files_test.ts Rename abbreviated assertions in std/testing (#6118) 2020-06-05 23:43:00 -04:00
form_data_test.ts Rename abbreviated assertions in std/testing (#6118) 2020-06-05 23:43:00 -04:00
format_error_test.ts
fs_events_test.ts
get_random_values_test.ts Rename abbreviated assertions in std/testing (#6118) 2020-06-05 23:43:00 -04:00
globals_test.ts fix: Better use of @ts-expect-error (#6038) 2020-06-02 00:24:44 -04:00
headers_test.ts Rename abbreviated assertions in std/testing (#6118) 2020-06-05 23:43:00 -04:00
internals_test.ts Use ts-expect-error instead of ts-ignore. (#5869) 2020-05-26 10:02:16 -04:00
io_test.ts
link_test.ts
make_temp_test.ts
metrics_test.ts
mkdir_test.ts
net_test.ts feat(cli/js/net): make rid on listener public (#5571) 2020-06-08 18:24:51 +02:00
os_test.ts feat(cli): Add Deno.env.delete() (#5859) 2020-06-09 14:58:30 +02:00
performance_test.ts
permissions_test.ts
process_test.ts fix(cli/js/process): Always return a code in ProcessStatus (#5244) 2020-06-10 11:10:08 -04:00
read_dir_test.ts
read_file_test.ts
read_link_test.ts
read_text_file_test.ts
README.md
real_path_test.ts
remove_test.ts chore(cli/tests/unit/remove_test): remove duplicate codes between sync and async cases (#6004) 2020-05-31 13:19:56 -04:00
rename_test.ts
request_test.ts fix: Better use of @ts-expect-error (#6038) 2020-06-02 00:24:44 -04:00
resources_test.ts
signal_test.ts
stat_test.ts
stdio_test.ts fix: Deno.readSync on stdin (#6126) 2020-06-09 18:29:12 +02:00
streams_internal_test.ts fix: Better use of @ts-expect-error (#6038) 2020-06-02 00:24:44 -04:00
streams_piping_test.ts
streams_transform_test.ts
streams_writable_test.ts
symlink_test.ts
test_util.ts Rename abbreviated assertions in std/testing (#6118) 2020-06-05 23:43:00 -04:00
testing_test.ts
text_encoding_test.ts
timers_test.ts
tls_test.ts
truncate_test.ts
tty_test.ts
umask_test.ts
unit_test_runner.ts Use ts-expect-error instead of ts-ignore. (#5869) 2020-05-26 10:02:16 -04:00
unit_tests.ts fix: Deno.readSync on stdin (#6126) 2020-06-09 18:29:12 +02:00
url_search_params_test.ts fix: Better use of @ts-expect-error (#6038) 2020-06-02 00:24:44 -04:00
url_test.ts
utime_test.ts
version_test.ts
write_file_test.ts
write_text_file_test.ts

Deno runtime tests

Files in this directory are unit tests for Deno runtime.

They are run under compiled Deno binary as opposed to files in cli/js/ which are bundled and snapshotted using deno_typescript crate.

Testing Deno runtime code requires checking API under different runtime permissions (ie. running with different --allow-* flags). To accomplish this all tests exercised are created using unitTest() function.

import { unitTest } from "./test_util.ts";

unitTest(function simpleTestFn(): void {
  // test code here
});

unitTest({
    ignore: Deno.build.os === "windows",
    perms: { read: true, write: true },
  },
  function complexTestFn(): void {
    // test code here
  }
);

unitTest is is a wrapper function that enhances Deno.test() API in several ways:

  • ability to conditionally skip tests using UnitTestOptions.skip
  • ability to register required set of permissions for given test case using UnitTestOptions.perms
  • sanitization of resources - ensuring that tests close all opened resources preventing interference between tests
  • sanitization of async ops - ensuring that tests don't leak async ops by ensuring that all started async ops are done before test finishes

Running tests

unit_test_runner.ts is the main script used to run unit tests.

Runner discovers required permissions combinations by loading cli/tests/unit/unit_tests.ts and going through all registered instances of unitTest.

There are three ways to run unit_test_runner.ts:

# Run all tests. Spawns worker processes for each discovered permission
# combination:
target/debug/deno run -A cli/tests/unit/unit_test_runner.ts --master

# By default all output of worker processes is discarded; for debug purposes
# the --verbose flag preserves output from the worker
target/debug/deno run -A cli/tests/unit/unit_test_runner.ts --master --verbose

# Run subset of tests that don't require any permissions
target/debug/deno run --unstable cli/tests/unit/unit_test_runner.ts

# Run subset tests that require "net" and "read" permissions
target/debug/deno run --unstable --allow-net --allow-read cli/tests/unit/unit_test_runner.ts

# "worker" mode communicates with parent using TCP socket on provided address;
# after initial setup drops permissions to specified set. It shouldn't be used
# directly, only be "master" process.
target/debug/deno run -A cli/tests/unit/unit_test_runner.ts --worker --addr=127.0.0.1:4500 --perms=net,write,run

# Run specific tests
target/debug/deno run --unstable --allow-net cli/tests/unit/unit_test_runner.ts -- netTcpListenClose

RUST_BACKTRACE=1 cargo run -- run --unstable --allow-read --allow-write cli/tests/unit/unit_test_runner.ts -- netUnixDialListen

Http server

tools/http_server.py is required to run when one's running unit tests. During CI it's spawned automatically, but if you want to run tests manually make sure that server is spawned otherwise there'll be cascade of test failures.