1 | ;
|
2 | Object.defineProperty(exports, "__esModule", { value: true });
|
3 | /**
|
4 | * The purpose of this test is to check that the trampoline function on AWS can
|
5 | * route calls, invoke the wrapper, and return values correctly, without
|
6 | * actually creating a cloud function. However, it does use real cloud queues.
|
7 | */
|
8 | const ava_1 = require("ava");
|
9 | const aws_sdk_1 = require("aws-sdk");
|
10 | const uuid_1 = require("uuid");
|
11 | const aws_faast_1 = require("../src/aws/aws-faast");
|
12 | const aws_queue_1 = require("../src/aws/aws-queue");
|
13 | const aws_trampoline_1 = require("../src/aws/aws-trampoline");
|
14 | const provider_1 = require("../src/provider");
|
15 | const serialize_1 = require("../src/serialize");
|
16 | const shared_1 = require("../src/shared");
|
17 | const wrapper_1 = require("../src/wrapper");
|
18 | const funcs = require("./fixtures/functions");
|
19 | const util_1 = require("./fixtures/util");
|
20 | const sqs = new aws_sdk_1.SQS({ apiVersion: "2012-11-05", region: "us-west-2" });
|
21 | process.env.AWS_REGION = "us-west-2";
|
22 | process.env.FAAST_SILENT = "true";
|
23 | const lambdaContext = {
|
24 | callbackWaitsForEmptyEventLoop: true,
|
25 | awsRequestId: "aws-trampoline-test-awsRequestId",
|
26 | logGroupName: "aws-trampoline-test-logGroupName",
|
27 | logStreamName: "aws-trampoline-test-logStreamName",
|
28 | getRemainingTimeInMillis: () => 1000,
|
29 | functionName: "aws-trampoline-test-functionName",
|
30 | functionVersion: "aws-trampoline-test-functionVersion",
|
31 | invokedFunctionArn: "aws-trampoline-test-invokedFunctionArn",
|
32 | memoryLimitInMB: "1728",
|
33 | done: () => { },
|
34 | fail: _ => { },
|
35 | succeed: (_) => { }
|
36 | };
|
37 | async function makeResponseQueue() {
|
38 | const QueueName = `faast-${uuid_1.v4()}-test`;
|
39 | const { QueueUrl } = await sqs.createQueue({ QueueName }).promise();
|
40 | return QueueUrl;
|
41 | }
|
42 | async function deleteResponseQueue(QueueUrl) {
|
43 | try {
|
44 | // Sometimes AWS needs time to propagate the existence of a queue before
|
45 | // deleting it. This manifests as a NonExistentQueue error. Waiting
|
46 | // a short while seems to make this less common.
|
47 | await shared_1.sleep(5000);
|
48 | return await sqs.deleteQueue({ QueueUrl }).promise();
|
49 | }
|
50 | catch (err) {
|
51 | console.error(`Could not delete response queue: ${err}`);
|
52 | throw err;
|
53 | }
|
54 | }
|
55 | async function getMessages(QueueUrl, kind, nExpected) {
|
56 | const metrics = new aws_faast_1.AwsMetrics();
|
57 | const cancel = new Promise(_ => { });
|
58 | const result = [];
|
59 | while (result.length < nExpected) {
|
60 | const messages = await aws_queue_1.receiveMessages(sqs, QueueUrl, metrics, cancel);
|
61 | result.push(...provider_1.filterMessages(messages.Messages, kind));
|
62 | }
|
63 | return result;
|
64 | }
|
65 | ava_1.default(util_1.title("aws", "trampoline https mode with promise response"), async (t) => {
|
66 | const wrapper = new wrapper_1.Wrapper(funcs, { childProcess: false, wrapperLog: () => { } });
|
67 | const { trampoline } = aws_trampoline_1.makeTrampoline(wrapper);
|
68 | const arg = "promise with https on aws";
|
69 | const name = funcs.identityString.name;
|
70 | const QueueUrl = await makeResponseQueue();
|
71 | try {
|
72 | await trampoline({
|
73 | callId: "42",
|
74 | name,
|
75 | args: serialize_1.serializeFunctionArgs(name, [arg], true),
|
76 | modulePath: "./fixtures/functions",
|
77 | ResponseQueueId: QueueUrl
|
78 | }, lambdaContext);
|
79 | const [msg] = await getMessages(QueueUrl, "promise", 1);
|
80 | util_1.expectMessage(t, msg, "promise", arg);
|
81 | }
|
82 | finally {
|
83 | deleteResponseQueue(QueueUrl);
|
84 | }
|
85 | });
|
86 | ava_1.default(util_1.title("aws", "trampoline queue mode with promise response"), async (t) => {
|
87 | const wrapper = new wrapper_1.Wrapper(funcs, { childProcess: false, wrapperLog: () => { } });
|
88 | const arg = "promise with queue on aws";
|
89 | const QueueUrl = await makeResponseQueue();
|
90 | try {
|
91 | const { trampoline } = aws_trampoline_1.makeTrampoline(wrapper);
|
92 | const name = funcs.identityString.name;
|
93 | const call = {
|
94 | callId: "43",
|
95 | name,
|
96 | args: serialize_1.serializeFunctionArgs(name, [arg], true),
|
97 | modulePath: "./fixtures/functions",
|
98 | ResponseQueueId: QueueUrl
|
99 | };
|
100 | const event = {
|
101 | Records: [
|
102 | {
|
103 | Sns: {
|
104 | Message: serialize_1.serialize(call)
|
105 | }
|
106 | }
|
107 | ]
|
108 | };
|
109 | await trampoline(event, lambdaContext);
|
110 | const [msg] = await getMessages(QueueUrl, "promise", 1);
|
111 | util_1.expectMessage(t, msg, "promise", arg);
|
112 | }
|
113 | finally {
|
114 | await deleteResponseQueue(QueueUrl);
|
115 | }
|
116 | });
|
117 | ava_1.default(util_1.title("aws", "trampoline https mode with async iterator response"), async (t) => {
|
118 | const wrapper = new wrapper_1.Wrapper(funcs, { childProcess: false, wrapperLog: () => { } });
|
119 | const { trampoline } = aws_trampoline_1.makeTrampoline(wrapper);
|
120 | const name = funcs.asyncGenerator.name;
|
121 | const arg = ["async generator with https on aws", "second arg"];
|
122 | const QueueUrl = await makeResponseQueue();
|
123 | try {
|
124 | await trampoline({
|
125 | callId: "44",
|
126 | name,
|
127 | args: serialize_1.serializeFunctionArgs(name, [arg], true),
|
128 | modulePath: "./fixtures/functions",
|
129 | ResponseQueueId: QueueUrl
|
130 | }, lambdaContext);
|
131 | const messages = await getMessages(QueueUrl, "iterator", arg.length + 1);
|
132 | util_1.checkIteratorMessages(t, messages, arg);
|
133 | }
|
134 | finally {
|
135 | await deleteResponseQueue(QueueUrl);
|
136 | }
|
137 | });
|
138 | ava_1.default(util_1.title("aws", "trampoline queue mode with async iterator response"), async (t) => {
|
139 | const wrapper = new wrapper_1.Wrapper(funcs, { childProcess: false, wrapperLog: () => { } });
|
140 | const QueueUrl = await makeResponseQueue();
|
141 | const arg = ["async generator with queue on aws", "second arg"];
|
142 | try {
|
143 | const { trampoline } = aws_trampoline_1.makeTrampoline(wrapper);
|
144 | const name = funcs.asyncGenerator.name;
|
145 | const call = {
|
146 | callId: "45",
|
147 | name,
|
148 | args: serialize_1.serializeFunctionArgs(name, [arg], true),
|
149 | modulePath: "./fixtures/functions",
|
150 | ResponseQueueId: QueueUrl
|
151 | };
|
152 | const event = {
|
153 | Records: [
|
154 | {
|
155 | Sns: {
|
156 | Message: serialize_1.serialize(call)
|
157 | }
|
158 | }
|
159 | ]
|
160 | };
|
161 | await trampoline(event, lambdaContext);
|
162 | const messages = await getMessages(QueueUrl, "iterator", arg.length + 1);
|
163 | util_1.checkIteratorMessages(t, messages, arg);
|
164 | }
|
165 | finally {
|
166 | await deleteResponseQueue(QueueUrl);
|
167 | }
|
168 | });
|
169 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-trampoline.test.js","sourceRoot":"","sources":["../../test/aws-trampoline.test.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * The purpose of this test is to check that the trampoline function on AWS can\n * route calls, invoke the wrapper, and return values correctly, without\n * actually creating a cloud function. However, it does use real cloud queues.\n */\nimport test from \"ava\";\nimport { Context, SNSEvent } from \"aws-lambda\";\nimport { SQS } from \"aws-sdk\";\nimport { v4 as uuidv4 } from \"uuid\";\nimport { AwsMetrics } from \"../src/aws/aws-faast\";\nimport { receiveMessages } from \"../src/aws/aws-queue\";\nimport { makeTrampoline } from \"../src/aws/aws-trampoline\";\nimport { filterMessages, Kind } from \"../src/provider\";\nimport { serialize, serializeFunctionArgs } from \"../src/serialize\";\nimport { sleep } from \"../src/shared\";\nimport { Wrapper } from \"../src/wrapper\";\nimport * as funcs from \"./fixtures/functions\";\nimport { checkIteratorMessages, expectMessage, title } from \"./fixtures/util\";\n\nconst sqs = new SQS({ apiVersion: \"2012-11-05\", region: \"us-west-2\" });\nprocess.env.AWS_REGION = \"us-west-2\";\nprocess.env.FAAST_SILENT = \"true\";\n\nconst lambdaContext: Context = {\n    callbackWaitsForEmptyEventLoop: true,\n    awsRequestId: \"aws-trampoline-test-awsRequestId\",\n    logGroupName: \"aws-trampoline-test-logGroupName\",\n    logStreamName: \"aws-trampoline-test-logStreamName\",\n    getRemainingTimeInMillis: () => 1000,\n    functionName: \"aws-trampoline-test-functionName\",\n    functionVersion: \"aws-trampoline-test-functionVersion\",\n    invokedFunctionArn: \"aws-trampoline-test-invokedFunctionArn\",\n    memoryLimitInMB: \"1728\",\n    done: () => {},\n    fail: _ => {},\n    succeed: (_: string) => {}\n};\n\nasync function makeResponseQueue() {\n    const QueueName = `faast-${uuidv4()}-test`;\n    const { QueueUrl } = await sqs.createQueue({ QueueName }).promise();\n    return QueueUrl!;\n}\n\nasync function deleteResponseQueue(QueueUrl: string) {\n    try {\n        // Sometimes AWS needs time to propagate the existence of a queue before\n        // deleting it. This manifests as a NonExistentQueue error. Waiting\n        // a short while seems to make this less common.\n        await sleep(5000);\n        return await sqs.deleteQueue({ QueueUrl }).promise();\n    } catch (err) {\n        console.error(`Could not delete response queue: ${err}`);\n        throw err;\n    }\n}\n\nasync function getMessages<K extends Kind>(QueueUrl: string, kind: K, nExpected: number) {\n    const metrics = new AwsMetrics();\n    const cancel = new Promise<void>(_ => {});\n    const result = [];\n    while (result.length < nExpected) {\n        const messages = await receiveMessages(sqs, QueueUrl, metrics, cancel);\n        result.push(...filterMessages(messages.Messages, kind));\n    }\n    return result;\n}\n\ntest(title(\"aws\", \"trampoline https mode with promise response\"), async t => {\n    const wrapper = new Wrapper(funcs, { childProcess: false, wrapperLog: () => {} });\n    const { trampoline } = makeTrampoline(wrapper);\n    const arg = \"promise with https on aws\";\n    const name = funcs.identityString.name;\n    const QueueUrl = await makeResponseQueue();\n    try {\n        await trampoline(\n            {\n                callId: \"42\",\n                name,\n                args: serializeFunctionArgs(name, [arg], true),\n                modulePath: \"./fixtures/functions\",\n                ResponseQueueId: QueueUrl\n            },\n            lambdaContext\n        );\n\n        const [msg] = await getMessages(QueueUrl, \"promise\", 1);\n        expectMessage(t, msg, \"promise\", arg);\n    } finally {\n        deleteResponseQueue(QueueUrl);\n    }\n});\n\ntest(title(\"aws\", \"trampoline queue mode with promise response\"), async t => {\n    const wrapper = new Wrapper(funcs, { childProcess: false, wrapperLog: () => {} });\n    const arg = \"promise with queue on aws\";\n    const QueueUrl = await makeResponseQueue();\n    try {\n        const { trampoline } = makeTrampoline(wrapper);\n        const name = funcs.identityString.name;\n        const call = {\n            callId: \"43\",\n            name,\n            args: serializeFunctionArgs(name, [arg], true),\n            modulePath: \"./fixtures/functions\",\n            ResponseQueueId: QueueUrl\n        };\n        const event = {\n            Records: [\n                {\n                    Sns: {\n                        Message: serialize(call)\n                    }\n                }\n            ]\n        };\n\n        await trampoline(event as SNSEvent, lambdaContext);\n\n        const [msg] = await getMessages(QueueUrl, \"promise\", 1);\n        expectMessage(t, msg, \"promise\", arg);\n    } finally {\n        await deleteResponseQueue(QueueUrl);\n    }\n});\n\ntest(title(\"aws\", \"trampoline https mode with async iterator response\"), async t => {\n    const wrapper = new Wrapper(funcs, { childProcess: false, wrapperLog: () => {} });\n    const { trampoline } = makeTrampoline(wrapper);\n    const name = funcs.asyncGenerator.name;\n    const arg = [\"async generator with https on aws\", \"second arg\"];\n    const QueueUrl = await makeResponseQueue();\n    try {\n        await trampoline(\n            {\n                callId: \"44\",\n                name,\n                args: serializeFunctionArgs(name, [arg], true),\n                modulePath: \"./fixtures/functions\",\n                ResponseQueueId: QueueUrl\n            },\n            lambdaContext\n        );\n        const messages = await getMessages(QueueUrl, \"iterator\", arg.length + 1);\n        checkIteratorMessages(t, messages, arg);\n    } finally {\n        await deleteResponseQueue(QueueUrl);\n    }\n});\n\ntest(title(\"aws\", \"trampoline queue mode with async iterator response\"), async t => {\n    const wrapper = new Wrapper(funcs, { childProcess: false, wrapperLog: () => {} });\n    const QueueUrl = await makeResponseQueue();\n    const arg = [\"async generator with queue on aws\", \"second arg\"];\n\n    try {\n        const { trampoline } = makeTrampoline(wrapper);\n        const name = funcs.asyncGenerator.name;\n        const call = {\n            callId: \"45\",\n            name,\n            args: serializeFunctionArgs(name, [arg], true),\n            modulePath: \"./fixtures/functions\",\n            ResponseQueueId: QueueUrl\n        };\n        const event = {\n            Records: [\n                {\n                    Sns: {\n                        Message: serialize(call)\n                    }\n                }\n            ]\n        };\n\n        await trampoline(event as SNSEvent, lambdaContext);\n\n        const messages = await getMessages(QueueUrl, \"iterator\", arg.length + 1);\n        checkIteratorMessages(t, messages, arg);\n    } finally {\n        await deleteResponseQueue(QueueUrl);\n    }\n});\n"]} |
\ | No newline at end of file |