UNPKG

faastjs

Version:

Serverless batch computing made simple.

104 lines 14.8 kB
"use strict"; 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"]}