1.0.1 • Published 1 year ago

unit-test-sentinel v1.0.1

Weekly downloads
-
License
MIT
Repository
github
Last release
1 year ago

Unit test sentinel

Provides unique objects for unit tests in JavaScript. Inspired by the sentinel object in Python.

It's useful for creating a value that is passed into a function call, but you don't want to keep track of this value in a local variable. Instead, you can ask the sentinel to give you a unique named property that will persist through your test.

Installation

npm install --save-dev unit-test-sentinel

Usage

Import the module sentinel and then create a sentinel object for each test. This example uses Mocha and calls the sentinel object ф (which is U+0444).

import sentinel from 'unit-test-sentinel'

// We'll test this function.
const logAndReturn = (input) => {
  console.log(input);
  return input;
};

describe('logAndReturn', () => {
  let ф;

  beforeEach(() => {
    // Create a sentinel object, which can contain arbirary properties.
    ф = sentinel.create();
  })

  it('returns its input', () => {
    // Pass in a custom input, as a named property.
    const result = logAndReturn(ф.customInput);

    // Expect that the output is the exact same object that was passed in.
    expect(result).to.equal(ф.customInput);
  })
});

This example require()s the sentinel module, uses assert for testing, and calls the sentinel object s. It also uses the random method, calling its object r.

const sentinel = require('unit-test-sentinel');
const s = sentinel.create();
const r = sentinel.random();

const first = s.hello; // => ¦ф.hello¦
const second = s.hello; // => ¦ф.hello¦
assert(first === second); // ✓

const r1 = s.randomized; // e.g. => randomized-WfQ8S;0{|+)t
const r2 = s.randomized; // => randomized-WfQ8S;0{|+)t
assert(r1 === r2); // ✓