faastjs
Version:
Serverless batch computing made simple.
104 lines • 14.8 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.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;
const tslib_1 = require("tslib");
const lolex_1 = tslib_1.__importDefault(require("lolex"));
const util_1 = require("util");
const index_1 = require("../../index");
const serialize_1 = require("../../src/serialize");
const shared_1 = require("../../src/shared");
Object.defineProperty(exports, "keysOf", { enumerable: true, get: function () { return shared_1.keysOf; } });
const measureConcurrency = (timings) => timings
.map(t => t.start)
.map(t => timings.filter(({ start, end }) => start <= t && t < end).length)
.reduce((a, b) => Math.max(a, b));
exports.measureConcurrency = measureConcurrency;
const sum = (a) => a.reduce((total, n) => total + n, 0);
exports.sum = sum;
const avg = (a) => (0, exports.sum)(a) / a.length;
exports.avg = avg;
const stdev = (a) => {
const average = (0, exports.avg)(a);
return Math.sqrt((0, exports.avg)(a.map(v => (v - average) ** 2)));
};
exports.stdev = stdev;
async function withClock(fn) {
const clock = lolex_1.default.install({ shouldAdvanceTime: true, now: Date.now() });
try {
await fn(clock);
}
finally {
clock.uninstall();
}
}
exports.withClock = withClock;
function checkResourcesCleanedUp(t, resources) {
for (const key of (0, shared_1.keysOf)(resources)) {
t.is(resources[key], undefined);
if (resources[key] !== undefined) {
console.log(`Resource '${String(key)}' not cleaned up: %O`, resources[key]);
}
}
}
exports.checkResourcesCleanedUp = checkResourcesCleanedUp;
function record(fn) {
const func = Object.assign((...args) => {
const rv = fn(...args);
func.recordings.push({ args, rv });
index_1.log.info(`func.recordings: %O`, func.recordings);
return rv;
}, { recordings: [] });
return func;
}
exports.record = record;
exports.configs = [
// { mode: "https", childProcess: false, validateSerialization: true },
{ mode: "https", childProcess: true, validateSerialization: true },
// { mode: "queue", childProcess: false, validateSerialization: true },
{ mode: "queue", childProcess: true, validateSerialization: true }
];
exports.noValidateConfigs = exports.configs.map(c => ({
...c,
validateSerialization: false
}));
function title(provider, msg, options) {
const desc = options ? (0, util_1.inspect)(options, { breakLength: Infinity }) : "";
return [provider === "local" ? "" : "remote", provider, msg, desc]
.filter(x => x !== "")
.join(" ");
}
exports.title = title;
function sleep(ms) {
return new Promise(resolve => setTimeout(resolve, ms));
}
exports.sleep = sleep;
async function toArray(gen) {
const result = [];
for await (const elem of gen) {
result.push(elem);
}
return result;
}
exports.toArray = toArray;
function expectMessage(t, msg, kind, expected) {
t.is(msg.kind, kind);
if (msg.kind === kind) {
const [value] = (0, serialize_1.deserialize)(msg.value);
t.deepEqual(value, expected);
}
}
exports.expectMessage = expectMessage;
function checkIteratorMessages(t, rawMessages, arg) {
const messages = [];
t.is(rawMessages.length, arg.length + 1);
for (const msg of rawMessages) {
messages[msg.sequence] = msg;
}
let i = 0;
for (; i < arg.length; i++) {
expectMessage(t, messages[i], "iterator", { done: false, value: arg[i] });
}
expectMessage(t, messages[i], "iterator", { done: true });
}
exports.checkIteratorMessages = checkIteratorMessages;
//# 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 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: Partial<T>\n) {\n    for (const key of keysOf(resources)) {\n        t.is(resources[key], undefined);\n        if (resources[key] !== undefined) {\n            console.log(`Resource '${String(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"]}