1.5.1 • Published 3 years ago

jest-theories v1.5.1

Weekly downloads
3,010
License
MIT
Repository
github
Last release
3 years ago

jest-theories

Run one test code with varying inputs to minimise on repition, and maximise on ease of test creation. More tests mean better coverage.

Installation

npm install jest-theories

Example

import theoretically from 'jest-theories';

describe('NumberToLongString', () => {
    const theories = [
        {input: 100, expected: 'One hundred'},
        {input: 1000, expected: 'One thousand'},
        {input: 10000, expected: 'Ten thousand'},
        {input: 100000, expected: 'One hundred thousand'},
    ]

    theoretically('the number {input} is correctly translated to string', theories, theory => {
        const output = NumberToLongString(theory.input);
        expect(output).toBe(theory.expected);
    })
});

The input string uses string-format for formatting.

Additionally to the fields available in your theory you can also use $idx for the index of the theory and $no for the number of the theory.

If you want to do more complex test name creation you can supply a function which takes the parameters of the theory and the index

import theoretically from 'jest-theories';

describe('Bigger than 1000', () => {
    const theories = [
        {input: 100, expected: false},
        {input: 1000, expected: false},
        {input: 10000, expected: true},
        {input: 100000, expected: true},
    ]

    theoretically(({input, expected}) => `the number ${input} is ${expected ? '' : 'not'} bigger than 1000`, theories, theory => {
        const output = IsBiggerThan1000(theory.input);
        expect(output).toBe(theory.expected);
    })
});

Inspiration

Inspiration from jasmine-theories and XUnit.

1.5.1

3 years ago

1.5.0

3 years ago

1.3.0

3 years ago

1.2.0

5 years ago

1.1.0

5 years ago

1.0.3

5 years ago

1.0.2

5 years ago

1.0.1

6 years ago

1.0.0

6 years ago

0.0.5

6 years ago

0.0.4

6 years ago

0.0.3

6 years ago

0.0.2

6 years ago

0.0.1

6 years ago