114 lines
3.8 KiB
JavaScript
114 lines
3.8 KiB
JavaScript
|
"use strict";
|
||
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||
|
exports.SetPredicate = void 0;
|
||
|
const isEqual = require("lodash.isequal");
|
||
|
const has_items_1 = require("../utils/has-items");
|
||
|
const of_type_1 = require("../utils/of-type");
|
||
|
const predicate_1 = require("./predicate");
|
||
|
class SetPredicate extends predicate_1.Predicate {
|
||
|
/**
|
||
|
@hidden
|
||
|
*/
|
||
|
constructor(options) {
|
||
|
super('Set', options);
|
||
|
}
|
||
|
/**
|
||
|
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 => has_items_1.default(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 => of_type_1.default(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 => isEqual(set, expected)
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
exports.SetPredicate = SetPredicate;
|