@djaler/jest-fast-check
TypeScript icon, indicating that this package has built-in type declarations

0.0.1 • Public • Published

Property based testing for Jest based on fast-check

Build Status npm version

Bring the power of property based testing framework fast-check into jest. jest-fast-check simplifies the integration of fast-check into jest testing framework.

Getting started

Install jest-fast-check and its peer dependencies:

# With yarn
yarn add -D jest fast-check jest-fast-check

# With npm
npm install --save-dev jest fast-check jest-fast-check

Example

import { testProp, fc } from "jest-fast-check";

// for all a, b, c strings
// b is a substring of a + b + c
testProp(
  "should detect the substring",
  [fc.string(), fc.string(), fc.string()],
  (a, b, c) => {
    return (a + b + c).includes(b);
  }
);

Please note that the properties accepted by jest-fast-check as input can either be synchronous or asynchronous (even just PromiseLike instances).

Advanced

If you want to forward custom parameters to fast-check, testProp accepts an optional fc.Parameters (more).

jest-fast-check also comes with .only, .skip and .todo from jest.

import { itProp, testProp, fc } from "jest-fast-check";

testProp(
  "should replay the test for the seed 4242",
  [fc.nat(), fc.nat()],
  (a, b) => {
    return a + b === b + a;
  },
  { seed: 4242 }
);

testProp.skip("should be skipped", [fc.fullUnicodeString()], (text) => {
  return text.length === [...text].length;
});

describe("with it", () => {
  itProp("should run too", [fc.nat(), fc.nat()], (a, b) => {
    return a + b === b + a;
  });
});

Minimal requirements

  • jest >=25.1.0
  • fast-check ^1.0.0
  • typescript >=3.9.0

Package Sidebar

Install

npm i @djaler/jest-fast-check

Weekly Downloads

0

Version

0.0.1

License

MIT

Unpacked Size

11.3 kB

Total Files

5

Last publish

Collaborators

  • djaler