UNPKG

22.1 kBJavaScriptView Raw
1"use strict";
2Object.defineProperty(exports, "__esModule", { value: true });
3const ava_1 = require("ava");
4const util_1 = require("util");
5const index_1 = require("../index");
6const funcs = require("./fixtures/functions");
7const util_2 = require("./fixtures/util");
8/**
9 * Note that there is an AWS Lambda bug where timeouts are not delivered if the
10 * function has a timeout >= 300s, and the function is invoked directly with the
11 * Invoke API (e.g. in faast.js' "https" mode, which is the default.). In this
12 * case if faast.js has childProcess mode on (the default), then it will set its
13 * own timeout. This situation is not explicitly tested here because it would
14 * make the entire testsuite slower for just one test. To test this situation
15 * manually, change the timeout to 300 or more, and run one of these tests:
16 *
17 * $ ava --timeout=10m -m="remote aws generator timeout { mode: 'https', childProcess: true }"
18 * $ ava --timeout=10m -m="remote aws timeout { mode: 'https', childProcess: true }"
19 */
20async function testTimeout(t, provider, options) {
21 const lambda = await (0, index_1.faast)(provider, funcs, {
22 ...options,
23 timeout: 5,
24 maxRetries: 0,
25 gc: "off",
26 description: t.title
27 });
28 t.plan(1);
29 // t.log(`${lambda.logUrl()}`);
30 try {
31 try {
32 await lambda.functions.infiniteLoop();
33 }
34 catch (err) {
35 const isTimeout = index_1.FaastError.hasCauseWithName(err, index_1.FaastErrorNames.ETIMEOUT);
36 t.is(isTimeout, true, `${(0, util_1.inspect)(err)}`);
37 }
38 }
39 finally {
40 await lambda.cleanup();
41 }
42}
43/**
44 * The purpose of this test is to verify that a CPU hogging async generator
45 * function won't starve the sending logic, so yield messages prior to the CPU
46 * intensive work are delivered.
47 */
48async function testGenerator(t, provider, options) {
49 t.plan(2);
50 const lambda = await (0, index_1.faast)(provider, funcs, {
51 ...options,
52 timeout: 5,
53 maxRetries: 0,
54 gc: "off",
55 description: t.title
56 });
57 // t.log(`${lambda.logUrl()}`);
58 try {
59 const arg = "hello, generator!";
60 for await (const result of lambda.functions.generateThenInfiniteLoop(arg)) {
61 t.is(result, arg);
62 }
63 t.fail("Did not timeout");
64 }
65 catch (err) {
66 t.is(index_1.FaastError.hasCauseWithName(err, index_1.FaastErrorNames.ETIMEOUT), true);
67 }
68 finally {
69 await lambda.cleanup();
70 }
71}
72async function memoryLimitOk(t, provider, options) {
73 const lambda = await (0, index_1.faast)(provider, funcs, {
74 ...options,
75 timeout: 200,
76 memorySize: 512,
77 maxRetries: 0,
78 gc: "off",
79 description: t.title
80 });
81 try {
82 const bytes = 64 * 1024 * 1024;
83 const rv = await lambda.functions.allocate(bytes);
84 t.is(rv.elems, bytes / 8);
85 }
86 finally {
87 await lambda.cleanup();
88 }
89}
90async function memoryLimitFail(t, provider, options) {
91 const lambda = await (0, index_1.faast)(provider, funcs, {
92 ...options,
93 timeout: 200,
94 memorySize: 512,
95 maxRetries: 0,
96 gc: "off",
97 description: t.title
98 });
99 try {
100 const bytes = 512 * 1024 * 1024;
101 await t.throwsAsync(lambda.functions.allocate(bytes), { message: /memory/i });
102 }
103 finally {
104 lambda && (await lambda.cleanup());
105 }
106}
107// Note that this test takes 180s by default. Set the ava timeout to 2m or
108// longer otherwise it will fail with a timeout error.
109async function testLongInvoke(t, provider, options) {
110 // The http timeout is 120s in awssdk by default. Uncomment the following
111 // line to shorten it to 20s for focused testing. Note that shortening it
112 // below 20s causes (harmless) timeout error messages from SQS on the long
113 // polling response queue. If faast.js is working correctly, the shortened
114 // timeout should not cause a test failure.
115 //
116 // config.update({ httpOptions: { timeout: 20000 } });
117 const opts = {
118 timeout: 500,
119 gc: "off",
120 description: t.title,
121 ...options
122 };
123 const faastModule = await (0, index_1.faast)(provider, funcs, opts);
124 const remote = faastModule.functions;
125 try {
126 let i = 0;
127 const args = ["a", "b", "c"];
128 // The use of an async generator is to mimick a real use case from a
129 // client of faast.js. The presence of an error should also be revealed
130 // with a regular remote function call.
131 for await (const arg of remote.asyncGeneratorDelay(args, 60000)) {
132 t.is(arg, args[i++]);
133 }
134 }
135 finally {
136 await faastModule.cleanup();
137 }
138}
139const allLimits = ["memory", "timeout", "long", "generator"];
140const configurations = [
141 ["aws", { mode: "https", childProcess: true }, allLimits],
142 ["aws", { mode: "queue", childProcess: true }, allLimits],
143 ["aws", { mode: "https", childProcess: false }, ["memory", "timeout", "generator"]],
144 ["aws", { mode: "queue", childProcess: false }, ["memory", "timeout", "generator"]],
145 ["google", { mode: "https", childProcess: true }, ["memory", "timeout", "long"]],
146 ["google", { mode: "queue", childProcess: true }, []],
147 ["local", {}, ["timeout"]]
148];
149for (const [provider, config, limitTypes] of configurations) {
150 const opts = (0, util_1.inspect)(config);
151 if (limitTypes.find(t => t === "memory")) {
152 (0, ava_1.default)((0, util_2.title)(provider, `memory under limit ${opts}`), memoryLimitOk, provider, config);
153 (0, ava_1.default)((0, util_2.title)(provider, `out of memory`, config), memoryLimitFail, provider, config);
154 }
155 if (limitTypes.find(t => t === "timeout")) {
156 (0, ava_1.default)((0, util_2.title)(provider, `timeout`, config), testTimeout, provider, config);
157 }
158 if (limitTypes.find(t => t === "long")) {
159 (0, ava_1.default)((0, util_2.title)(provider, `long invoke`, config), testLongInvoke, provider, config);
160 }
161 if (limitTypes.find(t => t === "generator")) {
162 (0, ava_1.default)((0, util_2.title)(provider, `generator timeout`, config), testGenerator, provider, config);
163 }
164}
165//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"limits.test.js","sourceRoot":"","sources":["../../test/limits.test.ts"],"names":[],"mappings":"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","sourcesContent":["import test, { ExecutionContext } from \"ava\";\nimport { inspect } from \"util\";\nimport { CommonOptions, faast, FaastError, FaastErrorNames, Provider } from \"../index\";\nimport * as funcs from \"./fixtures/functions\";\nimport { title } from \"./fixtures/util\";\n\n/**\n * Note that there is an AWS Lambda bug where timeouts are not delivered if the\n * function has a timeout >= 300s, and the function is invoked directly with the\n * Invoke API (e.g. in faast.js' \"https\" mode, which is the default.). In this\n * case if faast.js has childProcess mode on (the default), then it will set its\n * own timeout. This situation is not explicitly tested here because it would\n * make the entire testsuite slower for just one test. To test this situation\n * manually, change the timeout to 300 or more, and run one of these tests:\n *\n *    $ ava --timeout=10m -m=\"remote aws generator timeout { mode: 'https', childProcess: true }\"\n *    $ ava --timeout=10m -m=\"remote aws timeout { mode: 'https', childProcess: true }\"\n */\nasync function testTimeout(\n    t: ExecutionContext,\n    provider: Provider,\n    options: CommonOptions\n) {\n    const lambda = await faast(provider, funcs, {\n        ...options,\n        timeout: 5,\n        maxRetries: 0,\n        gc: \"off\",\n        description: t.title\n    });\n    t.plan(1);\n    // t.log(`${lambda.logUrl()}`);\n    try {\n        try {\n            await lambda.functions.infiniteLoop();\n        } catch (err: any) {\n            const isTimeout = FaastError.hasCauseWithName(err, FaastErrorNames.ETIMEOUT);\n            t.is(isTimeout, true, `${inspect(err)}`);\n        }\n    } finally {\n        await lambda.cleanup();\n    }\n}\n\n/**\n * The purpose of this test is to verify that a CPU hogging async generator\n * function won't starve the sending logic, so yield messages prior to the CPU\n * intensive work are delivered.\n */\nasync function testGenerator(\n    t: ExecutionContext,\n    provider: Provider,\n    options: CommonOptions\n) {\n    t.plan(2);\n    const lambda = await faast(provider, funcs, {\n        ...options,\n        timeout: 5,\n        maxRetries: 0,\n        gc: \"off\",\n        description: t.title\n    });\n    // t.log(`${lambda.logUrl()}`);\n    try {\n        const arg = \"hello, generator!\";\n        for await (const result of lambda.functions.generateThenInfiniteLoop(arg)) {\n            t.is(result, arg);\n        }\n        t.fail(\"Did not timeout\");\n    } catch (err: any) {\n        t.is(FaastError.hasCauseWithName(err, FaastErrorNames.ETIMEOUT), true);\n    } finally {\n        await lambda.cleanup();\n    }\n}\n\nasync function memoryLimitOk(\n    t: ExecutionContext,\n    provider: Provider,\n    options: CommonOptions\n) {\n    const lambda = await faast(provider, funcs, {\n        ...options,\n        timeout: 200,\n        memorySize: 512,\n        maxRetries: 0,\n        gc: \"off\",\n        description: t.title\n    });\n\n    try {\n        const bytes = 64 * 1024 * 1024;\n        const rv = await lambda.functions.allocate(bytes);\n        t.is(rv.elems, bytes / 8);\n    } finally {\n        await lambda.cleanup();\n    }\n}\n\nasync function memoryLimitFail(\n    t: ExecutionContext,\n    provider: Provider,\n    options: CommonOptions\n) {\n    const lambda = await faast(provider, funcs, {\n        ...options,\n        timeout: 200,\n        memorySize: 512,\n        maxRetries: 0,\n        gc: \"off\",\n        description: t.title\n    });\n\n    try {\n        const bytes = 512 * 1024 * 1024;\n        await t.throwsAsync(lambda.functions.allocate(bytes), { message: /memory/i });\n    } finally {\n        lambda && (await lambda.cleanup());\n    }\n}\n\n// Note that this test takes 180s by default. Set the ava timeout to 2m or\n// longer otherwise it will fail with a timeout error.\nasync function testLongInvoke(\n    t: ExecutionContext,\n    provider: Provider,\n    options: CommonOptions\n) {\n    // The http timeout is 120s in awssdk by default. Uncomment the following\n    // line to shorten it to 20s for focused testing. Note that shortening it\n    // below 20s causes (harmless) timeout error messages from SQS on the long\n    // polling response queue. If faast.js is working correctly, the shortened\n    // timeout should not cause a test failure.\n    //\n    // config.update({ httpOptions: { timeout: 20000 } });\n    const opts: CommonOptions = {\n        timeout: 500,\n        gc: \"off\",\n        description: t.title,\n        ...options\n    };\n    const faastModule = await faast(provider, funcs, opts);\n    const remote = faastModule.functions;\n    try {\n        let i = 0;\n        const args = [\"a\", \"b\", \"c\"];\n        // The use of an async generator is to mimick a real use case from a\n        // client of faast.js. The presence of an error should also be revealed\n        // with a regular remote function call.\n        for await (const arg of remote.asyncGeneratorDelay(args, 60000)) {\n            t.is(arg, args[i++]);\n        }\n    } finally {\n        await faastModule.cleanup();\n    }\n}\n\ntype LimitType = \"memory\" | \"timeout\" | \"generator\" | \"long\";\nconst allLimits = [\"memory\", \"timeout\", \"long\", \"generator\"] as const;\n\nconst configurations: [Provider, CommonOptions, readonly LimitType[]][] = [\n    [\"aws\", { mode: \"https\", childProcess: true }, allLimits],\n    [\"aws\", { mode: \"queue\", childProcess: true }, allLimits],\n    [\"aws\", { mode: \"https\", childProcess: false }, [\"memory\", \"timeout\", \"generator\"]],\n    [\"aws\", { mode: \"queue\", childProcess: false }, [\"memory\", \"timeout\", \"generator\"]],\n    [\"google\", { mode: \"https\", childProcess: true }, [\"memory\", \"timeout\", \"long\"]],\n    [\"google\", { mode: \"queue\", childProcess: true }, []],\n    [\"local\", {}, [\"timeout\"]]\n];\n\nfor (const [provider, config, limitTypes] of configurations) {\n    const opts = inspect(config);\n    if (limitTypes.find(t => t === \"memory\")) {\n        test(\n            title(provider, `memory under limit ${opts}`),\n            memoryLimitOk,\n            provider,\n            config\n        );\n        test(title(provider, `out of memory`, config), memoryLimitFail, provider, config);\n    }\n    if (limitTypes.find(t => t === \"timeout\")) {\n        test(title(provider, `timeout`, config), testTimeout, provider, config);\n    }\n    if (limitTypes.find(t => t === \"long\")) {\n        test(title(provider, `long invoke`, config), testLongInvoke, provider, config);\n    }\n    if (limitTypes.find(t => t === \"generator\")) {\n        test(\n            title(provider, `generator timeout`, config),\n            testGenerator,\n            provider,\n            config\n        );\n    }\n}\n"]}
\No newline at end of file