UNPKG

fast-check

Version:

Property based testing framework for JavaScript (like QuickCheck)

55 lines (54 loc) 2.63 kB
import { stream } from '../../stream/Stream.js'; import { Property } from '../property/Property.generic.js'; import { UnbiasedProperty } from '../property/UnbiasedProperty.js'; import { readConfigureGlobal } from './configuration/GlobalParameters.js'; import { QualifiedParameters } from './configuration/QualifiedParameters.js'; import { lazyToss, toss } from './Tosser.js'; import { pathWalk } from './utils/PathWalker.js'; function toProperty(generator, qParams) { const prop = !Object.prototype.hasOwnProperty.call(generator, 'isAsync') ? new Property(generator, () => true) : generator; return qParams.unbiased === true ? new UnbiasedProperty(prop) : prop; } function streamSample(generator, params) { const extendedParams = typeof params === 'number' ? { ...readConfigureGlobal(), numRuns: params } : { ...readConfigureGlobal(), ...params }; const qParams = QualifiedParameters.read(extendedParams); const nextProperty = toProperty(generator, qParams); const shrink = nextProperty.shrink.bind(nextProperty); const tossedValues = qParams.path.length === 0 ? stream(toss(nextProperty, qParams.seed, qParams.randomType, qParams.examples)) : pathWalk(qParams.path, stream(lazyToss(nextProperty, qParams.seed, qParams.randomType, qParams.examples)), shrink); return tossedValues.take(qParams.numRuns).map((s) => s.value_); } function sample(generator, params) { return [...streamSample(generator, params)]; } function round2(n) { return (Math.round(n * 100) / 100).toFixed(2); } function statistics(generator, classify, params) { const extendedParams = typeof params === 'number' ? { ...readConfigureGlobal(), numRuns: params } : { ...readConfigureGlobal(), ...params }; const qParams = QualifiedParameters.read(extendedParams); const recorded = {}; for (const g of streamSample(generator, params)) { const out = classify(g); const categories = Array.isArray(out) ? out : [out]; for (const c of categories) { recorded[c] = (recorded[c] || 0) + 1; } } const data = Object.entries(recorded) .sort((a, b) => b[1] - a[1]) .map((i) => [i[0], `${round2((i[1] * 100.0) / qParams.numRuns)}%`]); const longestName = data.map((i) => i[0].length).reduce((p, c) => Math.max(p, c), 0); const longestPercent = data.map((i) => i[1].length).reduce((p, c) => Math.max(p, c), 0); for (const item of data) { qParams.logger(`${item[0].padEnd(longestName, '.')}..${item[1].padStart(longestPercent, '.')}`); } } export { sample, statistics };