Merge pull request #6847 from thomasmichaelwallace/fix-sqs-integration-tests

SQS integration tests
This commit is contained in:
Philipp Muens 2019-10-18 09:58:38 +02:00 committed by GitHub
commit d14e9d649b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 150 additions and 0 deletions

View File

@ -0,0 +1,13 @@
'use strict';
// NOTE: the `utils.js` file is bundled into the deployment package
// eslint-disable-next-line
const { log } = require('./utils');
function sqsBasic(event, context, callback) {
const functionName = 'sqsBasic';
log(functionName, JSON.stringify(event));
return callback(null, event);
}
module.exports = { sqsBasic };

View File

@ -0,0 +1,21 @@
service: CHANGE_TO_UNIQUE_PER_RUN
provider:
name: aws
runtime: nodejs10.x
versionFunctions: false
functions:
sqsBasic:
handler: core.sqsBasic
events:
- sqs:
arn:
Fn::Join:
- ':'
- - arn
- aws
- sqs
- Ref: AWS::Region
- Ref: AWS::AccountId
- CHANGE_TO_UNIQUE_PER_RUN

View File

@ -0,0 +1,69 @@
'use strict';
const path = require('path');
const { expect } = require('chai');
const { getTmpDirPath } = require('../../utils/fs');
const { createSqsQueue, deleteSqsQueue, sendSqsMessage } = require('../../utils/sqs');
const {
createTestService,
deployService,
removeService,
waitForFunctionLogs,
} = require('../../utils/misc');
const { getMarkers } = require('../shared/utils');
describe('AWS - SQS Integration Test', function() {
this.timeout(1000 * 60 * 100); // Involves time-taking deploys
let serviceName;
let stackName;
let tmpDirPath;
let queueName;
const stage = 'dev';
before(() => {
tmpDirPath = getTmpDirPath();
console.info(`Temporary path: ${tmpDirPath}`);
const serverlessConfig = createTestService(tmpDirPath, {
templateDir: path.join(__dirname, 'service'),
filesToAdd: [path.join(__dirname, '..', 'shared')],
serverlessConfigHook:
// Ensure unique queues (to avoid collision among concurrent CI runs)
config => {
queueName = `${config.service}-basic`;
config.functions.sqsBasic.events[0].sqs.arn['Fn::Join'][1][5] = queueName;
},
});
serviceName = serverlessConfig.service;
stackName = `${serviceName}-${stage}`;
// create existing SQS queue
// NOTE: deployment can only be done once the SQS queue is created
console.info(`Creating SQS queue "${queueName}"...`);
return createSqsQueue(queueName).then(() => {
console.info(`Deploying "${stackName}" service...`);
deployService(tmpDirPath);
});
});
after(() => {
console.info('Removing service...');
removeService(tmpDirPath);
console.info('Deleting SQS queue');
return deleteSqsQueue(queueName);
});
describe('Basic Setup', () => {
it('should invoke on queue message(s)', () => {
const functionName = 'sqsBasic';
const markers = getMarkers(functionName);
const message = 'Hello from SQS!';
return sendSqsMessage(queueName, message)
.then(() => waitForFunctionLogs(tmpDirPath, functionName, markers.start, markers.end))
.then(logs => {
expect(logs).to.include(functionName);
expect(logs).to.include(message);
});
});
});
});

47
tests/utils/sqs/index.js Normal file
View File

@ -0,0 +1,47 @@
'use strict';
const AWS = require('aws-sdk');
const { region, persistentRequest } = require('../misc');
function createSqsQueue(queueName) {
const SQS = new AWS.SQS({ region });
const params = {
QueueName: queueName,
};
return SQS.createQueue(params).promise();
}
function deleteSqsQueue(queueName) {
const SQS = new AWS.SQS({ region });
return SQS.getQueueUrl({ QueueName: queueName })
.promise()
.then(data => {
const params = {
QueueUrl: data.QueueUrl,
};
return SQS.deleteQueue(params).promise();
});
}
function sendSqsMessage(queueName, message) {
const SQS = new AWS.SQS({ region });
return SQS.getQueueUrl({ QueueName: queueName })
.promise()
.then(data => {
const params = {
QueueUrl: data.QueueUrl,
MessageBody: message,
};
return SQS.sendMessage(params).promise();
});
}
module.exports = {
createSqsQueue: persistentRequest.bind(this, createSqsQueue),
deleteSqsQueue: persistentRequest.bind(this, deleteSqsQueue),
sendSqsMessage: persistentRequest.bind(this, sendSqsMessage),
};