Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Docs for deno test + minor other changes #5185

Merged
merged 7 commits into from
May 10, 2020
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion docs/contributing.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# Contributing

- Read the [style guide](contributing/style_guide.md).
- Read the [style guide](./contributing/style_guide.md).

- Please don't make [the benchmarks](https://deno.land/benchmarks.html) worse.

Expand Down
6 changes: 3 additions & 3 deletions docs/contributing/building_from_source.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ Deno you can download a prebuilt executable (more information in the

Clone on Linux or Mac:

```bash
```shell
git clone --recurse-submodules https://github.com/denoland/deno.git
```

Expand All @@ -18,7 +18,7 @@ Extra steps for Windows users:
(otherwise symlinks would require administrator privileges).
2. Make sure you are using git version 2.19.2.windows.1 or newer.
3. Set `core.symlinks=true` before the checkout:
```bash
```shell
git config --global core.symlinks true
git clone --recurse-submodules https://github.com/denoland/deno.git
```
Expand Down Expand Up @@ -77,7 +77,7 @@ about the V8 build.

Build with Cargo:

```bash
```shell
# Build:
cargo build -vv

Expand Down
8 changes: 4 additions & 4 deletions docs/contributing/development_tools.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@

Test `deno`:

```bash
```shell
# Run the whole suite:
cargo test

Expand All @@ -14,21 +14,21 @@ cargo test js_unit_tests

Test `std/`:

```bash
```shell
cargo test std_tests
```

### Lint and format

Lint the code:

```bash
```shell
./tools/lint.py
```

Format the code:

```bash
```shell
./tools/format.py
```

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

This one serves a local directory in HTTP.

```bash
```shell
deno install --allow-net --allow-read https://deno.land/std/http/file_server.ts
```

Expand Down
18 changes: 18 additions & 0 deletions docs/examples/file_system_events.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
### File system events

To poll for file system events:

```ts
const watcher = Deno.watchFs("/");
for await (const event of watcher) {
console.log(">>>> event", event);
// { kind: "create", paths: [ "/foo.txt" ] }
}
```

Note that the exact ordering of the events can vary between operating systems.
This feature uses different syscalls depending on the platform:

- Linux: inotify
- macOS: FSEvents
- Windows: ReadDirectoryChangesW
2 changes: 1 addition & 1 deletion docs/examples/tcp_echo.md
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ For security reasons, Deno does not allow programs to access the network without
explicit permission. To allow accessing the network, use a command-line flag:

```shell
$ deno run --allow-net https://deno.land/std/examples/echo_server.ts
deno run --allow-net https://deno.land/std/examples/echo_server.ts
```

To test it, try sending data to it with netcat:
Expand Down
2 changes: 1 addition & 1 deletion docs/examples/unix_cat.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,5 +20,5 @@ I/O streams in Deno.
Try the program:

```shell
$ deno run --allow-read https://deno.land/std/examples/cat.ts /etc/passwd
deno run --allow-read https://deno.land/std/examples/cat.ts /etc/passwd
```
12 changes: 6 additions & 6 deletions docs/getting_started/first_steps.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,13 +17,13 @@ and use modern features wherever possible.
Because of this browser compatibility a simple `Hello World` program is actually
no different to one you can run in the browser:

```typescript
```ts
console.log("Welcome to Deno 🦕");
```

Try the program:

```bash
```shell
deno run https://deno.land/std/examples/welcome.ts
```

Expand All @@ -37,7 +37,7 @@ Just like in the browser you can use the web standard
[`fetch`](https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API) API to
make HTTP calls:

```typescript
```ts
const url = Deno.args[0];
const res = await fetch(url);

Expand All @@ -60,7 +60,7 @@ Lets walk through what this application does:

Try it out:

```bash
```shell
deno run https://deno.land/std/examples/curl.ts https://example.com
```

Expand All @@ -71,7 +71,7 @@ programs the permission to do certain 'privileged' actions like network access.

Try it out again with the correct permission flag:

```bash
```shell
deno run --allow-net=example.com https://deno.land/std/examples/curl.ts https://example.com
```

Expand Down Expand Up @@ -103,7 +103,7 @@ I/O streams in Deno.

Try the program:

```bash
```shell
deno run --allow-read https://deno.land/std/examples/cat.ts /etc/passwd
```

Expand Down
2 changes: 1 addition & 1 deletion docs/getting_started/typescript.md
Original file line number Diff line number Diff line change
Expand Up @@ -100,7 +100,7 @@ be provided to Deno on program execution.
You need to explicitly tell Deno where to look for this configuration by setting
the `-c` argument when executing your application.

```bash
```shell
deno run -c tsconfig.json mod.ts
```

Expand Down
4 changes: 2 additions & 2 deletions docs/linking_to_external_code.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# Linking to third party code

In the [Getting Started](../getting_started) section, we saw that Deno could
In the [Getting Started](./getting_started.md) section, we saw that Deno could
execute scripts from URLs. Like browser JavaScript, Deno can import libraries
directly from URLs. This example uses a URL to import an assertion library:

Expand Down Expand Up @@ -52,7 +52,7 @@ specifying that path as the `$DENO_DIR` environmental variable at runtime.

By using a lock file (using the `--lock` command line flag) you can ensure
you're running the code you expect to be. You can learn more about this
[here](./integrity_checking).
[here](./linking_to_external_code/integrity_checking.md).

### How do you import to a specific version?

Expand Down
2 changes: 1 addition & 1 deletion docs/runtime/program_lifecycle.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ Listener for `load` events can be asynchronous and will be awaited. Listener for

Example:

```typescript
```ts
// main.ts
import "./imported.ts";

Expand Down
2 changes: 1 addition & 1 deletion docs/runtime/stability.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ are not ready because they are still in draft phase are locked behind the
- It enables the use of unstable APIs during runtime.
- It adds the
[`lib.deno.unstable.d.ts`](https://github.com/denoland/deno/blob/master/cli/js/lib.deno.unstable.d.ts)
file to the list of TypeScript definitions that are used for typechecking.
file to the list of TypeScript definitions that are used for type checking.
This includes the output of `deno types`.

You should be aware that unstable APIs have probably **not undergone a security
Expand Down
3 changes: 2 additions & 1 deletion docs/runtime/workers.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,8 @@ new Worker("./worker.js", { type: "classic" });

### Using Deno in worker

**UNSTABLE**: This feature is unstable and requires `--unstable` flag
> This is an unstable Deno feature. Learn more about
> [unstable features](./stability.md).

By default `Deno` namespace is not available in worker scope.

Expand Down
105 changes: 105 additions & 0 deletions docs/testing.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,105 @@
# Testing

Deno has a built-in test runner that you can use for testing JavaScript or
TypeScript code.

## Writing tests

To define a test you need to call `Deno.test` with a name and function to be
tested:

```ts
Deno.test("hello world", () => {
const x = 1 + 2;
if (x !== 3) {
throw Error("x should be equal to 3");
}
});
```

There are some useful assertion utilities at https://deno.land/std/testing to
make testing easier:

```ts
import { assertEquals } from "https://deno.land/std/testing/asserts.ts";

Deno.test("hello world", () => {
const x = 1 + 2;
assertEquals(x, 3);
});
```

### Async functions

You can also test asynchronous code by passing a test function that returns a
promise. For this you can use the `async` keyword when defining a function:

```ts
Deno.test("async hello world", async () => {
const x = 1 + 2;

// await some async task
await delay(100);

if (x !== 3) {
throw Error("x should be equal to 3");
}
});
```

### Resource and async op sanitizers

Certain actions in Deno create resources in the resource table
([learn more here](./contributing/architecture.md)). These resources should be
closed after you are done using them.

For each test definition the test runner checks that all resources created in
this test have been closed. This is to prevent resource 'leaks'. This is enabled
by default for all tests, but can be disabled by setting the `sanitizeResources`
boolean to false in the test definition.

The same is true for async operation like interacting with the filesystem. The
test runner checks that each operation you start in the test is completed before
the end of the test. This is enabled by default for all tests, but can be
disabled by setting the `sanitizeOps` boolean to false in the test definition.

```ts
Deno.test({
name: "leaky test",
fn() {
Deno.open("hello.txt");
},
sanitizeResources: false,
sanitizeOps: false,
});
```

### Ignoring tests

Sometimes you want to ignore tests based on some sort of condition (for example
you only want a test to run on Windows). For this you can use the `ignore`
boolean in the test definition. If it is set to true the test will be skipped.

```ts
Deno.test({
name: "do macOS feature",
ignore: Deno.build.os !== "darwin",
fn() {
doMacOSFeature();
},
});
```

## Running tests

To run the test, call `deno test` with the file that contains your test
function:

```shell
deno test my_test.ts
```

You can also omit the file name, in which case all tests in the current
directory (recursively) that match the glob `{*_,}test.{js,ts,jsx,tsx}` will be
run. If you pass a directory, all files in the directory that match this glob
will be run.
18 changes: 3 additions & 15 deletions docs/toc.json
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@
"name": "The Runtime",
"children": {
"stability": "Stability",
"program_lifecycle": "Program Lifecycle",
"program_lifecycle": "Program lifecycle",
"compiler_apis": "Compiler APIs",
"workers": "Workers"
}
Expand All @@ -32,19 +32,7 @@
}
},
"testing": {
"name": "Testing",
"children": {
"writing": "Writing tests",
"running": "Running tests"
}
},
"plugins": {
"name": "Plugins",
"children": {
"how_do_plugins_work": "How do plugins work?",
"creating_plugins": "Creating plugins",
"using_plugins": "Using plugins"
}
"name": "Testing"
},
"tools": {
"name": "Tools",
Expand Down Expand Up @@ -73,7 +61,7 @@
"name": "Examples",
"children": {
"unix_cat": "Unix cat program",
"fileserver": "File server",
"file_server": "File server",
"tcp_echo": "TCP echo server",
"subprocess": "Creating a subprocess",
"permissions": "Inspecting and revoking permissions",
Expand Down
2 changes: 1 addition & 1 deletion docs/tools.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ and TypeScript:
<!-- prettier-ignore-start -->
<!-- prettier incorrectly moves the coming soon links to new lines -->

- [test runner (`deno test`)](../testing)
- [test runner (`deno test`)](./testing.md)
- [code formatter (`deno fmt`)](./tools/formatter.md)
- [bundler (`deno bundle`)](./tools/bundler.md)
- [debugger (`--debug`)](./tools/debugger.md)
Expand Down
5 changes: 2 additions & 3 deletions docs/tools/script_installer.md
Original file line number Diff line number Diff line change
Expand Up @@ -61,9 +61,8 @@ $ deno install --allow-net --allow-read https://deno.land/std/http/file_server.t
The above command creates an executable called `file_server` that runs with
write and read permissions and binds to port 8080.

For good practice, use the
[`import.meta.main`](#testing-if-current-file-is-the-main-program) idiom to
specify the entry point in an executable script.
For good practice, use the [`import.meta.main`](../examples/testing_if_main.md)
idiom to specify the entry point in an executable script.

Example:

Expand Down