/bs-jest-dom

BuckleScript bindings for jest-dom.

Primary LanguageOCamlMIT LicenseMIT

bs-jest-dom · Build Status npm Coveralls

BuckleScript bindings for jest-dom.

Installation

$ yarn add --dev bs-jest-dom

# or..

$ npm install --save-dev bs-jest-dom

If you don't have @glennsl/bs-jest already installed run

$ yarn add --dev @glennsl/bs-jest

# or..

$ npm install --save-dev @glennsl/bs-jest

Usage

Add to bsconfig.json

{
  "bs-dev-dependencies": ["bs-jest-dom"]
}
/* Heading_test.re */

open Jest;
open Expect;
open JestDom;
open ReactTestingLibrary;

module Heading = {
  let component = ReasonReact.statelessComponent("Heading");

  let make = (~text, _children) => {
    ...component,
    render: _self =>
      <h1> {ReasonReact.string(text)} </h1>,
  };
};

test("renders in the document", () =>
  <Heading text="Hello, World!" />
  |> render
  |> getByText(~matcher=`Str("Hello, World!"))
  |> expect
  |> toBeInTheDocument
);
/* Heading_test.re */

open Jest;
open Expect;
open JestDom;
open Webapi.Dom;
open Webapi.Dom.Element;

test("heading is visible", () => {
  let div = Document.createElement("div", document);

  div->setInnerHTML("<h1>Hello, World!</h1>");

  div
  |> querySelector("h1")
  |> expect
  |> toBeVisible;
});

Examples

See src/__tests__ for some examples.

Development

$ git clone https://github.com/wyze/bs-jest-dom.git
$ cd bs-jest-dom
$ yarn add @glennsl/bs-jest # or `npm install @glennsl/bs-jest`
$ yarn # or `npm install`

Build

$ yarn build

Test

$ yarn test

Change Log

Full Change Log

v2.0.0 (2019-03-11)

License

MIT © Neil Kistner