v11.0.0-canary.1
Pre-release11.0.0-canary.1 (2023-01-16)
💥 BREAKING CHANGES 💥
-
In previous versions, the lodash.mergeWith customizer skipped source properties
that resolved toundefined. With this version, the customizer now unsets these properties
(sets them toundefined), allowing the end user to easily unset defaults (e.g.filename). -
babelOptions.filenameis now set tofilepath
by default rather thanundefined. -
Implicit "global" options merging is no longer supported
In previous versions of babel-plugin-tester, any test object and fixture
configuration option could be passed directly to babel-plugin-tester and apply
"globally" across all test objects and fixtures. This was even the case for
options that made no sense in a "global" context, such asonly,skip, and
code. In this version of babel-plugin-tester, only options explicitly listed
in the documentation can be passed directly and applied globally. Unrecognized
"rest" options are silently ignored. -
Test/fixture configuration is resolved early and consistently
In previous versions of babel-plugin-tester, test object and fixture
configuration options were resolved in various places, with some options getting
finalized beforeit(...)anddescribe(...)were called and others being
determined as Jest was executing the test. In this version, all configuration
options are resolved and finalized beforeit(...)anddescribe(...)are
called. This also means configurations are finalized before hooks like
beforeAllget called by the testing framework. -
Fixture configuration schema is standardized
In previous versions of babel-plugin-tester, you could provide any key to
options.jsonand it would be passed as-is to the plugin under test. This made
it impossible to allow fixtures to be configured with the same flexibility as
test objects. In this version of babel-plugin-tester, fixtureoptions.json
(andoptions.js) files must return a standard set of options. Non-standard
properties are silently ignored. For instance: to pass options to the plugin
under test, they must be provided viapluginOptions. -
Global
setup/teardownno longer overwrites local versionsIn previous versions of babel-plugin-tester, test-level
setupandteardown
functions overrode globalsetupandteardownfunctions. In this version of
babel-plugin-tester, the globalsetupandteardownfunctions will be called
alongside their test-level counterparts for each test and in a well-defined
order (see documentation). -
TypeErrorfor config error;AssertionErrorfor test errorAll configuration-related issues now throw
TypeErrorinstead of
AssertionError.AssertionErroris now exclusively used for failing tests.
Additionally, the text of some error messages has been updated. -
erroronly captures exceptions from Babelerror(akathrows) no longer potentially captures exceptions thrown by the
formatResultfunction. If theformatResultfunction throws, the entire test
will fail immediately. -
errorno longer accepts arbitrary class constructorserror(akathrows) no longer accepts arbitrary class constructors. Any
provided class constructor must extendError, e.g. built-ins like
SyntaxErroror custom error classes likeclass MyError extends Error. Thanks
to the nature of JavaScript, providing a class constructor that does not
extendErrorwill lead to undefined behavior. -
Built-in TypeScript support
TypeScript types are now included within the package itself, obviating the need
to install a separate types package. Installing the old types package alongside
this version of babel-plugin-tester will cause conflicts. -
Global
describeanditfunctions must be definedbabel-plugin-tester will refuse to run if
describe,it,it.only, or
it.skipare not globally available. -
All test titles are now numbered
All test titles are now numbered (e.g.
"1. ...","2. ...", etc), including
fixtures tests and tests with custom titles. -
Minimum recommended node version bumped from
10.13.0 to 14.20.0 -
Plugin names are once again automatically determined
by analyzing the return value of the plugin function. Though this is
implemented in a backwards-compatible way, there is a
small caveat.
✨ Features
- Add support for testing presets (73b90b3)
- Implement default filepath inference using Error stack trace (9d1b321)
- src: add
exec/execFixturesupport via Node's VM module (4754f42) - src: add support for "only", "skip", and "title" test options in fixtures (#90) (89b58b5)
- src: add support for arbitrary run order of plugin under test (#91) (8c8b858)
- src: add support for loading prettier configuration files in fixtures (f54deda)
- src: add TEST_SKIP/TEST_NUM_SKIP/TEST_ONLY/TEST_NUM_ONLY env variable support (13626d1)
- src: bring back (lightweight) plugin name inference (#92) (f9ad903)
- src: implement
titleNumberingandrestartTitleNumberingoptions (09e792d) - src: implement standard
setup/teardownrun order (4ea283f) - src: provide debug output support via debug package (4c7c6e7)
- Windows support (f214995)
🪄 Fixes
- src: ensure test function errors are not swallowed by teardown function errors (2acfe37)
- src: fix fixtureOutputExt being ignored in root options.json (#89) (481be19)
- src: fix plugin run order for fixtures to match tests (#88) (fbb6c19)
⚙️ Build system
- deps: bump prettier from 2.8.0 to 2.8.1 (#98) (0bdb351)
- package: restore @babel/[email protected] as minimum supported version (00712c0)
- Transmute codebase to TypeScript (#96) (5f588e9)
- Update tooling (d5b4d9c)
🔥 Reverted
- "test: make debugging names shorter and sweeter" (0b869bb)