UNPKG

faastjs

Version:

Serverless batch computing made simple.

169 lines 23.3 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); /** * The purpose of this test is to check that the trampoline function on AWS can * route calls, invoke the wrapper, and return values correctly, without * actually creating a cloud function. However, it does use real cloud queues. */ const ava_1 = require("ava"); const aws_sdk_1 = require("aws-sdk"); const uuid_1 = require("uuid"); const aws_faast_1 = require("../src/aws/aws-faast"); const aws_queue_1 = require("../src/aws/aws-queue"); const aws_trampoline_1 = require("../src/aws/aws-trampoline"); const provider_1 = require("../src/provider"); const serialize_1 = require("../src/serialize"); const shared_1 = require("../src/shared"); const wrapper_1 = require("../src/wrapper"); const funcs = require("./fixtures/functions"); const util_1 = require("./fixtures/util"); const sqs = new aws_sdk_1.SQS({ apiVersion: "2012-11-05", region: "us-west-2" }); process.env.AWS_REGION = "us-west-2"; process.env.FAAST_SILENT = "true"; const lambdaContext = { callbackWaitsForEmptyEventLoop: true, awsRequestId: "aws-trampoline-test-awsRequestId", logGroupName: "aws-trampoline-test-logGroupName", logStreamName: "aws-trampoline-test-logStreamName", getRemainingTimeInMillis: () => 1000, functionName: "aws-trampoline-test-functionName", functionVersion: "aws-trampoline-test-functionVersion", invokedFunctionArn: "aws-trampoline-test-invokedFunctionArn", memoryLimitInMB: "1728", done: () => { }, fail: _ => { }, succeed: (_) => { } }; async function makeResponseQueue() { const QueueName = `faast-${(0, uuid_1.v4)()}-test`; const { QueueUrl } = await sqs.createQueue({ QueueName }).promise(); return QueueUrl; } async function deleteResponseQueue(QueueUrl) { try { // Sometimes AWS needs time to propagate the existence of a queue before // deleting it. This manifests as a NonExistentQueue error. Waiting // a short while seems to make this less common. await (0, shared_1.sleep)(5000); return await sqs.deleteQueue({ QueueUrl }).promise(); } catch (err) { console.error(`Could not delete response queue: ${err}`); throw err; } } async function getMessages(QueueUrl, kind, nExpected) { const metrics = new aws_faast_1.AwsMetrics(); const cancel = new Promise(_ => { }); const result = []; while (result.length < nExpected) { const messages = await (0, aws_queue_1.receiveMessages)(sqs, QueueUrl, metrics, cancel); result.push(...(0, provider_1.filterMessages)(messages.Messages, kind)); } return result; } (0, ava_1.default)((0, util_1.title)("aws", "trampoline https mode with promise response"), async (t) => { const wrapper = new wrapper_1.Wrapper(funcs, { childProcess: false, wrapperLog: () => { } }); const { trampoline } = (0, aws_trampoline_1.makeTrampoline)(wrapper); const arg = "promise with https on aws"; const name = funcs.identityString.name; const QueueUrl = await makeResponseQueue(); try { await trampoline({ callId: "42", name, args: (0, serialize_1.serializeFunctionArgs)(name, [arg], true), modulePath: "./fixtures/functions", ResponseQueueId: QueueUrl }, lambdaContext); const [msg] = await getMessages(QueueUrl, "promise", 1); (0, util_1.expectMessage)(t, msg, "promise", arg); } finally { deleteResponseQueue(QueueUrl); } }); (0, ava_1.default)((0, util_1.title)("aws", "trampoline queue mode with promise response"), async (t) => { const wrapper = new wrapper_1.Wrapper(funcs, { childProcess: false, wrapperLog: () => { } }); const arg = "promise with queue on aws"; const QueueUrl = await makeResponseQueue(); try { const { trampoline } = (0, aws_trampoline_1.makeTrampoline)(wrapper); const name = funcs.identityString.name; const call = { callId: "43", name, args: (0, serialize_1.serializeFunctionArgs)(name, [arg], true), modulePath: "./fixtures/functions", ResponseQueueId: QueueUrl }; const event = { Records: [ { Sns: { Message: (0, serialize_1.serialize)(call) } } ] }; await trampoline(event, lambdaContext); const [msg] = await getMessages(QueueUrl, "promise", 1); (0, util_1.expectMessage)(t, msg, "promise", arg); } finally { await deleteResponseQueue(QueueUrl); } }); (0, ava_1.default)((0, util_1.title)("aws", "trampoline https mode with async iterator response"), async (t) => { const wrapper = new wrapper_1.Wrapper(funcs, { childProcess: false, wrapperLog: () => { } }); const { trampoline } = (0, aws_trampoline_1.makeTrampoline)(wrapper); const name = funcs.asyncGenerator.name; const arg = ["async generator with https on aws", "second arg"]; const QueueUrl = await makeResponseQueue(); try { await trampoline({ callId: "44", name, args: (0, serialize_1.serializeFunctionArgs)(name, [arg], true), modulePath: "./fixtures/functions", ResponseQueueId: QueueUrl }, lambdaContext); const messages = await getMessages(QueueUrl, "iterator", arg.length + 1); (0, util_1.checkIteratorMessages)(t, messages, arg); } finally { await deleteResponseQueue(QueueUrl); } }); (0, ava_1.default)((0, util_1.title)("aws", "trampoline queue mode with async iterator response"), async (t) => { const wrapper = new wrapper_1.Wrapper(funcs, { childProcess: false, wrapperLog: () => { } }); const QueueUrl = await makeResponseQueue(); const arg = ["async generator with queue on aws", "second arg"]; try { const { trampoline } = (0, aws_trampoline_1.makeTrampoline)(wrapper); const name = funcs.asyncGenerator.name; const call = { callId: "45", name, args: (0, serialize_1.serializeFunctionArgs)(name, [arg], true), modulePath: "./fixtures/functions", ResponseQueueId: QueueUrl }; const event = { Records: [ { Sns: { Message: (0, serialize_1.serialize)(call) } } ] }; await trampoline(event, lambdaContext); const messages = await getMessages(QueueUrl, "iterator", arg.length + 1); (0, util_1.checkIteratorMessages)(t, messages, arg); } finally { await deleteResponseQueue(QueueUrl); } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-trampoline.test.js","sourceRoot":"","sources":["../../test/aws-trampoline.test.ts"],"names":[],"mappings":";;AAAA;;;;GAIG;AACH,6BAAuB;AAEvB,qCAA8B;AAC9B,+BAAoC;AACpC,oDAAkD;AAClD,oDAAuD;AACvD,8DAA2D;AAC3D,8CAAuD;AACvD,gDAAoE;AACpE,0CAAsC;AACtC,4CAAyC;AACzC,8CAA8C;AAC9C,0CAA8E;AAE9E,MAAM,GAAG,GAAG,IAAI,aAAG,CAAC,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,EAAE,WAAW,EAAE,CAAC,CAAC;AACvE,OAAO,CAAC,GAAG,CAAC,UAAU,GAAG,WAAW,CAAC;AACrC,OAAO,CAAC,GAAG,CAAC,YAAY,GAAG,MAAM,CAAC;AAElC,MAAM,aAAa,GAAY;IAC3B,8BAA8B,EAAE,IAAI;IACpC,YAAY,EAAE,kCAAkC;IAChD,YAAY,EAAE,kCAAkC;IAChD,aAAa,EAAE,mCAAmC;IAClD,wBAAwB,EAAE,GAAG,EAAE,CAAC,IAAI;IACpC,YAAY,EAAE,kCAAkC;IAChD,eAAe,EAAE,qCAAqC;IACtD,kBAAkB,EAAE,wCAAwC;IAC5D,eAAe,EAAE,MAAM;IACvB,IAAI,EAAE,GAAG,EAAE,GAAE,CAAC;IACd,IAAI,EAAE,CAAC,CAAC,EAAE,GAAE,CAAC;IACb,OAAO,EAAE,CAAC,CAAS,EAAE,EAAE,GAAE,CAAC;CAC7B,CAAC;AAEF,KAAK,UAAU,iBAAiB;IAC5B,MAAM,SAAS,GAAG,SAAS,IAAA,SAAM,GAAE,OAAO,CAAC;IAC3C,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,GAAG,CAAC,WAAW,CAAC,EAAE,SAAS,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC;IACpE,OAAO,QAAS,CAAC;AACrB,CAAC;AAED,KAAK,UAAU,mBAAmB,CAAC,QAAgB;IAC/C,IAAI;QACA,wEAAwE;QACxE,mEAAmE;QACnE,gDAAgD;QAChD,MAAM,IAAA,cAAK,EAAC,IAAI,CAAC,CAAC;QAClB,OAAO,MAAM,GAAG,CAAC,WAAW,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC;KACxD;IAAC,OAAO,GAAQ,EAAE;QACf,OAAO,CAAC,KAAK,CAAC,oCAAoC,GAAG,EAAE,CAAC,CAAC;QACzD,MAAM,GAAG,CAAC;KACb;AACL,CAAC;AAED,KAAK,UAAU,WAAW,CAAiB,QAAgB,EAAE,IAAO,EAAE,SAAiB;IACnF,MAAM,OAAO,GAAG,IAAI,sBAAU,EAAE,CAAC;IACjC,MAAM,MAAM,GAAG,IAAI,OAAO,CAAO,CAAC,CAAC,EAAE,GAAE,CAAC,CAAC,CAAC;IAC1C,MAAM,MAAM,GAAG,EAAE,CAAC;IAClB,OAAO,MAAM,CAAC,MAAM,GAAG,SAAS,EAAE;QAC9B,MAAM,QAAQ,GAAG,MAAM,IAAA,2BAAe,EAAC,GAAG,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;QACvE,MAAM,CAAC,IAAI,CAAC,GAAG,IAAA,yBAAc,EAAC,QAAQ,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC;KAC3D;IACD,OAAO,MAAM,CAAC;AAClB,CAAC;AAED,IAAA,aAAI,EAAC,IAAA,YAAK,EAAC,KAAK,EAAE,6CAA6C,CAAC,EAAE,KAAK,EAAC,CAAC,EAAC,EAAE;IACxE,MAAM,OAAO,GAAG,IAAI,iBAAO,CAAC,KAAK,EAAE,EAAE,YAAY,EAAE,KAAK,EAAE,UAAU,EAAE,GAAG,EAAE,GAAE,CAAC,EAAE,CAAC,CAAC;IAClF,MAAM,EAAE,UAAU,EAAE,GAAG,IAAA,+BAAc,EAAC,OAAO,CAAC,CAAC;IAC/C,MAAM,GAAG,GAAG,2BAA2B,CAAC;IACxC,MAAM,IAAI,GAAG,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC;IACvC,MAAM,QAAQ,GAAG,MAAM,iBAAiB,EAAE,CAAC;IAC3C,IAAI;QACA,MAAM,UAAU,CACZ;YACI,MAAM,EAAE,IAAI;YACZ,IAAI;YACJ,IAAI,EAAE,IAAA,iCAAqB,EAAC,IAAI,EAAE,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC;YAC9C,UAAU,EAAE,sBAAsB;YAClC,eAAe,EAAE,QAAQ;SAC5B,EACD,aAAa,CAChB,CAAC;QAEF,MAAM,CAAC,GAAG,CAAC,GAAG,MAAM,WAAW,CAAC,QAAQ,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;QACxD,IAAA,oBAAa,EAAC,CAAC,EAAE,GAAG,EAAE,SAAS,EAAE,GAAG,CAAC,CAAC;KACzC;YAAS;QACN,mBAAmB,CAAC,QAAQ,CAAC,CAAC;KACjC;AACL,CAAC,CAAC,CAAC;AAEH,IAAA,aAAI,EAAC,IAAA,YAAK,EAAC,KAAK,EAAE,6CAA6C,CAAC,EAAE,KAAK,EAAC,CAAC,EAAC,EAAE;IACxE,MAAM,OAAO,GAAG,IAAI,iBAAO,CAAC,KAAK,EAAE,EAAE,YAAY,EAAE,KAAK,EAAE,UAAU,EAAE,GAAG,EAAE,GAAE,CAAC,EAAE,CAAC,CAAC;IAClF,MAAM,GAAG,GAAG,2BAA2B,CAAC;IACxC,MAAM,QAAQ,GAAG,MAAM,iBAAiB,EAAE,CAAC;IAC3C,IAAI;QACA,MAAM,EAAE,UAAU,EAAE,GAAG,IAAA,+BAAc,EAAC,OAAO,CAAC,CAAC;QAC/C,MAAM,IAAI,GAAG,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC;QACvC,MAAM,IAAI,GAAG;YACT,MAAM,EAAE,IAAI;YACZ,IAAI;YACJ,IAAI,EAAE,IAAA,iCAAqB,EAAC,IAAI,EAAE,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC;YAC9C,UAAU,EAAE,sBAAsB;YAClC,eAAe,EAAE,QAAQ;SAC5B,CAAC;QACF,MAAM,KAAK,GAAG;YACV,OAAO,EAAE;gBACL;oBACI,GAAG,EAAE;wBACD,OAAO,EAAE,IAAA,qBAAS,EAAC,IAAI,CAAC;qBAC3B;iBACJ;aACJ;SACJ,CAAC;QAEF,MAAM,UAAU,CAAC,KAAiB,EAAE,aAAa,CAAC,CAAC;QAEnD,MAAM,CAAC,GAAG,CAAC,GAAG,MAAM,WAAW,CAAC,QAAQ,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;QACxD,IAAA,oBAAa,EAAC,CAAC,EAAE,GAAG,EAAE,SAAS,EAAE,GAAG,CAAC,CAAC;KACzC;YAAS;QACN,MAAM,mBAAmB,CAAC,QAAQ,CAAC,CAAC;KACvC;AACL,CAAC,CAAC,CAAC;AAEH,IAAA,aAAI,EAAC,IAAA,YAAK,EAAC,KAAK,EAAE,oDAAoD,CAAC,EAAE,KAAK,EAAC,CAAC,EAAC,EAAE;IAC/E,MAAM,OAAO,GAAG,IAAI,iBAAO,CAAC,KAAK,EAAE,EAAE,YAAY,EAAE,KAAK,EAAE,UAAU,EAAE,GAAG,EAAE,GAAE,CAAC,EAAE,CAAC,CAAC;IAClF,MAAM,EAAE,UAAU,EAAE,GAAG,IAAA,+BAAc,EAAC,OAAO,CAAC,CAAC;IAC/C,MAAM,IAAI,GAAG,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC;IACvC,MAAM,GAAG,GAAG,CAAC,mCAAmC,EAAE,YAAY,CAAC,CAAC;IAChE,MAAM,QAAQ,GAAG,MAAM,iBAAiB,EAAE,CAAC;IAC3C,IAAI;QACA,MAAM,UAAU,CACZ;YACI,MAAM,EAAE,IAAI;YACZ,IAAI;YACJ,IAAI,EAAE,IAAA,iCAAqB,EAAC,IAAI,EAAE,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC;YAC9C,UAAU,EAAE,sBAAsB;YAClC,eAAe,EAAE,QAAQ;SAC5B,EACD,aAAa,CAChB,CAAC;QACF,MAAM,QAAQ,GAAG,MAAM,WAAW,CAAC,QAAQ,EAAE,UAAU,EAAE,GAAG,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QACzE,IAAA,4BAAqB,EAAC,CAAC,EAAE,QAAQ,EAAE,GAAG,CAAC,CAAC;KAC3C;YAAS;QACN,MAAM,mBAAmB,CAAC,QAAQ,CAAC,CAAC;KACvC;AACL,CAAC,CAAC,CAAC;AAEH,IAAA,aAAI,EAAC,IAAA,YAAK,EAAC,KAAK,EAAE,oDAAoD,CAAC,EAAE,KAAK,EAAC,CAAC,EAAC,EAAE;IAC/E,MAAM,OAAO,GAAG,IAAI,iBAAO,CAAC,KAAK,EAAE,EAAE,YAAY,EAAE,KAAK,EAAE,UAAU,EAAE,GAAG,EAAE,GAAE,CAAC,EAAE,CAAC,CAAC;IAClF,MAAM,QAAQ,GAAG,MAAM,iBAAiB,EAAE,CAAC;IAC3C,MAAM,GAAG,GAAG,CAAC,mCAAmC,EAAE,YAAY,CAAC,CAAC;IAEhE,IAAI;QACA,MAAM,EAAE,UAAU,EAAE,GAAG,IAAA,+BAAc,EAAC,OAAO,CAAC,CAAC;QAC/C,MAAM,IAAI,GAAG,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC;QACvC,MAAM,IAAI,GAAG;YACT,MAAM,EAAE,IAAI;YACZ,IAAI;YACJ,IAAI,EAAE,IAAA,iCAAqB,EAAC,IAAI,EAAE,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC;YAC9C,UAAU,EAAE,sBAAsB;YAClC,eAAe,EAAE,QAAQ;SAC5B,CAAC;QACF,MAAM,KAAK,GAAG;YACV,OAAO,EAAE;gBACL;oBACI,GAAG,EAAE;wBACD,OAAO,EAAE,IAAA,qBAAS,EAAC,IAAI,CAAC;qBAC3B;iBACJ;aACJ;SACJ,CAAC;QAEF,MAAM,UAAU,CAAC,KAAiB,EAAE,aAAa,CAAC,CAAC;QAEnD,MAAM,QAAQ,GAAG,MAAM,WAAW,CAAC,QAAQ,EAAE,UAAU,EAAE,GAAG,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QACzE,IAAA,4BAAqB,EAAC,CAAC,EAAE,QAAQ,EAAE,GAAG,CAAC,CAAC;KAC3C;YAAS;QACN,MAAM,mBAAmB,CAAC,QAAQ,CAAC,CAAC;KACvC;AACL,CAAC,CAAC,CAAC","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: any) {\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"]}