1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403
|
---
layout: layout
title: Change Log
---
## 12.0 2018-05-16
Breaking change to support deep matching and pattern matching of
objects in `Set` collections. (Previously, `Set` contents would only
match if they were equal.)
## 11.0 2017-11-26
Significant refactoring and speed improvements.
Add [`t.skip()`](/api/#tskipname-options-function) and
[`t.todo()`](/api/#tskipname-options-function) methods.
Add
[`t.resolves(promise)`](/asserts/#tresolvespromise--fn-message-extra)
to assert that a Promise object (or function that returns a Promise)
will resolve.
Add [`t.resolveMatch(promise,
pattern)`](/asserts/#tresolvematch-promise--fn-wanted-message-extra)
to assert that a Promise object (or function that returns a Promise)
will resolve to a value matching the supplied pattern.
Add support for [snapshot testing](/snapshots/).
Improved implementation of [Mocha-like DSL](/mochalike/)
### BREAKING CHANGES:
- Classes are true ECMAScript classes now, so constructors cannot be
called without `new`.
- Unnamed subtests are not given the name `(unnamed test)`
- The `t.current()` method is removed
## 10.7 2017-06-24
Add support for [filtering tests using 'only'](/only/).
Don't show grep/only skips in the default reporter output.
## 10.6 2017-06-23
Add support for [filtering tests using regular expressions](/grep/).
## 10.5 2017-06-20
Add support for Maps and Sets in `t.match()`, `t.same()`, and
`t.strictSame()`.
## 10.4 2017-06-18
Add
[`t.rejects()`](/asserts/#trejectspromise--fn-expectederror-message-extra)
assertion.
## 10.3 2017-03-01
* Add `-o` `--output-file` to put the raw TAP to a file.
* Never print Domain objects in YAML. They're humongous.
* Don't lose error messages in doesNotThrow
## 10.2 2017-02-18
Variety of minor cleanup fixes, and a debug mode.
* Respond to TAP_DEBUG and NODE_DEBUG environs
* Catch errors thrown in teardown handlers
* Improve root-level thrown error reporting
* don't let an occupied test slip past endAll
* Handle unhandledRejection as a root TAP error
* better inspect data
* If results are synthetically set, don't clobber when parser ends
* monkeypatch exit as well as reallyExit
## 10.1 2017-02-07
Added support for source maps. Stack traces in your jsx and
coffeescript files will now be helpful!
Added the `-J` option to auto-calculate the number of cores on your
system, and run that many parallel jobs.
## 10.0 2017-01-28
Full rewrite to support [parallel tests](/parallel/). Pass `-j4` on
[the command-line](/cli/) to run 4 test files at once in parallel.
This also refactors a lot of the grimier bits of the codebase, splits
the one mega-Test class into a proper OOP hierarchy, and pulls a bunch
of reusable stuff out into modules.
Somehow, in the process, it also fixed an odd timing bug with
`beforeEach` functions that returned promises.
It truly is a luxury to have a massive pile of tests when it's time to
refactor.
The [mocha-like DSL](/mochalike/) is now much more functional, and
documented.
Now supports passng `-T` or `--timeout=0` to the [CLI](/cli/) to not
impose a timeout on tests.
## 9.0 2017-01-07
Buffered subtests!
This adds support for outputting subtests in the
[buffered](/subtests/) format, where the summary test point _precedes_
the indented subtest output, rather than coming afterwards.
This sets the stage for parallel tests, coming in v10. Mostly, it's
just an update to [tap-parser](http://npm.im/tap-parser), and a lot of
internal clean-up.
Update [nyc](http://npm.im/nyc) to v10, which includes some fixes for
covering newer JavaScript language features, and support for implicit
function names.
Also: remove a lot of excess noise and repetitive stack traces in yaml
diagnostics.
## 8.0 2016-10-25
Update `tmatch` to version 3. This makes regular expressions test
against the stringified versions of the test object in all `t.match()`
methods. It's a breaking change because it can cause tests to pass
that would have failed previously, or vice versa. However, it is more
expected, and strongly recommended.
Handle unfinished promise-awaiting tests when the process exits.
Show yaml diagnostics for the first "missing test" failure when a plan
is not met, so that the plan can be more easily debugged.
(Diagnostics are still excluded for the additional "missing test"
failures that are generated, to reduce unnecessary noise.)
Make coverage MUCH FASTER by turning on nyc caching.
## 7.1 2016-09-06
Remove a race condition in how `Bail out!` messages got printed when
setting the "bail on failure" option in child tests. Now, whether
it's a child process or just a nested subtest, it'll always print
`Bail out!` at the failure level, then again at the top level, with
nothing in between.
Support `{ diagnostic: false }` in the options object for failing
tests to suppress yaml diagnostics.
Diagnostics are now shown when a synthetic `timeout` failure is
generated for child test processes that ignore `SIGTERM` and must be
killed with `SIGKILL`.
## 7.0 2016-08-27
Move `# Subtest` commands to the parent level rather than the child
level, more like Perl's `Test2` family of modules. This is more
readable for humans.
Update to version 2 of the tap parser. (This adds support for putting
the `# Subtest` commands at the parent level.)
Support use of a `--save` and `--bail` together. Any test files that
were skipped due to a bailout are considered "not yet passed", and so
get put in the save file.
Forcibly kill any spawned child process tests when the root test exits
the parent process, preventing zombie test processes.
Handle `SIGTERM` signals sent to the main process after the root test
has ended. This provides more useful output in the cases where the
root test object has explicitly ended or satisfied its plan, but a
timeout still occurs because of pending event loop activity.
Prevent `for..in` loops from iterating inherited keys in many cases,
providing resilience against `Object.prototype` mutations.
Add the `--100` flag to set statements, functions, lines, and branches
to 100% coverage required.
## 6.3 2016-07-30
Let `t.doesNotThrow` take a string as the first argument.
Bump `nyc` up to version 7.
The tap `lib/` folder is excluded from all stack traces.
## 6.2 2016-07-15
Add the `--test-arg=<argument>` option.
## 6.1 2016-07-01
Add support for `{diagnostic: true}` in test and assert options, to
force a YAML diagnostic block after passing child tests and
assertions.
## 6.0 2016-06-30
Only produce output on stdout if the root TAP test object is
interacted with in some way. Simply doing `require('tap')` no longer
prints out the minimum TAP output, which means that you can interact
with, for example, `var Test = require('tap').Test` without causing
output side effects.
Add `~/.taprc` yaml config file support.
Add the `--dump-config` command line flag to print out the config
options.
Document environment variables used.
Built-in CodeCov.io support has been removed. If you were relying on
this, you can add `codecov` as a devDependency, and then add this to
the scripts block in your `package.json` file:
{
"scripts": {
"test": "tap test/*.js --coverage",
"posttest": "tap --coverage-report=lcov | codecov"
}
}
## 5.8 2016-06-24
Make coverage piping errors non-fatal.
Clean up argument ordering logic in `t.throws()`. This now works for
almost any ordering of arguments, which is unfortunately necessary for
historical reasons. Additionally, you can now pass in an `Error`
class to verify the type, which would previously not work properly in
some cases.
## 5.7 2016-02-22
Report timeout errors in child test scripts much more diligently.
On Unix systems, the child process handles `SIGTERM` signals by
assuming that things are taking too long, dumping a report of all
active handles and requests in process, and exiting in error.
On Windows systems (where `SIGTERM` is always uncatchably fatal), or
if a Unix child test process doesn't exit within 1 second (causing a
fatal `SIGKILL` to be sent), the parent generates more comprehensive
output to indicate that the child test exited due to a timeout.
## 5.6 2016-02-17
Update `tmatch` to version 2. You can now test objects by supplying
their constructor, so `t.match(x, { foo: Function, name: String })`
would verify that the object has a `name` string and a `foo` method.
## 5.5 2016-02-15
Add the `t.assertAt` and `t.assertStack` properties, to override where
an assertion was effectively called from.
## 5.4 2016-01-31
Support passing in a class to `t.throws`, rather than an Error sample
object.
## 5.3 2016-01-31
Return a `Promise` object from `t.test()`, `t.spawn()`, and
`t.stdin()`.
## 5.2 2016-01-26
Adds `t.beforeEach()` and `t.afterEach()`.
## 5.1 2016-01-16
All about the cli flags!
Support `--node-arg=...` and `--nyc-arg=...` command line flags.
Add support for coverage checking using `--statements=95` etc.
Test for executable-ness more consistently across platforms.
## 5.0 2016-01-03
Make it impossible to `try/catch` out of plan/end abuses. Calling
`t.end()` more than once, or having a number of tests that doesn't
match the `plan()` number, is always a failure.
Push thrown errors to the front of the action queue. This means that,
even if other things are pending, an uncaught exception or a plan/end
bug, will always take the highest priority in what gets output.
Many updates to nyc, spawn-wrap, and foreground-child, so that tap now
reliably works on Windows (and a [ci to prove
it](https://ci.appveyor.com/project/isaacs/node-tap).)
Moved into the [tapjs org](https://github.com/tapjs).
## 4.0 2015-12-30
Raise an error if `t.end()` is explicitly called more than once. This
is a breaking change, because it can cause previously-passing tests to
fail, if they did `t.end()` in multiple places.
Support promises returned by mochalike functions.
## 3.1 2015-12-29
Support sending coverage output to both codecov.io and coveralls.io.
## 3.0 2015-12-29
Upgrade to nyc 5. This means that `config.nyc.exclude` arrays in
`package.json` now take globs instead of regular expressions.
## 2.3 2015-11-18
Use the name of the function supplied to `t.test(fn)` as the test name
if a string name is not provided.
Better support for sparse arrays.
## 2.2 2015-10-23
Add support for Codecov.io as well as Coveralls.io.
Catch failures that come after an otherwise successful test set.
Fix timing of `t.on('end')` so that event fires *before* the next
child test is started, instead of immediately after it.
`t.throws()` can now be supplied a regexp for the expected Error
message.
## 2.1 2015-10-06
Exit in failure on root test bailout.
Support promises returned by `t.test(fn)` function.
## 2.0 2015-09-27
Update matching behavior using [tmatch](http://npm.im/tmatch). This
is a breaking change to `t.match`, `t.similar`, `t.has`, etc., but
brings them more in line with what people epirically seem to expect
these functions to do.
Deal with pending handles left open when a child process gets a
`SIGTERM` on timeout.
Remove domains in favor of more reliable and less invasive state and
error-catching bookkeeping.
## 1.4 2015-09-02
Add `t.contains()` alias for `t.match()`.
Use `deeper` for deep object similarity testing.
Treat unfinished tests as failures.
Add support for pragmas in TAP output.
## 1.3 2015-06-23
Bind all Test methods to object.
Add `t.tearDown()`, `t.autoend()`, so that the root export is Just
Another Test Object, which just happens to be piping to stdout.
Support getting an error object in bailout()
## 1.2 2015-05-26
Better support for exit status codes.
## 1.1 2015-05-20
Add coverage using nyc.
If a `COVERALLS_REPO_TOKEN` is provided, then run tests with coverage,
and pipe to coveralls.
## 1.0 2015-05-06
Complete rewrite from 0.x.
Child tests implemented as nested TAP output, similar to Perl's
`Test::More`.
## 0.x
The 0.x versions used a "flattened" approach to child tests, which
requires some bookkeeping.
It worked, mostly, but its primary success was inspiring
[tape](http://npm.im/tape) and tap v1 and beyond.
|