-
Notifications
You must be signed in to change notification settings - Fork 781
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Ref #1735 Co-authored-by: James M. Greene <[email protected]>
- Loading branch information
1 parent
fb15185
commit 773c890
Showing
7 changed files
with
190 additions
and
38 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,64 @@ | ||
--- | ||
layout: page-api | ||
title: assert.closeTo() | ||
excerpt: Compare that a number is equal within a given tolerance. | ||
groups: | ||
- assert | ||
redirect_from: | ||
- "/assert/closeTo/" | ||
version_added: "unreleased" | ||
--- | ||
|
||
`closeTo( actual, expected, delta, message = "" )` | ||
|
||
Compare that a number is equal to a known target number within a given tolerance. | ||
|
||
| name | description | | ||
|------|-------------| | ||
| `actual` (number) | Expression being tested | | ||
| `expected` (number) | Known target number | | ||
| `delta` (number) | The maximum difference between the expected and actual number | | ||
| `message` (string) | Optional description of the actual expression | | ||
|
||
The `assert.closeTo()` assertion checks that the actual expression approximates the expected number, allowing it to be off by at most the specified amount ("delta"). This can be used to assert that two numbers are roughly or almost equal to each other. | ||
|
||
The actual number may be either above or below the expected number, as long as it is within the `delta` difference (inclusive). | ||
|
||
While non-strict assertions like this are [often discouraged](https://timotijhof.net/posts/2015/qunit-anti-patterns/), it may be necessary to account for limitations in how fractional numbers are represented in JavaScript. For example, `0.1 + 0.2` is actually `0.30000000000000004`. This because math operations in JavaScript adhere to the "IEEE floating-point" standard. | ||
|
||
To learn how floating-point numbers work internally, refer to [Double-precision floating-point format](https://en.wikipedia.org/wiki/Double-precision_floating-point_format) on Wikipedia. To learn why floating-point numbers experience these side effects, refer to "[What Every Computer Scientist Should Know About Floating-Point Arithmetic](http://docs.oracle.com/cd/E19957-01/806-3568/ncg_goldberg.html)" by David Goldberg. | ||
|
||
## Examples | ||
|
||
```js | ||
QUnit.test('good example', assert => { | ||
const x = 0.1 + 0.2; // 0.30000000000000004 | ||
|
||
// passing: must be between 0.299 and 0.301 | ||
assert.closeTo(x, 0.3, 0.001); | ||
|
||
const y = 20.13; | ||
// passing: must be between 20.05 and 20.15 inclusive | ||
assert.closeTo(y, 20.10, 0.05); | ||
}); | ||
|
||
QUnit.test('bad example', assert => { | ||
const x = 20.7; | ||
// failing: must be between 20.0 and 20.2 inclusive | ||
assert.closeTo(x, 20.1, 0.1); | ||
// message: value should be within 0.1 inclusive | ||
// actual : 20.7 | ||
// expected: 20.1 | ||
|
||
const y = 2018; | ||
// failing: must be between 2010 and 2014 inclusive | ||
assert.closeTo(y, 2012, 2); | ||
// message: value should be within 2 inclusive | ||
// actual : 2018 | ||
// expected: 2012 | ||
}); | ||
``` | ||
|
||
## See also | ||
|
||
* Use [`assert.propContains()`](./propContains.md) to partially compare an object. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
// For passing tests, see /test/main/assert.js | ||
// | ||
// TODO: After we migrate running of tests in browsers to use TAP, | ||
// merge these two files and verify them by TAP output instead of | ||
// by boolean passing (akin to what we do with Node.js already). | ||
|
||
QUnit.module('assert', function () { | ||
QUnit.test('true [failure]', function (assert) { | ||
assert.true(false); | ||
}); | ||
|
||
QUnit.test('false [failure]', function (assert) { | ||
assert.false(true); | ||
}); | ||
|
||
QUnit.test('closeTo [failure]', function (assert) { | ||
assert.closeTo(1, 2, 0); | ||
assert.closeTo(1, 2, 1); | ||
assert.closeTo(2, 7, 1); | ||
|
||
assert.closeTo(7, 7.3, 0.1); | ||
assert.closeTo(7, 7.3, 0.2); | ||
assert.closeTo(2011, 2013, 1); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,70 @@ | ||
# name: test with failing assertion | ||
# command: ["qunit","assert-failure.js"] | ||
|
||
TAP version 13 | ||
not ok 1 assert > true [failure] | ||
--- | ||
message: failed | ||
severity: failed | ||
actual : false | ||
expected: true | ||
stack: | | ||
at /qunit/test/cli/fixtures/assert-failure.js:9:16 | ||
... | ||
not ok 2 assert > false [failure] | ||
--- | ||
message: failed | ||
severity: failed | ||
actual : true | ||
expected: false | ||
stack: | | ||
at /qunit/test/cli/fixtures/assert-failure.js:13:17 | ||
... | ||
not ok 3 assert > closeTo [failure] | ||
--- | ||
message: value should be within 0 inclusive | ||
severity: failed | ||
actual : 1 | ||
expected: 2 | ||
stack: | | ||
at /qunit/test/cli/fixtures/assert-failure.js:17:12 | ||
... | ||
--- | ||
message: value should be within 1 inclusive | ||
severity: failed | ||
actual : 2 | ||
expected: 7 | ||
stack: | | ||
at /qunit/test/cli/fixtures/assert-failure.js:19:12 | ||
... | ||
--- | ||
message: value should be within 0.1 inclusive | ||
severity: failed | ||
actual : 7 | ||
expected: 7.3 | ||
stack: | | ||
at /qunit/test/cli/fixtures/assert-failure.js:21:12 | ||
... | ||
--- | ||
message: value should be within 0.2 inclusive | ||
severity: failed | ||
actual : 7 | ||
expected: 7.3 | ||
stack: | | ||
at /qunit/test/cli/fixtures/assert-failure.js:22:12 | ||
... | ||
--- | ||
message: value should be within 1 inclusive | ||
severity: failed | ||
actual : 2011 | ||
expected: 2013 | ||
stack: | | ||
at /qunit/test/cli/fixtures/assert-failure.js:23:12 | ||
... | ||
1..3 | ||
# pass 0 | ||
# skip 0 | ||
# todo 0 | ||
# fail 3 | ||
|
||
# exit code: 1 |
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters