Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
enzyme-adapter-preact-pure
Advanced tools
This is an adapter to support using the Enzyme UI component testing library with Preact. For documentation, please see the testing guide on the PreactJS website.
Version 3.x of the adapter supports Preact v10+. Earlier versions support both Preact v8 and v10.
Add the library to your development dependencies:
# If using npm
npm install --save-dev enzyme-adapter-preact-pure
# If using yarn
yarn add --dev enzyme-adapter-preact-pure
Then in the setup code for your tests, configure Enzyme to use the adapter provided by this package:
import { configure } from 'enzyme';
import Adapter from 'enzyme-adapter-preact-pure';
configure({ adapter: new Adapter() });
Once the adapter is configured, you can write Enzyme tests for your Preact UI components following the Enzyme docs. The full DOM rendering, shallow rendering and string rendering modes are supported.
For runnable example projects, see the examples/ directory. To run the examples locally, clone this repository, then run:
cd examples/<project name>
npm install
npm test
The general intent is that tests written using Enzyme + React can be easily made to work with Enzyme + Preact or vice-versa. However there are some differences in behavior between this adapter and Enzyme's React adapters to be aware of:
When using Enzyme's shallow rendering mode, this adapter always invokes the
component's lifecycle methods (componentDidUpdate
etc.).
The disableLifecycleMethods
option is not respected.
React's shallow rendering does not create actual DOM nodes. The shallow rendering implemented by this adapter does. It works by simply by rendering the component as normal, except making any child components output only the children passed to them. In other words, during shallow rendering, all child components behave as if they were defined like this:
function ShallowRenderedChild({ children }) {
return children;
}
This means that any side effects that rendered DOM elements have, such as <img>
elements loading images, will still execute.
If you are converting a React Enzyme test suite to use Preact, try out our CompatShallowRenderer
. This renderer is an alternate shallow renderer to the default that uses a custom diffing algorithm that mirrors the Preact diff algorithm but only shallowly renders elements, similarly to what react-shallow-render
does for React components. This renderer has a couple of behaviors that more closely resembles the React adapters, including:
disableLifecycleMethods
option is respectedTo enable the CompatShallowRenderer
, pass it into the shallowRenderer
Adapter option when configuring Enzyme:
import { configure } from 'enzyme';
import Adapter from 'enzyme-adapter-preact-pure';
import { CompatShallowRenderer } from 'enzyme-adapter-preact-pure/compat';
// Setup Enzyme
configure({
adapter: new Adapter({
ShallowRenderer: CompatShallowRenderer,
}),
});
The simulate
API does not dispatch actual DOM events in the React adapters, it just calls
the corresponding handler. The Preact adapter does dispatch an actual event
using element.dispatchEvent(...)
. Because this behavior, the Preact adapters can only simulate events on real DOM nodes, not Components.
If you'd like to simulate events on Components, enable the simulateEventsOnComponents
option in the Adapter options. This option changes the previous behavior of how events were dispatched (by directly invoking event handlers instead of dispatching an event) and so is disabled by default. Enabling this option is useful if you are migrating an Enzyme test suite from React to Preact.
import { configure } from 'enzyme';
import Adapter from 'enzyme-adapter-preact-pure';
// Setup Enzyme
configure({
adapter: new Adapter({
simulateEventsOnComponents: true,
}),
});
By default, the Preact string renderer renders your component into the DOM and then returns the innerHTML
of the DOM container. This behavior means string rendering requires a DOM environment.
If you'd like to run tests that use the string renderer in a test environment that does not have a DOM, pass preact-render-to-string
into the renderToString
Adapter option. Enabling this option is useful if you are migrating an Enzyme test suite from React to Preact.
import { configure } from 'enzyme';
import Adapter from 'enzyme-adapter-preact-pure';
import renderToString from 'preact-render-to-string';
// Setup Enzyme
configure({
adapter: new Adapter({
renderToString,
}),
});
setState
synchronously re-renders the component in React, except in event
handlers.
Preact on the other hand by default batches together calls to setState
within
the same tick of the event loop and schedules a render to happen in a future
microtask. React's behavior may change in a future release.
To make writing tests easier, the Preact adapter will apply any pending state updates and re-render when:
mount
or shallow
wrapper.setProps
, wrapper.simulate
or
wrapper.setState
wrapper.update
is called explicitly by a testThe consequences of this when writing tests are that any state updates triggered
outside of an Enzyme method call will not be reflected in the rendered DOM until
wrapper.update
is called. Note this function also needs to be called when using
React, as it synchronizes Enzyme's snapshot of the output with the actual DOM
tree.
Example:
const wrapper = shallow(<ParentComponent />);
// Trigger a state update outsize of Enzyme.
wrapper.find(ChildComponent).props().onClick();
// Update the Enzyme wrapper's snapshot.
wrapper.update();
// Test that parent component updated as expected.
When using the Hooks API you also
need to wrap any code which triggers effects in an
act call in order to flush
effects and trigger a re-render. The initial render and calls to APIs such as
setProps
or simulate
are automatically wrapped in act
for you.
In Preact the act
function is available in the "preact/test-utils" package.
import { act } from 'preact/test-utils';
// Any effects scheduled by the initial render will run before `mount` returns.
const wrapper = mount(<Widget showInputField={false} />);
// Perform an action outside of Enzyme which triggers effects in the parent
// `Widget`. Since Enzyme doesn't know about this, we have to wrap the calls
// with `act` to make effects execute before we call `wrapper.update`.
act(() => {
wrapper.find(ChildWidget).props().onButtonClicked();
});
// Update the Enzyme wrapper's snapshot
wrapper.update();
In order to support Enzyme's class selectors, class
props on Preact components
are mapped to className
.
import { mount } from 'enzyme';
const wrapper = mount(<div class="widget" />);
wrapper.props(); // Returns `{ children: [], className: 'widget' }`
wrapper.find('.widget').length; // Returns `1`
This package has the same interface as the official enzyme-adapter-react-$version packages. If you are using preact/compat, you can alias enzyme-adapter-react-$version to this package in the same way as preact/compat.
This package is compatible with TypeScript and ships with type declarations.
In order to mix Enzymes types from @types/enzyme
with Preact, you will need
to include some extensions to the "preact" types which are provided by this
project.
To do that, add the following line to one of the source files or .d.ts
files
for your project:
/// <reference types="enzyme-adapter-preact-pure" />
See the TypeScript example in examples/typescript
for a runnable example.
After cloning the repository, you can build it and run tests as follows:
# Install dependencies.
yarn install
# Build the adapter library.
yarn build
# Run tests.
yarn test
# Run tests against a custom build of Preact.
yarn test --preact-lib <path to Preact bundle>
New releases of this package are created using np.
master
branchnp <semver-type>
to create the release, where <semver-type>
is the
category of release according to Semantic Versioning, typically minor
.Can I use this library to test components that use hooks?
Yes. This library supports components that use the "Hooks" APIs available in
Preact v10+. You may need to use the act
function from preact/test-utils
to flush effects synchronously in certain places. See the notes above about
state updates in tests.
Why does the package name have a "-pure" suffix?
The name has a "-pure" suffix to distinguish it from enzyme-adapter-preact package which indirectly depends on React. This library is a "pure" Preact adapter which does not require Preact's React compatibility add-on.
[4.1.0] - 2023-01-05
Adds a new shallow renderer that more closely matches the behavior of the
React 16 shallow renderer. This new renderer can be enabled by importing
CompatShallowRenderer
from enzyme-adapter-preact-pure/compat
and passing
it in the ShallowRenderer
Adapter option.
The previous shallow renderer rendered components into a DOM and modified the component's output so that all children return null to prevent rendering further down the tree. The compat shallow renderer is a custom implementation of Preact's diffing algorithm that only shallow renders the given component and does not recurse down the VDOM tree. It's behavior more closely matches the React 16 Enzyme adapter and it well suited for migrating an Enzyme test suite from React to Preact.
Support more return types (e.g. booleans, numbers, BigInts) from components
Add an option (renderToString
) to allow passing in a custom string renderer
to use for Enzyme's 'string' renderer instead of rendering into the DOM and
reading the HTML output. It is expected that renderToString
from
preact-render-to-string
is passed into this option. This change enables
using the string renderer in non-DOM environments and more closely matches the
React adapter's behavior.
Add a feature flag (simulateEventsOnComponents
) for supporting simulating
events on Components
#211
This new feature flag turns on behavior that enables calling .simulate
directly on Components. For shallow rendering, this directly calls the
component's corresponding prop. For mount rendering, it finds the first DOM
node in the Component, and dispatches the event from it.
NOTE: This flag changes the behavior of calling simulate
on shallow rendered
host (a.k.a DOM) nodes. When this flag is off, simulate
dispatches a native
DOM event on the host node. When this flag is turned on, simulate
directly
calls the prop of the event handler with arguments passed to simulate
.
The behavior turned on by this flag matches the behavior of the React 16 Enzyme adapter.
FAQs
Enzyme adapter for Preact
The npm package enzyme-adapter-preact-pure receives a total of 7,327 weekly downloads. As such, enzyme-adapter-preact-pure popularity was classified as popular.
We found that enzyme-adapter-preact-pure demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.