0
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2024-10-29 08:58:01 -04:00
denoland-deno/tests/specs
Nathan Whitaker 51f5f5789b
feat(add): Add npm packages to package.json if present (#25477)
Closes https://github.com/denoland/deno/issues/25321

Ended up being a larger refactoring, since we're now juggling
(potentially) two config files in the same `add`, instead of choosing
one. I don't love the shape of the code, but I think it's good enough

Some smaller side improvements:
- `deno remove` supports `jsonc`
- `deno install --dev` will be a really simple change
- if `deno remove` removes the last import/dependency in the
`imports`/`dependencies`/`devDependencies` field, it removes the field
instead of leaving an empty object
2024-09-06 17:18:13 +00:00
..
add feat(add): Add npm packages to package.json if present (#25477) 2024-09-06 17:18:13 +00:00
bench feat: include version number in all --json based outputs (#25335) 2024-09-05 08:51:40 +00:00
bundle/removed BREAKING: remove deno bundle (#25339) 2024-09-02 17:27:37 +02:00
cache fix: update hint for deno add <package> (#25455) 2024-09-05 11:08:22 +02:00
cert BREAKING: remove deno bundle (#25339) 2024-09-02 17:27:37 +02:00
check feat(lsp): turn on useUnknownInCatchVariables (#25474) 2024-09-06 12:23:59 +02:00
clean/general feat(clean): add progress bar (#25026) 2024-08-14 13:04:07 +02:00
cli/help_and_version_broken_pipe fix: panic when piping "deno help" or "deno --version" (#22917) 2024-07-09 22:57:00 +00:00
compile feat(check): turn on useUnknownInCatchVariables (#25465) 2024-09-05 15:22:31 +02:00
coverage fix(coverage): Error if no files are included in the report (#22952) 2024-03-15 20:58:57 -07:00
doc feat: include version number in all --json based outputs (#25335) 2024-09-05 08:51:40 +00:00
eval chore: deprecate eval itests (#25382) 2024-09-03 15:14:19 +00:00
flags feat: add lowercase -v version flag (#23750) 2024-05-23 00:20:20 +00:00
fmt feat(fmt): support HTML, Svelte, Vue, Astro and Angular (#25019) 2024-08-14 22:58:48 +02:00
future BREAKING(buffer): remove Deno.Buffer (#25441) 2024-09-06 18:28:05 +10:00
import_map/import_map_config refactor: move importMap with imports/scopes diagnostic to deno_config (#24553) 2024-07-12 12:48:53 -04:00
info BREAKING: remove "emit" and "map" from deno info output (#25468) 2024-09-05 14:22:13 +00:00
init/lib fix(init): use bare specifier for jsr:@std/assert (#24581) 2024-07-14 13:22:43 -04:00
install feat(install): deno install with entrypoint (#25411) 2024-09-04 13:06:16 -07:00
jsr fix: update dry run success message (#24885) 2024-08-06 08:14:06 +00:00
jupyter/install_command refactor(jupyter): use runtimelib for Jupyter structures and directory paths (#23826) 2024-05-21 22:35:21 +02:00
lint feat(cli): give access to process global everywhere (#25291) 2024-09-04 11:04:06 +02:00
lockfile test: reenable frozen_lockfile tests (#25381) 2024-09-03 06:43:10 -04:00
node chore: remove DENO_FUTURE=1 from spec tests (#25329) 2024-08-31 21:25:32 +00:00
npm fix: lock down allow-run permissions more (#25370) 2024-09-04 14:51:24 +02:00
permission fix(regression): do not expose resolved path in Deno.Command permission denied error (#25434) 2024-09-04 22:57:49 +00:00
publish fix: make some warnings more standard (#25324) 2024-09-03 10:45:01 +02:00
remove feat(add): Add npm packages to package.json if present (#25477) 2024-09-06 17:18:13 +00:00
run fix: add suggestion how to fix importing CJS module (#21764) 2024-09-05 12:49:07 +00:00
serve feat: Add Deno.ServeDefaultExport type (#24879) 2024-08-05 23:19:09 +02:00
task fix(task): correct name for scoped npm package binaries (#25390) 2024-09-03 13:56:39 +00:00
test refactor(cli/js): align error messages (#25406) 2024-09-04 09:19:55 +02:00
vendor/removed BREAKING: remove deno vendor (#25343) 2024-09-03 17:00:57 +10:00
workspaces fix(byonm): resolve npm deps of jsr deps (#25399) 2024-09-04 14:00:44 +00:00
mod.rs test: add supporting for ignoring spec tests (#25242) 2024-08-28 00:19:29 +00:00
README.md chore: support -- --nocapture in the spec tests (#24113) 2024-06-06 08:37:13 -04:00
schema.json test: add supporting for ignoring spec tests (#25242) 2024-08-28 00:19:29 +00:00

specs

These are integration tests that execute the deno binary. They supersede the itest macro found in the tests/integration folder and are the preferred way of writing tests that use the deno binary.

Structure

Tests must have the following directory structure:

tests/specs/<category_name>/<test_name>/__test__.json

Test filtering

To run a specific test, run:

cargo test specs::category_name::test_name

Or just the following, though it might run other tests:

cargo test test_name

To run showing the output of every test use -- --nocapture (note: this will cause tests to run sequentially instead of in parallel):

cargo test test_name -- --nocapture

__test__.json file

This file describes the test(s) to execute and the steps to execute. A basic example looks like:

{
  "args": "run main.js",
  "output": "main.out"
}

This will run deno run main.js then assert that the output matches the text in main.out.

Or another example that runs multiple steps:

{
  "tempDir": true,
  "steps": [{
    "args": "cache main.ts",
    "output": "cache.out"
  }, {
    "args": "run main.ts",
    "output": "error.out",
    "exitCode": 1
  }]
}

Or if you want to run several tests at the same time:

{
  "tests": {
    "ignore_dir": {
      "args": "run script.ts",
      "output": "script.out"
    },
    "some_other_test": {
      "args": "run other.ts",
      "output": "other.out"
    }
  }
}

Top level properties

  • repeat (number) - Number of times to repeat a test.
  • tempDir (boolean) - Copy all the non-test files to a temporary directory and execute the command in that temporary directory.
    • By default, tests are executed with a current working directory of the test, but this may not be desirable for tests such as ones that create a node_modules directory.

Step properties

When writing a single step, these may be at the top level rather than nested in a "steps" array or "tests" object.

  • args - A string (that will be spilt on whitespace into an args array) or an array of arguments.
  • output - Path to use to assert the output or text (must end with an .out extension) or text to pattern match against the output.
  • flaky - Step should be repeated until success a maximum of 3 times.
  • if ("windows", "linux", "mac", "unix") - Whether to run this step.
  • exitCode (number) - Expected exit code.

Auto-complete

To get auto-complete for these files, add the following to a local .vscode/settings.json file:

{
  "json.schemas": [{
    "fileMatch": [
      "__test__.jsonc"
    ],
    "url": "./tests/specs/schema.json"
  }]
}

.out files

.out files are used to assert the output when running a test or test step.

Within the file, you can use the following for matching:

  • [WILDCARD] - match any text at the wildcard
  • [WILDLINE] - match any text on the current line
  • [WILDCHAR] - match the next character
  • [WILDCHARS(5)] - match any of the next 5 characters
  • [UNORDERED_START] followed by many lines then [UNORDERED_END] will match the lines in any order (useful for non-deterministic output)
  • [# example] - line comments start with [# and end with ]