ReScript bindings for testing-library/react.
npm install --save-dev rescript-react-testing-library
# or yarn
yarn add --dev rescript-react-testing-library
Update your bsconfig file:
{
"bs-dev-dependencies": ["rescript-react-testing-library"]
}
open Jest
open Expect
open ReactTestingLibrary
// Make it pipe-first:
let toMatchSnapshot = a => a |> Expect.toMatchSnapshot
module DummyComponent = {
@react.component
let make = () => {
<div>
<label> {React.string("Choose a color")} </label>
<select>
<option> {React.string("Red")} </option>
<option> {React.string("Green")} </option>
<option onClick={_ => Js.log("Blue")}> {React.string("Blue")} </option>
</select>
</div>
}
}
describe("DummyComponent", () => {
beforeEach(() => {
<DummyComponent />->renderOnScreen
})
test("render Red option", () => {
screen
->getByRole(~matcher=#Str("option"), ~options=makeByRoleOptions(~name="Red", ()))
->expect
->toMatchSnapshot
})
test("render Green option", () => {
screen
->getByRole(~matcher=#Str("option"), ~options=makeByRoleOptions(~name="Green", ()))
->expect
->toMatchSnapshot
})
test("render Blue option", () => {
screen
->getByRole(~matcher=#Str("option"), ~options=makeByRoleOptions(~name="Blue", ()))
->expect
->toMatchSnapshot
})
})