mirror of
https://github.com/serverless/serverless.git
synced 2026-01-18 14:58:43 +00:00
* Allow multiple cron/rate expressions in AWS schedule event * Update schedule.test.js to use runServerless * schedule.test.js: minimize calls to runServerless
75 lines
2.6 KiB
JavaScript
75 lines
2.6 KiB
JavaScript
'use strict';
|
|
|
|
const { expect } = require('chai');
|
|
const fixtures = require('../../fixtures/programmatic');
|
|
|
|
const { deployService, removeService } = require('../../utils/integration');
|
|
const { confirmCloudWatchLogs } = require('../../utils/misc');
|
|
|
|
describe('AWS - Schedule Integration Test', function () {
|
|
this.timeout(1000 * 60 * 100); // Involves time-taking deploys
|
|
let serviceDir;
|
|
let stackName;
|
|
|
|
before(async () => {
|
|
const serviceData = await fixtures.setup('schedule');
|
|
({ servicePath: serviceDir } = serviceData);
|
|
stackName = `${serviceData.serviceConfig.service}-dev`;
|
|
return deployService(serviceDir);
|
|
});
|
|
|
|
after(async () => {
|
|
return removeService(serviceDir);
|
|
});
|
|
|
|
describe('Minimal Setup', () => {
|
|
it('should invoke every minute', () => {
|
|
const functionName = 'scheduleMinimal';
|
|
|
|
return confirmCloudWatchLogs(`/aws/lambda/${stackName}-${functionName}`, async () => {}, {
|
|
checkIsComplete: (soFarEvents) => {
|
|
const logs = soFarEvents.reduce((data, event) => data + event.message, '');
|
|
return logs.includes(functionName);
|
|
},
|
|
}).then((events) => {
|
|
const logs = events.reduce((data, event) => data + event.message, '');
|
|
expect(logs).to.include(functionName);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('Extended Setup', () => {
|
|
it('should invoke every minute with transformed input', () => {
|
|
const functionName = 'scheduleExtended';
|
|
|
|
return confirmCloudWatchLogs(`/aws/lambda/${stackName}-${functionName}`, async () => {}, {
|
|
checkIsComplete: (soFarEvents) => {
|
|
const logs = soFarEvents.reduce((data, event) => data + event.message, '');
|
|
return logs.includes('transformedInput');
|
|
},
|
|
}).then((events) => {
|
|
const logs = events.reduce((data, event) => data + event.message, '');
|
|
expect(logs).to.include(functionName);
|
|
expect(logs).to.include('transformedInput');
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('Extended Setup (array)', () => {
|
|
it('should invoke every minute with transformed input', () => {
|
|
const functionName = 'scheduleExtendedArray';
|
|
|
|
return confirmCloudWatchLogs(`/aws/lambda/${stackName}-${functionName}`, async () => {}, {
|
|
checkIsComplete: (soFarEvents) => {
|
|
const logs = soFarEvents.reduce((data, event) => data + event.message, '');
|
|
return logs.includes('transformedInput');
|
|
},
|
|
}).then((events) => {
|
|
const logs = events.reduce((data, event) => data + event.message, '');
|
|
expect(logs).to.include(functionName);
|
|
expect(logs).to.include('transformedInput');
|
|
});
|
|
});
|
|
});
|
|
});
|