Changelog
8.4.0 / 2021-05-07
options.require
to Mocha constructor for root hook
plugins on parallel runs (@juergba)top-level await
and ESM test files (@juergba)Also thanks to @outsideris for various improvements on our GH actions workflows.
Changelog
8.3.2 / 2021-03-12
require
interface (@alexander-fenster)Changelog
8.3.0 / 2021-02-11
require
error when bundling Mocha with Webpack (@devhazem)Also thanks to @outsideris and @HyunSangHan for various fixes to our website and documentation.
Changelog
8.2.1 / 2020-11-02
Fixed stuff.
Promise
rejections and erroneous "done()
called twice" errors (@boneskull)MaxListenersExceededWarning
in watch mode (@boneskull)Also thanks to @akeating for a documentation fix!
Changelog
8.2.0 / 2020-10-16
The major feature added in v8.2.0 is addition of support for global fixtures.
While Mocha has always had the ability to run setup and teardown via a hook (e.g., a before()
at the top level of a test file) when running tests in serial, Mocha v8.0.0 added support for parallel runs. Parallel runs are incompatible with this strategy; e.g., a top-level before()
would only run for the file in which it was defined.
With global fixtures, Mocha can now perform user-defined setup and teardown regardless of mode, and these fixtures are guaranteed to run once and only once. This holds for parallel mode, serial mode, and even "watch" mode (the teardown will run once you hit Ctrl-C, just before Mocha finally exits). Tasks such as starting and stopping servers are well-suited to global fixtures, but not sharing resources--global fixtures do not share context with your test files (but they do share context with each other).
Here's a short example of usage:
// fixtures.js
// can be async or not
exports.mochaGlobalSetup = async function () {
this.server = await startSomeServer({port: process.env.TEST_PORT});
console.log(`server running on port ${this.server.port}`);
};
exports.mochaGlobalTeardown = async function () {
// the context (`this`) is shared, but not with the test files
await this.server.stop();
console.log(`server on port ${this.server.port} stopped`);
};
// this file can contain root hook plugins as well!
// exports.mochaHooks = { ... }
Fixtures are loaded with --require
, e.g., mocha --require fixtures.js
.
For detailed information, please see the documentation and this handy-dandy flowchart to help understand the differences between hooks, root hook plugins, and global fixtures (and when you should use each).
test.js
) now usable with --extension
option (@jordanstephens).js
, .test.js
) now usable with --extension
option (@boneskull)json
reporter now contains speed
("fast"/"medium"/"slow") property (@wwhurin)For implementors of custom reporters:
Runner.prototype.workerReporter()
); reporters should subclass ParallelBufferedReporter
in mocha/lib/nodejs/reporters/parallel-buffered
Runner.prototype.linkPartialObjects()
); use if strict object equality is needed when consuming Runner
event dataRunner.prototype.isParallelMode()
)npm
v6.x causing some of Mocha's deps to be installed when mocha
is present in a package's devDependencies
and npm install --production
is run the package's working copy (@boneskull)nyc
with Mocha in parallel mode (@boneskull)lookupFiles()
in mocha/lib/utils
, which was broken/missing in Mocha v8.1.0; it now prints a deprecation warning (use const {lookupFiles} = require('mocha/lib/cli')
instead) (@boneskull)Thanks to @AviVahl, @donghoon-song, @ValeriaVG, @znarf, @sujin-park, and @majecty for other helpful contributions!
Changelog
8.1.3 / 2020-08-28
Mocha.utils.lookupFiles()
and Webpack compatibility (both broken since v8.1.0); Mocha.utils.lookupFiles()
is now deprecated and will be removed in the next major revision of Mocha; use require('mocha/lib/cli').lookupFiles
instead (@boneskull)Changelog
8.1.2 / 2020-08-25
Changelog
8.1.1 / 2020-08-04
Changelog
8.1.0 / 2020-07-30
In this release, Mocha now builds its browser bundle with Rollup and Babel, which will provide the project's codebase more flexibility and consistency.
While we've been diligent about backwards compatibility, it's possible consumers of the browser bundle will encounter differences (other than an increase in the bundle size). If you do encounter an issue with the build, please report it here.
This release does not drop support for IE11.
Other community contributions came from @Devjeel, @Harsha509 and @sharath2106. Thank you to everyone who contributed to this release!
Do you read Korean? See this guide to running parallel tests in Mocha, translated by our maintainer, @outsideris.
mocha init
(@boneskull)delay
option in browser (@craigtaub)--enable-source-maps
with Mocha (@bcoe)