Skip to content

Releases: avajs/ava

v6.1.2

28 Feb 20:56
5d48c95
Compare
Choose a tag to compare

What's Changed

  • Fix throws assertions rejecting falsy values when any: true by @gibson042 in #3313

Full Changelog: v6.1.1...v6.1.2

v6.1.1

29 Jan 21:07
2e0c2b1
Compare
Choose a tag to compare

What's Changed

Full Changelog: v6.1.0...v6.1.1

v6.1.0

21 Jan 20:11
aae39b2
Compare
Choose a tag to compare

What's Changed

  • Implement registerCompletionHandler() by @novemberborn in #3283

    AVA 6 expects test code to clean up gracefully when the tests are complete, allowing the test environment (worker thread or child process) to exit. If this does not happen, AVA will report a timeout. You can use registerCompletionHandler() to perform any other clean up (or indeed exit the process) after AVA has completed the test execution. See the description here.

  • Fix potential bug with watch mode when no failed test files are written by @novemberborn in #3287

  • Fix ava/internal ESM type module by @codetheweb in #3292

Full Changelog: v6.0.1...v6.1.0

v6.0.1

06 Dec 21:21
5975b60
Compare
Choose a tag to compare

What's Changed

Full Changelog: v6.0.0...v6.0.1

v6.0.0

04 Dec 21:38
cf7a288
Compare
Choose a tag to compare

Breaking Changes

  • AVA now requires Node.js versions 18.18, 20.8 or 21. Versions 14 and 16 are no longer supported. #3251 #3216

  • When tests finish, worker threads or child processes are no longer exited through proces.exit(). If your test file does not exit on its own, the test run will time out. #3260

  • Changes to watch mode #3218:

    • Watch mode can no longer be started via the ava.config.* or package.json configuration.
    • The ignoredByWatcher configuration has moved to the watchMode object, under the ignoreChanges key.
    • Watch mode now uses the built-in fs.watch() in recursive mode. This is supported on Linux in Node.js 20 or newer, and MacOS and Windows in Node.js 18 as well. There are caveats to keep in mind.
  • Failed assertions now throw, meaning that any subsequent code is not executed. This also impacts the type definitions. #3246

  • Only native errors are now considered errors by the t.throws() and t.throwsAsync() assertions. Object.create(Error.prototype) is not a native error. #3229

  • Changes to modules loaded through the require configuration #3184:

    • If such modules export a default function, this function is now invoked.
    • Local files are loaded through @ava/typescript if necessary.

Improvements

Rewritten watcher

The watcher has been rewritten. It鈥檚 now built on fs.watch() in recursive mode.

@vercel/nft is used to perform static dependency analysis, supporting ESM and CJS imports for JavaScript & TypeScript source files. This is a huge improvement over the previous runtime tracking of CJS imports, which did not support ESM.

Integration with @ava/typescript has been improved. The watcher can now detect a change to a TypeScript source file, then wait for the corresponding build output to change before re-running tests.

The ignoredByWatcher configuration has moved to the watchMode object, under the ignoreChanges key.

See #3218 and #3257.

Failed assertions now throw

Assertions now throw a TestFailure error when they fail. This error is not exported or documented and should not be used or thrown manually. You cannot catch this error in order to recover from a failure, use t.try() instead.

All assertions except for t.throws() and t.throwsAsync() now return true when they pass. This is useful for some of the assertions in TypeScript where they can be used as a type guard.

Committing a failed t.try() result now also throws.

See #3246.

t.throws() and t.throwsAsync() can now expect any error

By default, the thrown error (or rejection reason) must be a native error. You can change the assertion to expect any kind of error by setting any: true in the expectation object:

t.throws(() => { throw 'error' }, {any: true})

See #3245 by @adiSuper94.

The require configuration is now more powerful

It now loads ES modules.

Local files are loaded through @ava/typescript if necessary, so you can also write these in TypeScript.

If there is a default export function, it is invoked after loading. The function is awaited so it can do asynchronous setup before further modules are loaded. Arguments from the configuration can be passed to the function (as a [structured clone](https://developer.mozilla.org/en-US/docs/Web/API/structuredClone)).

See #3184 by @sculpt0r.

Other changes worth noting

  • Internal events can now be observed (experimentally). See #3247 by @codetheweb. It鈥檚 experimental and undocumented.
  • You can now use t.timeout.clear() to restore a previous t.timeout(). #3221
  • Code coverage is flushed to disk at opportune moments. #3220

New Contributors

Full Changelog: v5.3.1...v6.0.0

v5.3.1

16 Jun 16:42
306e37c
Compare
Choose a tag to compare

What's Changed

  • Update t.like() to support Symbol keys and ignore non-enumerable properties by @gibson042 in #3209
  • Fix circular selector detection in t.like() by @novemberborn in #3212

Full Changelog: v5.3.0...v5.3.1

v5.3.0

25 May 07:02
568fe40
Compare
Choose a tag to compare

What's Changed

  • Support arrays in t.like() assertions by @tommy-mitchell in #3185
  • Recognize typical assertion errors (expect and assert) and use their formatting by @Irvenae in #3187

New Contributors

Full Changelog: v5.2.0...v5.3.0

v5.2.0

06 Feb 20:42
1353b08
Compare
Choose a tag to compare

What's Changed

New Contributors

Full Changelog: v5.1.1...v5.2.0

v5.1.1

15 Jan 21:02
c749348
Compare
Choose a tag to compare

What's Changed

Full Changelog: v5.1.0...v5.1.1

v5.1.0

14 Nov 14:10
4ecfe7d
Compare
Choose a tag to compare

What's Changed

  • Output logs for tests that remain pending when AVA exits by @kevo1ution in #3125
  • Check for --config file extensions after they fail to load, allowing custom loaders by @panva in #3135

New Contributors

Full Changelog: v5.0.1...v5.1.0