faastjs
Version:
Serverless batch computing made simple.
45 lines • 6.48 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
const tslib_1 = require("tslib");
const ava_1 = tslib_1.__importDefault(require("ava"));
const index_1 = require("../index");
const trace_1 = require("../src/trace");
const funcs = tslib_1.__importStar(require("./fixtures/functions"));
const util_1 = require("./fixtures/util");
function testCancellation(t, provider, options) {
return (0, util_1.withClock)(async () => {
await (0, util_1.sleep)(0); // wait until ava sets its timeout so it doesn't get picked up by async_hooks.
(0, trace_1.startAsyncTracing)();
const faastModule = await (0, index_1.faast)(provider, funcs, {
...options,
childProcess: true,
gc: "off",
description: t.title
});
try {
faastModule.functions.spin(10000).catch(_ => { });
await (0, util_1.sleep)(500); // wait until the request actually starts
}
finally {
await faastModule.cleanup();
}
(0, trace_1.stopAsyncTracing)();
await (0, util_1.sleep)(500);
const leaks = (0, trace_1.detectAsyncLeaks)();
t.true(leaks.length === 0);
(0, trace_1.clearLeakDetector)();
});
}
for (const provider of index_1.providers) {
let configurations = util_1.configs;
if (provider !== "local") {
configurations = util_1.configs.filter(t => t.childProcess === true);
}
for (const config of configurations) {
// Cancellation tests must be run serially because the point is to
// detect async operations started by faast.js that are not completed
// before cleanup returns.
ava_1.default.serial((0, util_1.title)(provider, `cleanup waits for all async operations to complete before returning`, config), testCancellation, provider, config);
}
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FuY2VsbGF0aW9uLnRlc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi90ZXN0L2NhbmNlbGxhdGlvbi50ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHNEQUE2QztBQUM3QyxvQ0FBcUU7QUFDckUsd0NBS3NCO0FBQ3RCLG9FQUE4QztBQUM5QywwQ0FBbUU7QUFFbkUsU0FBUyxnQkFBZ0IsQ0FDckIsQ0FBbUIsRUFDbkIsUUFBa0IsRUFDbEIsT0FBdUI7SUFFdkIsT0FBTyxJQUFBLGdCQUFTLEVBQUMsS0FBSyxJQUFJLEVBQUU7UUFDeEIsTUFBTSxJQUFBLFlBQUssRUFBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLDhFQUE4RTtRQUM5RixJQUFBLHlCQUFpQixHQUFFLENBQUM7UUFDcEIsTUFBTSxXQUFXLEdBQUcsTUFBTSxJQUFBLGFBQUssRUFBQyxRQUFRLEVBQUUsS0FBSyxFQUFFO1lBQzdDLEdBQUcsT0FBTztZQUNWLFlBQVksRUFBRSxJQUFJO1lBQ2xCLEVBQUUsRUFBRSxLQUFLO1lBQ1QsV0FBVyxFQUFFLENBQUMsQ0FBQyxLQUFLO1NBQ3ZCLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQztZQUNELFdBQVcsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBRSxHQUFFLENBQUMsQ0FBQyxDQUFDO1lBQ2pELE1BQU0sSUFBQSxZQUFLLEVBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyx5Q0FBeUM7UUFDL0QsQ0FBQztnQkFBUyxDQUFDO1lBQ1AsTUFBTSxXQUFXLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDaEMsQ0FBQztRQUNELElBQUEsd0JBQWdCLEdBQUUsQ0FBQztRQUNuQixNQUFNLElBQUEsWUFBSyxFQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ2pCLE1BQU0sS0FBSyxHQUFHLElBQUEsd0JBQWdCLEdBQUUsQ0FBQztRQUNqQyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDLENBQUM7UUFDM0IsSUFBQSx5QkFBaUIsR0FBRSxDQUFDO0lBQ3hCLENBQUMsQ0FBQyxDQUFDO0FBQ1AsQ0FBQztBQUVELEtBQUssTUFBTSxRQUFRLElBQUksaUJBQVMsRUFBRSxDQUFDO0lBQy9CLElBQUksY0FBYyxHQUFHLGNBQU8sQ0FBQztJQUM3QixJQUFJLFFBQVEsS0FBSyxPQUFPLEVBQUUsQ0FBQztRQUN2QixjQUFjLEdBQUcsY0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxZQUFZLEtBQUssSUFBSSxDQUFDLENBQUM7SUFDbEUsQ0FBQztJQUNELEtBQUssTUFBTSxNQUFNLElBQUksY0FBYyxFQUFFLENBQUM7UUFDbEMsa0VBQWtFO1FBQ2xFLHFFQUFxRTtRQUNyRSwwQkFBMEI7UUFDMUIsYUFBSSxDQUFDLE1BQU0sQ0FDUCxJQUFBLFlBQUssRUFDRCxRQUFRLEVBQ1IscUVBQXFFLEVBQ3JFLE1BQU0sQ0FDVCxFQUNELGdCQUFnQixFQUNoQixRQUFRLEVBQ1IsTUFBTSxDQUNULENBQUM7SUFDTixDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0ZXN0LCB7IEV4ZWN1dGlvbkNvbnRleHQgfSBmcm9tIFwiYXZhXCI7XG5pbXBvcnQgeyBDb21tb25PcHRpb25zLCBmYWFzdCwgUHJvdmlkZXIsIHByb3ZpZGVycyB9IGZyb20gXCIuLi9pbmRleFwiO1xuaW1wb3J0IHtcbiAgICBjbGVhckxlYWtEZXRlY3RvcixcbiAgICBkZXRlY3RBc3luY0xlYWtzLFxuICAgIHN0YXJ0QXN5bmNUcmFjaW5nLFxuICAgIHN0b3BBc3luY1RyYWNpbmdcbn0gZnJvbSBcIi4uL3NyYy90cmFjZVwiO1xuaW1wb3J0ICogYXMgZnVuY3MgZnJvbSBcIi4vZml4dHVyZXMvZnVuY3Rpb25zXCI7XG5pbXBvcnQgeyBjb25maWdzLCBzbGVlcCwgdGl0bGUsIHdpdGhDbG9jayB9IGZyb20gXCIuL2ZpeHR1cmVzL3V0aWxcIjtcblxuZnVuY3Rpb24gdGVzdENhbmNlbGxhdGlvbihcbiAgICB0OiBFeGVjdXRpb25Db250ZXh0LFxuICAgIHByb3ZpZGVyOiBQcm92aWRlcixcbiAgICBvcHRpb25zPzogQ29tbW9uT3B0aW9uc1xuKSB7XG4gICAgcmV0dXJuIHdpdGhDbG9jayhhc3luYyAoKSA9PiB7XG4gICAgICAgIGF3YWl0IHNsZWVwKDApOyAvLyB3YWl0IHVudGlsIGF2YSBzZXRzIGl0cyB0aW1lb3V0IHNvIGl0IGRvZXNuJ3QgZ2V0IHBpY2tlZCB1cCBieSBhc3luY19ob29rcy5cbiAgICAgICAgc3RhcnRBc3luY1RyYWNpbmcoKTtcbiAgICAgICAgY29uc3QgZmFhc3RNb2R1bGUgPSBhd2FpdCBmYWFzdChwcm92aWRlciwgZnVuY3MsIHtcbiAgICAgICAgICAgIC4uLm9wdGlvbnMsXG4gICAgICAgICAgICBjaGlsZFByb2Nlc3M6IHRydWUsXG4gICAgICAgICAgICBnYzogXCJvZmZcIixcbiAgICAgICAgICAgIGRlc2NyaXB0aW9uOiB0LnRpdGxlXG4gICAgICAgIH0pO1xuICAgICAgICB0cnkge1xuICAgICAgICAgICAgZmFhc3RNb2R1bGUuZnVuY3Rpb25zLnNwaW4oMTAwMDApLmNhdGNoKF8gPT4ge30pO1xuICAgICAgICAgICAgYXdhaXQgc2xlZXAoNTAwKTsgLy8gd2FpdCB1bnRpbCB0aGUgcmVxdWVzdCBhY3R1YWxseSBzdGFydHNcbiAgICAgICAgfSBmaW5hbGx5IHtcbiAgICAgICAgICAgIGF3YWl0IGZhYXN0TW9kdWxlLmNsZWFudXAoKTtcbiAgICAgICAgfVxuICAgICAgICBzdG9wQXN5bmNUcmFjaW5nKCk7XG4gICAgICAgIGF3YWl0IHNsZWVwKDUwMCk7XG4gICAgICAgIGNvbnN0IGxlYWtzID0gZGV0ZWN0QXN5bmNMZWFrcygpO1xuICAgICAgICB0LnRydWUobGVha3MubGVuZ3RoID09PSAwKTtcbiAgICAgICAgY2xlYXJMZWFrRGV0ZWN0b3IoKTtcbiAgICB9KTtcbn1cblxuZm9yIChjb25zdCBwcm92aWRlciBvZiBwcm92aWRlcnMpIHtcbiAgICBsZXQgY29uZmlndXJhdGlvbnMgPSBjb25maWdzO1xuICAgIGlmIChwcm92aWRlciAhPT0gXCJsb2NhbFwiKSB7XG4gICAgICAgIGNvbmZpZ3VyYXRpb25zID0gY29uZmlncy5maWx0ZXIodCA9PiB0LmNoaWxkUHJvY2VzcyA9PT0gdHJ1ZSk7XG4gICAgfVxuICAgIGZvciAoY29uc3QgY29uZmlnIG9mIGNvbmZpZ3VyYXRpb25zKSB7XG4gICAgICAgIC8vIENhbmNlbGxhdGlvbiB0ZXN0cyBtdXN0IGJlIHJ1biBzZXJpYWxseSBiZWNhdXNlIHRoZSBwb2ludCBpcyB0b1xuICAgICAgICAvLyBkZXRlY3QgYXN5bmMgb3BlcmF0aW9ucyBzdGFydGVkIGJ5IGZhYXN0LmpzIHRoYXQgYXJlIG5vdCBjb21wbGV0ZWRcbiAgICAgICAgLy8gYmVmb3JlIGNsZWFudXAgcmV0dXJucy5cbiAgICAgICAgdGVzdC5zZXJpYWwoXG4gICAgICAgICAgICB0aXRsZShcbiAgICAgICAgICAgICAgICBwcm92aWRlcixcbiAgICAgICAgICAgICAgICBgY2xlYW51cCB3YWl0cyBmb3IgYWxsIGFzeW5jIG9wZXJhdGlvbnMgdG8gY29tcGxldGUgYmVmb3JlIHJldHVybmluZ2AsXG4gICAgICAgICAgICAgICAgY29uZmlnXG4gICAgICAgICAgICApLFxuICAgICAgICAgICAgdGVzdENhbmNlbGxhdGlvbixcbiAgICAgICAgICAgIHByb3ZpZGVyLFxuICAgICAgICAgICAgY29uZmlnXG4gICAgICAgICk7XG4gICAgfVxufVxuIl19