UNPKG

12.9 kBJavaScriptView Raw
1"use strict";
2Object.defineProperty(exports, "__esModule", { value: true });
3const ava_1 = require("ava");
4const index_1 = require("../index");
5const funcs = require("../test/fixtures/functions");
6const util_1 = require("../test/fixtures/util");
7const throttle_1 = require("../src/throttle");
8async function throughput(t, provider, options) {
9 const lambda = await (0, index_1.faast)(provider, funcs, {
10 gc: "off",
11 description: t.title,
12 ...options
13 });
14 lambda.on("stats", s => console.log(s.toString()));
15 try {
16 let completed = 0;
17 const nSamplesPerFunction = 100000000;
18 const pump = new throttle_1.Pump({ concurrency: options.concurrency }, () => lambda.functions.monteCarloPI(nSamplesPerFunction).then(() => completed++));
19 pump.start();
20 await (0, util_1.sleep)(options.duration);
21 await pump.drain();
22 const cost = await lambda.costSnapshot();
23 console.log(`Stats: ${lambda.stats()}`);
24 console.log(`Cost:`);
25 console.log(`${cost}`);
26 console.log(`Completed ${completed} calls in ${options.duration / (60 * 1000)} minute(s)`);
27 }
28 finally {
29 await lambda.cleanup();
30 }
31}
32async function rampUp(t, provider, options) {
33 const lambda = await (0, index_1.faast)(provider, funcs, {
34 gc: "off",
35 description: t.title,
36 ...options
37 });
38 lambda.on("stats", s => console.log(s.toString()));
39 try {
40 const nParallelFunctions = 500;
41 const nSamplesPerFunction = 2000000;
42 const promises = [];
43 for (let i = 0; i < nParallelFunctions; i++) {
44 promises.push(lambda.functions.monteCarloPI(nSamplesPerFunction));
45 }
46 const results = await Promise.all(promises);
47 let insidePoints = 0;
48 let samplePoints = 0;
49 results.forEach(m => {
50 insidePoints += m.inside;
51 samplePoints += m.samples;
52 });
53 console.log(`Stats:\n${lambda.stats()}`);
54 console.log(`inside: ${insidePoints}, samples: ${samplePoints}`);
55 t.is(samplePoints, nParallelFunctions * nSamplesPerFunction);
56 const estimatedPI = (insidePoints / samplePoints) * 4;
57 console.log(`PI estimate: ${estimatedPI}`);
58 t.is(Number(estimatedPI.toFixed(2)), 3.14);
59 const cost = await lambda.costSnapshot();
60 console.log(`Cost: ${cost}`);
61 }
62 finally {
63 await lambda.cleanup();
64 }
65}
66const rampUpConfigurations = [
67 { memorySize: 1024, mode: "https", concurrency: 500 },
68 { memorySize: 1024, mode: "queue", concurrency: 500 }
69];
70for (const provider of index_1.providers) {
71 for (const config of rampUpConfigurations) {
72 ava_1.default.serial((0, util_1.title)(provider, "ramp up", config), rampUp, provider, config);
73 }
74}
75const throughputConfigurations = [
76 { memorySize: 2048, mode: "https", concurrency: 500, duration: 180 * 1000 },
77 { memorySize: 2048, mode: "queue", concurrency: 500, duration: 180 * 1000 }
78];
79for (const provider of index_1.providers) {
80 for (const config of throughputConfigurations) {
81 ava_1.default.serial((0, util_1.title)(provider, "throughput load test", config), throughput, provider, config);
82 }
83}
84ava_1.default.serial(throughput, "local", { memorySize: 64, duration: 60 * 1000 });
85//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"performance.test.js","sourceRoot":"","sources":["../../test-perf/performance.test.ts"],"names":[],"mappings":"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","sourcesContent":["import test, { ExecutionContext } from \"ava\";\nimport { CommonOptions, faast, Provider, providers } from \"../index\";\nimport * as funcs from \"../test/fixtures/functions\";\nimport { sleep, title } from \"../test/fixtures/util\";\nimport { Pump } from \"../src/throttle\";\n\nasync function throughput(\n    t: ExecutionContext,\n    provider: Provider,\n    options: CommonOptions & { duration: number }\n) {\n    const lambda = await faast(provider, funcs, {\n        gc: \"off\",\n        description: t.title,\n        ...options\n    });\n    lambda.on(\"stats\", s => console.log(s.toString()));\n\n    try {\n        let completed = 0;\n        const nSamplesPerFunction = 100000000;\n        const pump = new Pump({ concurrency: options.concurrency! }, () =>\n            lambda.functions.monteCarloPI(nSamplesPerFunction).then(() => completed++)\n        );\n        pump.start();\n        await sleep(options.duration);\n        await pump.drain();\n        const cost = await lambda.costSnapshot();\n        console.log(`Stats: ${lambda.stats()}`);\n        console.log(`Cost:`);\n        console.log(`${cost}`);\n        console.log(\n            `Completed ${completed} calls in ${options.duration / (60 * 1000)} minute(s)`\n        );\n    } finally {\n        await lambda.cleanup();\n    }\n}\n\nasync function rampUp(t: ExecutionContext, provider: Provider, options: CommonOptions) {\n    const lambda = await faast(provider, funcs, {\n        gc: \"off\",\n        description: t.title,\n        ...options\n    });\n    lambda.on(\"stats\", s => console.log(s.toString()));\n\n    try {\n        const nParallelFunctions = 500;\n        const nSamplesPerFunction = 2000000;\n        const promises: Promise<funcs.MonteCarloReturn>[] = [];\n        for (let i = 0; i < nParallelFunctions; i++) {\n            promises.push(lambda.functions.monteCarloPI(nSamplesPerFunction));\n        }\n\n        const results = await Promise.all(promises);\n        let insidePoints = 0;\n        let samplePoints = 0;\n\n        results.forEach(m => {\n            insidePoints += m.inside;\n            samplePoints += m.samples;\n        });\n\n        console.log(`Stats:\\n${lambda.stats()}`);\n        console.log(`inside: ${insidePoints}, samples: ${samplePoints}`);\n        t.is(samplePoints, nParallelFunctions * nSamplesPerFunction);\n        const estimatedPI = (insidePoints / samplePoints) * 4;\n        console.log(`PI estimate: ${estimatedPI}`);\n        t.is(Number(estimatedPI.toFixed(2)), 3.14);\n        const cost = await lambda.costSnapshot();\n        console.log(`Cost: ${cost}`);\n    } finally {\n        await lambda.cleanup();\n    }\n}\n\nconst rampUpConfigurations = [\n    { memorySize: 1024, mode: \"https\", concurrency: 500 },\n    { memorySize: 1024, mode: \"queue\", concurrency: 500 }\n] as const;\n\nfor (const provider of providers) {\n    for (const config of rampUpConfigurations) {\n        test.serial(title(provider, \"ramp up\", config), rampUp, provider, config);\n    }\n}\n\nconst throughputConfigurations = [\n    { memorySize: 2048, mode: \"https\", concurrency: 500, duration: 180 * 1000 },\n    { memorySize: 2048, mode: \"queue\", concurrency: 500, duration: 180 * 1000 }\n] as const;\n\nfor (const provider of providers) {\n    for (const config of throughputConfigurations) {\n        test.serial(\n            title(provider, \"throughput load test\", config),\n            throughput,\n            provider,\n            config\n        );\n    }\n}\n\ntest.serial(throughput, \"local\", { memorySize: 64, duration: 60 * 1000 });\n"]}
\No newline at end of file