Skip to content

brnrdog/rescript-react-testing-library

Repository files navigation

ReScript React Testing Library

npm GitHub Workflow Status Codecov

ReScript bindings for testing-library/react.

Install

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"]
}

Usage

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
  })
})

About

ReScript bindings for @testing-library/react.

Resources

License

Stars

Watchers

Forks

Packages

No packages published