Skip to content

Commit

Permalink
Return booleans indicating whether assertions passed
Browse files Browse the repository at this point in the history
Co-authored-by: Mark Wubben <[email protected]>
  • Loading branch information
jmarkham828 and novemberborn authored Mar 7, 2021
1 parent d8b1e89 commit 72a4e2f
Show file tree
Hide file tree
Showing 4 changed files with 550 additions and 471 deletions.
40 changes: 26 additions & 14 deletions docs/03-assertions.md
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,8 @@ test('unicorns are truthy', t => {

If multiple assertion failures are encountered within a single test, AVA will only display the *first* one.

Assertions return a boolean indicating whether they passed. You can use this to return early from a test. Note that this does not apply to the "throws" assertions.

## Assertion planning

Assertion plans ensure tests only pass when a specific number of assertions have been executed. They'll help you catch cases where tests exit too early. They'll also cause tests to fail if too many assertions are executed, which can be useful if you have assertions inside callbacks or loops.
Expand Down Expand Up @@ -165,47 +167,47 @@ test('custom assertion', t => {

### `.pass(message?)`

Passing assertion.
Passing assertion. Returns a boolean indicating whether the assertion passed.

### `.fail(message?)`

Failing assertion.
Failing assertion. Returns a boolean indicating whether the assertion passed.

### `.assert(value, message?)`

Asserts that `value` is truthy. This is [`power-assert`](#enhanced-assertion-messages) enabled.
Asserts that `value` is truthy. This is [`power-assert`](#enhanced-assertion-messages) enabled. Returns a boolean indicating whether the assertion passed.

### `.truthy(value, message?)`

Assert that `value` is truthy.
Assert that `value` is truthy. Returns a boolean indicating whether the assertion passed.

### `.falsy(value, message?)`

Assert that `value` is falsy.
Assert that `value` is falsy. Returns a boolean indicating whether the assertion passed.

### `.true(value, message?)`

Assert that `value` is `true`.
Assert that `value` is `true`. Returns a boolean indicating whether the assertion passed.

### `.false(value, message?)`

Assert that `value` is `false`.
Assert that `value` is `false`. Returns a boolean indicating whether the assertion passed.

### `.is(value, expected, message?)`

Assert that `value` is the same as `expected`. This is based on [`Object.is()`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is).
Assert that `value` is the same as `expected`. This is based on [`Object.is()`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is). Returns a boolean indicating whether the assertion passed.

### `.not(value, expected, message?)`

Assert that `value` is not the same as `expected`. This is based on [`Object.is()`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is).
Assert that `value` is not the same as `expected`. This is based on [`Object.is()`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is). Returns a boolean indicating whether the assertion passed.

### `.deepEqual(value, expected, message?)`

Assert that `value` is deeply equal to `expected`. See [Concordance](https://github.com/concordancejs/concordance) for details. In AVA 3 this works with [React elements and `react-test-renderer`](https://github.com/concordancejs/react).

### `.notDeepEqual(value, expected, message?)`

Assert that `value` is not deeply equal to `expected`. The inverse of `.deepEqual()`.
Assert that `value` is not deeply equal to `expected`. The inverse of `.deepEqual()`. Returns a boolean indicating whether the assertion passed.

### `.like(value, selector, message?)`

Expand All @@ -232,6 +234,8 @@ t.like({
})
```

Finally, this returns a boolean indicating whether the assertion passed.

### `.throws(fn, expectation?, message?)`

Assert that an error is thrown. `fn` must be a function which should throw. The thrown value *must* be an error. It is returned so you can run more assertions against it.
Expand Down Expand Up @@ -262,6 +266,8 @@ test('throws', t => {
});
```

Does not return anything.

### `.throwsAsync(thrower, expectation?, message?)`

Assert that an error is thrown. `thrower` can be an async function which should throw, or a promise that should reject. This assertion must be awaited.
Expand Down Expand Up @@ -297,9 +303,11 @@ test('rejects', async t => {
});
```

Does not return anything.

### `.notThrows(fn, message?)`

Assert that no error is thrown. `fn` must be a function which shouldn't throw.
Assert that no error is thrown. `fn` must be a function which shouldn't throw. Does not return anything.

### `.notThrowsAsync(nonThrower, message?)`

Expand All @@ -313,21 +321,23 @@ test('resolves', async t => {
});
```

Does not return anything.

### `.regex(contents, regex, message?)`

Assert that `contents` matches `regex`.
Assert that `contents` matches `regex`. Returns a boolean indicating whether the assertion passed.

### `.notRegex(contents, regex, message?)`

Assert that `contents` does not match `regex`.
Assert that `contents` does not match `regex`. Returns a boolean indicating whether the assertion passed.

### `.snapshot(expected, message?)`

Compares the `expected` value with a previously recorded snapshot. Snapshots are stored for each test, so ensure you give your tests unique titles.

AVA 3 supports an `options` object that lets you select a specific snapshot, for instance `{id: 'my snapshot'}`. This is buggy and will be removed in AVA 4.

Snapshot assertions cannot be skipped when snapshots are being updated.
Snapshot assertions cannot be skipped when snapshots are being updated. Returns a boolean indicating whether the assertion passed.

### `.try(title?, implementation | macro | macro[], ...args?)`

Expand Down Expand Up @@ -374,3 +384,5 @@ test('flaky macro', async t => {
secondTry.commit();
});
```

Returns a boolean indicating whether the assertion passed.
Loading

0 comments on commit 72a4e2f

Please sign in to comment.