unit-test-sentinel
Version:
Provides a sentinel object that can contain and return arbitrary unique properties for unit tests.
57 lines (40 loc) • 1.88 kB
Markdown
Provides unique objects for unit tests in JavaScript. Inspired by the [sentinel object](https://docs.python.org/3/library/unittest.mock.html#sentinel) 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.
`npm install --save-dev unit-test-sentinel`
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`).
```javascript
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`.
```javascript
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); // ✓
```