ow
Version:
Function argument validation for humans
110 lines (102 loc) • 3.73 kB
JavaScript
import { deepEqual } from 'fast-equals';
import hasItems from '../utils/has-items.js';
import ofType from '../utils/of-type.js';
import { Predicate } from './predicate.js';
export class SetPredicate extends Predicate {
/**
@hidden
*/
constructor(options, validators) {
super('Set', options, validators);
}
/**
Test a Set to have a specific size.
@param size - The size of the Set.
*/
size(size) {
return this.addValidator({
message: (set, label) => `Expected ${label} to have size \`${size}\`, got \`${set.size}\``,
validator: set => set.size === size,
});
}
/**
Test a Set to have a minimum size.
@param size - The minimum size of the Set.
*/
minSize(size) {
return this.addValidator({
message: (set, label) => `Expected ${label} to have a minimum size of \`${size}\`, got \`${set.size}\``,
validator: set => set.size >= size,
negatedMessage: (set, label) => `Expected ${label} to have a maximum size of \`${size - 1}\`, got \`${set.size}\``,
});
}
/**
Test a Set to have a maximum size.
@param size - The maximum size of the Set.
*/
maxSize(size) {
return this.addValidator({
message: (set, label) => `Expected ${label} to have a maximum size of \`${size}\`, got \`${set.size}\``,
validator: set => set.size <= size,
negatedMessage: (set, label) => `Expected ${label} to have a minimum size of \`${size + 1}\`, got \`${set.size}\``,
});
}
/**
Test a Set to include all the provided items. The items are tested by identity, not structure.
@param items - The items that should be a item in the Set.
*/
has(...items) {
return this.addValidator({
message: (_, label, missingItems) => `Expected ${label} to have items \`${JSON.stringify(missingItems)}\``,
validator: set => hasItems(set, items),
});
}
/**
Test a Set to include any of the provided items. The items are tested by identity, not structure.
@param items - The items that could be a item in the Set.
*/
hasAny(...items) {
return this.addValidator({
message: (_, label) => `Expected ${label} to have any item of \`${JSON.stringify(items)}\``,
validator: set => items.some(item => set.has(item)),
});
}
/**
Test all the items in the Set to match the provided predicate.
@param predicate - The predicate that should be applied against every item in the Set.
*/
ofType(predicate) {
return this.addValidator({
message: (_, label, error) => `(${label}) ${error}`,
validator: set => ofType(set, 'values', predicate),
});
}
/**
Test a Set to be empty.
*/
get empty() {
return this.addValidator({
message: (set, label) => `Expected ${label} to be empty, got \`${JSON.stringify([...set])}\``,
validator: set => set.size === 0,
});
}
/**
Test a Set to be not empty.
*/
get nonEmpty() {
return this.addValidator({
message: (_, label) => `Expected ${label} to not be empty`,
validator: set => set.size > 0,
});
}
/**
Test a Set to be deeply equal to the provided Set.
@param expected - Expected Set to match.
*/
deepEqual(expected) {
return this.addValidator({
message: (set, label) => `Expected ${label} to be deeply equal to \`${JSON.stringify([...expected])}\`, got \`${JSON.stringify([...set])}\``,
validator: set => deepEqual(set, expected),
});
}
}