Sazerac is a library for data-driven tests, where a series of tests asserts that the return value of a function matches the expected value. It provides nice syntax for tightening this up. https://hackernoon.com/sazerac-data-driven-testing-for-javascript-e3408ac29d8c This converts our tests to use it, and replaces some similar home-grown code. I fixed one bug I encountered along the way: mikec/sazerac#12.
35 lines
1.3 KiB
JavaScript
35 lines
1.3 KiB
JavaScript
'use strict';
|
|
|
|
const { test, given } = require('sazerac');
|
|
const {latest} = require('./version');
|
|
|
|
describe('Version helpers', function () {
|
|
test(latest, () => {
|
|
// semver-compatible versions.
|
|
given(['1.0.0', '1.0.2', '1.0.1']).expect('1.0.2');
|
|
given(['1.0.0', '2.0.0', '3.0.0']).expect('3.0.0');
|
|
given(['0.0.1', '0.0.10', '0.0.2', '0.0.20']).expect('0.0.20');
|
|
|
|
// Simple dotted versions.
|
|
given(['1.0.0', 'v1.0.2', 'r1.0.1', 'release-2.0.0']).expect('release-2.0.0');
|
|
given(['1.0.0', 'v2.0.0', 'r1.0.1', 'release-1.0.3']).expect('v2.0.0');
|
|
given(['2.0.0', 'v1.0.3', 'r1.0.1', 'release-1.0.3']).expect('2.0.0');
|
|
given(['1.0.0', 'v1.0.2', 'r2.0.0', 'release-1.0.3']).expect('r2.0.0');
|
|
|
|
// Versions with 'v' prefix.
|
|
given(['0.1', '0.3', '0.2']).expect('0.3');
|
|
given(['0.1', '0.5', '0.12', '0.21']).expect('0.21');
|
|
given(['1.0', '2.0', '3.0']).expect('3.0');
|
|
|
|
// Versions with '-release' prefix
|
|
given(['v1.0.0', 'v1.0.2', 'v1.0.1']).expect('v1.0.2');
|
|
given(['v1.0.0', 'v3.0.0', 'v2.0.0']).expect('v3.0.0');
|
|
|
|
// Versions with '-release' prefix
|
|
given(['release-1.0.0', 'release-1.0.2', 'release-1.0.20', 'release-1.0.3']).expect('release-1.0.20');
|
|
|
|
// Simple (one-number) versions
|
|
given(['2', '10', '1']).expect('10');
|
|
});
|
|
});
|