Skip to content
This repository has been archived by the owner on Apr 17, 2021. It is now read-only.

Commit

Permalink
Update other producer tests to align
Browse files Browse the repository at this point in the history
  • Loading branch information
alistairjcbrown committed Nov 20, 2018
1 parent 3f7adba commit 856b7e9
Show file tree
Hide file tree
Showing 3 changed files with 65 additions and 66 deletions.
82 changes: 40 additions & 42 deletions lambdas/tests/eventbrite/handlers/producer.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ describe("Eventbrite Producer", function() {
getFromWeb.mockImplementation(() => errorResponse());
});

it("returns an error", function(done) {
it("returns an error and no file paths", function(done) {
producer.produce(event, context, function(err, response) {
expect(err).toEqual([{ error: "test error" }]);
expect(response).toBe(null);
Expand Down Expand Up @@ -73,31 +73,30 @@ describe("Eventbrite Producer", function() {
getFromWeb.mockImplementation(() => singleResponse());
});

it("does not return an error and returns message", function(done) {
producer.produce(event, context, function(err, response) {
expect(err).toBe(null);
expect(response).toEqual({ message: ["path/to/new/file.json"] });
done();
});
});

it("makes a request to the API", function(done) {
producer.produce(event, context, function() {
producer.produce(event, context, function(err) {
expect(getFromWeb).toHaveBeenCalledTimes(1);
expect(getFromWeb).toHaveBeenCalledWith(apiCallPage(1));
done();
done(err);
});
});

it("uploads data", function(done) {
producer.produce(event, context, function() {
producer.produce(event, context, function(err) {
expect(uploadTo).toHaveBeenCalledTimes(1);
expect(uploadTo).toHaveBeenCalledWith(
"muxer-produced-events-eventbrite",
expect.any(Function),
{ pagination: { has_more_items: false, page_count: 1 } }
);
done();
done(err);
});
});

it("returns file paths", function(done) {
producer.produce(event, context, function(err, response) {
expect(response).toEqual({ message: ["path/to/new/file.json"] });
done(err);
});
});
});
Expand All @@ -114,32 +113,18 @@ describe("Eventbrite Producer", function() {
.mockReturnValue(finalResponse({ events: [{ name: "Last Event" }] }));
});

it("does not return an error and returns message", function(done) {
producer.produce(event, context, function(err, response) {
expect(err).toBe(null);
expect(response).toEqual({
message: [
"path/to/new/file.json",
"path/to/new/file.json",
"path/to/new/file.json"
]
});
done();
});
});

it("makes a request to the API", function(done) {
producer.produce(event, context, function() {
producer.produce(event, context, function(err) {
expect(getFromWeb).toHaveBeenCalledTimes(3);
expect(getFromWeb).toHaveBeenCalledWith(apiCallPage(1));
expect(getFromWeb).toHaveBeenCalledWith(apiCallPage(2));
expect(getFromWeb).toHaveBeenCalledWith(apiCallPage(3));
done();
done(err);
});
});

it("uploads data", function(done) {
producer.produce(event, context, function() {
producer.produce(event, context, function(err) {
expect(uploadTo).toHaveBeenCalledTimes(3);
expect(uploadTo).toHaveBeenCalledWith(
"muxer-produced-events-eventbrite",
Expand All @@ -165,7 +150,20 @@ describe("Eventbrite Producer", function() {
pagination: { has_more_items: false, page_count: 3 }
}
);
done();
done(err);
});
});

it("returns file paths", function(done) {
producer.produce(event, context, function(err, response) {
expect(response).toEqual({
message: [
"path/to/new/file.json",
"path/to/new/file.json",
"path/to/new/file.json"
]
});
done(err);
});
});
});
Expand All @@ -180,17 +178,6 @@ describe("Eventbrite Producer", function() {
.mockReturnValue(errorResponse({ page: 3 }));
});

it("return the errors", function(done) {
producer.produce(event, context, function(err, response) {
expect(err).toEqual([
{ error: "test error", page: 2 },
{ error: "test error", page: 3 }
]);
expect(response).toBe(null);
done();
});
});

it("makes a request to the API", function(done) {
producer.produce(event, context, function() {
expect(getFromWeb).toHaveBeenCalledTimes(3);
Expand All @@ -207,5 +194,16 @@ describe("Eventbrite Producer", function() {
done();
});
});

it("returns the errors and no file paths", function(done) {
producer.produce(event, context, function(err, response) {
expect(err).toEqual([
{ error: "test error", page: 2 },
{ error: "test error", page: 3 }
]);
expect(response).toBe(null);
done();
});
});
});
});
31 changes: 16 additions & 15 deletions lambdas/tests/farsetlabs/handlers/producer.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,16 +6,18 @@ const { uploadTo } = require(`${prefix}/node_modules/@muxer/lambda-utils`);
const producer = require(`${prefix}/handlers/producer`);

const apicall =
"https://www.googleapis.com/calendar/v3/calendars/farsetlabs.org.uk_srmqnkn373auq51u00s2nijrq8%40group.calendar.google.com/events?maxResults=2500&singleEvents=true&orderBy=startTime&timeMin=2019-11-06T10:30:00.000Z&timeMax=2020-11-06T10:30:00.000Z&key=google-calendar-token-abc123";
"https://www.googleapis.com/calendar/v3/calendars/farsetlabs.org.uk_srmqnkn373auq51u00s2nijrq8%40group.calendar.google.com/events?maxResults=2500&singleEvents=true&orderBy=startTime&timeMin=2018-11-06T10:30:00.000Z&timeMax=2019-11-06T10:30:00.000Z&key=google-calendar-token-abc123";

const event = null;
const context = null;

describe("Farsetlabs Producer", function() {
beforeEach(function() {
const frozenDate = new Date("2018-11-06T10:30:00");
const NativeDate = Date;
global.Date = jest.fn(
input => new NativeDate(input || "2018-11-06T10:30:00")
);
jest.clearAllMocks();
global.Date = jest.fn(() => frozenDate);
uploadTo.mockImplementation(resolved({ key: "path/to/new/file.json" }));
});

Expand All @@ -29,31 +31,30 @@ describe("Farsetlabs Producer", function() {
getFromWeb.mockImplementation(() => resolvedResponse({ items: [] }));
});

it("does not return an error and returns message", function(done) {
producer.produce(event, context, function(err, response) {
expect(err).toBe(null);
expect(response).toEqual({ message: ["path/to/new/file.json"] });
done();
});
});

it("makes a request to the API", function(done) {
producer.produce(event, context, function() {
producer.produce(event, context, function(err) {
expect(getFromWeb).toHaveBeenCalledTimes(1);
expect(getFromWeb).toHaveBeenCalledWith(apicall);
done();
done(err);
});
});

it("uploads data", function(done) {
producer.produce(event, context, function() {
producer.produce(event, context, function(err) {
expect(uploadTo).toHaveBeenCalledTimes(1);
expect(uploadTo).toHaveBeenCalledWith(
"muxer-produced-events-farsetlabs",
expect.any(Function),
{ items: [] }
);
done();
done(err);
});
});

it("returns file paths", function(done) {
producer.produce(event, context, function(err, response) {
expect(response).toEqual({ message: ["path/to/new/file.json"] });
done(err);
});
});
});
Expand Down
18 changes: 9 additions & 9 deletions lambdas/tests/meetupcom/handlers/producer.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -74,14 +74,7 @@ describe("Meetup.com Producer", function() {
});
});

it("does not upload data", function(done) {
producer.produce(event, context, function() {
expect(uploadTo).not.toHaveBeenCalled();
done();
});
});

it("return an error and no file paths", function(done) {
it("returns an error and no file paths", function(done) {
producer.produce(event, context, function(err, response) {
expect(err).toEqual([
{
Expand All @@ -93,6 +86,13 @@ describe("Meetup.com Producer", function() {
done();
});
});

it("does not upload data", function(done) {
producer.produce(event, context, function() {
expect(uploadTo).not.toHaveBeenCalled();
done();
});
});
});

describe("when no groups are returned", function() {
Expand Down Expand Up @@ -180,7 +180,7 @@ describe("Meetup.com Producer", function() {
});
});

it("return the errors and no file paths", function(done) {
it("returns the errors and no file paths", function(done) {
producer.produce(event, context, function(err, response) {
expect(err).toEqual([
[{ code: "auth_fail", message: "Invalid signature" }]
Expand Down

0 comments on commit 856b7e9

Please sign in to comment.