UNPKG

14.7 kBJavaScriptView Raw
1"use strict";
2Object.defineProperty(exports, "__esModule", { value: true });
3exports.checkIteratorMessages = exports.expectMessage = exports.toArray = exports.sleep = exports.title = exports.noValidateConfigs = exports.configs = exports.record = exports.checkResourcesCleanedUp = exports.withClock = exports.stdev = exports.avg = exports.sum = exports.measureConcurrency = exports.keysOf = void 0;
4const lolex = require("lolex");
5const util_1 = require("util");
6const index_1 = require("../../index");
7const serialize_1 = require("../../src/serialize");
8const shared_1 = require("../../src/shared");
9Object.defineProperty(exports, "keysOf", { enumerable: true, get: function () { return shared_1.keysOf; } });
10const measureConcurrency = (timings) => timings
11 .map(t => t.start)
12 .map(t => timings.filter(({ start, end }) => start <= t && t < end).length)
13 .reduce((a, b) => Math.max(a, b));
14exports.measureConcurrency = measureConcurrency;
15const sum = (a) => a.reduce((total, n) => total + n, 0);
16exports.sum = sum;
17const avg = (a) => (0, exports.sum)(a) / a.length;
18exports.avg = avg;
19const stdev = (a) => {
20 const average = (0, exports.avg)(a);
21 return Math.sqrt((0, exports.avg)(a.map(v => (v - average) ** 2)));
22};
23exports.stdev = stdev;
24async function withClock(fn) {
25 const clock = lolex.install({ shouldAdvanceTime: true, now: Date.now() });
26 try {
27 await fn(clock);
28 }
29 finally {
30 clock.uninstall();
31 }
32}
33exports.withClock = withClock;
34function checkResourcesCleanedUp(t, resources) {
35 for (const key of (0, shared_1.keysOf)(resources)) {
36 t.is(resources[key], undefined);
37 if (resources[key] !== undefined) {
38 console.log(`Resource '${key}' not cleaned up: %O`, resources[key]);
39 }
40 }
41}
42exports.checkResourcesCleanedUp = checkResourcesCleanedUp;
43function record(fn) {
44 const func = Object.assign((...args) => {
45 const rv = fn(...args);
46 func.recordings.push({ args, rv });
47 index_1.log.info(`func.recordings: %O`, func.recordings);
48 return rv;
49 }, { recordings: [] });
50 return func;
51}
52exports.record = record;
53exports.configs = [
54 // { mode: "https", childProcess: false, validateSerialization: true },
55 { mode: "https", childProcess: true, validateSerialization: true },
56 // { mode: "queue", childProcess: false, validateSerialization: true },
57 { mode: "queue", childProcess: true, validateSerialization: true }
58];
59exports.noValidateConfigs = exports.configs.map(c => ({
60 ...c,
61 validateSerialization: false
62}));
63function title(provider, msg, options) {
64 const desc = options ? (0, util_1.inspect)(options, { breakLength: Infinity }) : "";
65 return [provider === "local" ? "" : "remote", provider, msg, desc]
66 .filter(x => x !== "")
67 .join(" ");
68}
69exports.title = title;
70function sleep(ms) {
71 return new Promise(resolve => setTimeout(resolve, ms));
72}
73exports.sleep = sleep;
74async function toArray(gen) {
75 const result = [];
76 for await (const elem of gen) {
77 result.push(elem);
78 }
79 return result;
80}
81exports.toArray = toArray;
82function expectMessage(t, msg, kind, expected) {
83 t.is(msg.kind, kind);
84 if (msg.kind === kind) {
85 const [value] = (0, serialize_1.deserialize)(msg.value);
86 t.deepEqual(value, expected);
87 }
88}
89exports.expectMessage = expectMessage;
90function checkIteratorMessages(t, rawMessages, arg) {
91 const messages = [];
92 t.is(rawMessages.length, arg.length + 1);
93 for (const msg of rawMessages) {
94 messages[msg.sequence] = msg;
95 }
96 let i = 0;
97 for (; i < arg.length; i++) {
98 expectMessage(t, messages[i], "iterator", { done: false, value: arg[i] });
99 }
100 expectMessage(t, messages[i], "iterator", { done: true });
101}
102exports.checkIteratorMessages = checkIteratorMessages;
103//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"util.js","sourceRoot":"","sources":["../../../test/fixtures/util.ts"],"names":[],"mappings":"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","sourcesContent":["import { ExecutionContext } from \"ava\";\nimport * as lolex from \"lolex\";\nimport { inspect } from \"util\";\nimport { CommonOptions, log, Provider } from \"../../index\";\nimport { IteratorResponseMessage, Message } from \"../../src/provider\";\nimport { deserialize } from \"../../src/serialize\";\nimport { keysOf } from \"../../src/shared\";\nimport { Timing } from \"./functions\";\nexport { keysOf };\n\nexport const measureConcurrency = (timings: Timing[]) =>\n    timings\n        .map(t => t.start)\n        .map(t => timings.filter(({ start, end }) => start <= t && t < end).length)\n        .reduce((a, b) => Math.max(a, b));\n\nexport const sum = (a: number[]) => a.reduce((total, n) => total + n, 0);\n\nexport const avg = (a: number[]) => sum(a) / a.length;\n\nexport const stdev = (a: number[]) => {\n    const average = avg(a);\n    return Math.sqrt(avg(a.map(v => (v - average) ** 2)));\n};\n\nexport type VClock = lolex.InstalledClock<lolex.Clock>;\n\nexport async function withClock(fn: (clock: VClock) => Promise<void>) {\n    const clock = lolex.install({ shouldAdvanceTime: true, now: Date.now() });\n    try {\n        await fn(clock);\n    } finally {\n        clock.uninstall();\n    }\n}\n\nexport function checkResourcesCleanedUp<T extends object>(\n    t: ExecutionContext,\n    resources: T\n) {\n    for (const key of keysOf(resources)) {\n        t.is(resources[key], undefined);\n        if (resources[key] !== undefined) {\n            console.log(`Resource '${key}' not cleaned up: %O`, resources[key]);\n        }\n    }\n}\n\nexport interface RecordedCall<A extends any[], R> {\n    args: A;\n    rv: R;\n}\n\nexport interface RecordedFunction<A extends any[], R> {\n    (...args: A): R;\n    recordings: Array<RecordedCall<A, R>>;\n}\n\nexport function record<A extends any[], R>(fn: (...args: A) => R) {\n    const func: RecordedFunction<A, R> = Object.assign(\n        (...args: A) => {\n            const rv = fn(...args);\n            func.recordings.push({ args, rv });\n            log.info(`func.recordings: %O`, func.recordings);\n            return rv;\n        },\n        { recordings: [] }\n    );\n    return func;\n}\n\nexport const configs: CommonOptions[] = [\n    // { mode: \"https\", childProcess: false, validateSerialization: true },\n    { mode: \"https\", childProcess: true, validateSerialization: true },\n    // { mode: \"queue\", childProcess: false, validateSerialization: true },\n    { mode: \"queue\", childProcess: true, validateSerialization: true }\n];\n\nexport const noValidateConfigs = configs.map(c => ({\n    ...c,\n    validateSerialization: false\n}));\n\nexport function title(provider: Provider, msg: string, options?: object) {\n    const desc = options ? inspect(options, { breakLength: Infinity }) : \"\";\n    return [provider === \"local\" ? \"\" : \"remote\", provider, msg, desc]\n        .filter(x => x !== \"\")\n        .join(\" \");\n}\n\nexport function sleep(ms: number) {\n    return new Promise(resolve => setTimeout(resolve, ms));\n}\n\nexport async function toArray<T>(gen: AsyncIterable<T> | Iterable<T>) {\n    const result = [];\n    for await (const elem of gen) {\n        result.push(elem);\n    }\n    return result;\n}\n\nexport function expectMessage<T>(\n    t: ExecutionContext,\n    msg: Message,\n    kind: \"promise\" | \"iterator\",\n    expected: T\n) {\n    t.is(msg.kind, kind);\n    if (msg.kind === kind) {\n        const [value] = deserialize(msg.value);\n        t.deepEqual(value, expected);\n    }\n}\n\nexport function checkIteratorMessages(\n    t: ExecutionContext,\n    rawMessages: IteratorResponseMessage[],\n    arg: string[]\n) {\n    const messages = [];\n    t.is(rawMessages.length, arg.length + 1);\n    for (const msg of rawMessages) {\n        messages[msg.sequence] = msg;\n    }\n\n    let i = 0;\n    for (; i < arg.length; i++) {\n        expectMessage(t, messages[i], \"iterator\", { done: false, value: arg[i] });\n    }\n    expectMessage(t, messages[i], \"iterator\", { done: true });\n}\n"]}
\No newline at end of file