getEvents method name unclear
georgesbiaux opened this issue · 0 comments
georgesbiaux commented
Hi :)
I have used the lib in a use case when several events are sent to EventBridge, I thought that the getEvents method would fetch them all (until the queue was empty). But instead, it only fetched the messages one by one. This was quite confusing since the plural in the name of the method lead me to think it would fetch all the events fired so far. This confusion caused many failure in my test suite, which were difficult to debug.
So, in the end, I implemented a method like so to fetch all events in one function call:
static async getAllEventBridgeMessages(): Promise<EventBridgeMessage[]> {
if (EventBridgeTestUtil.eventBridge === null) {
throw new Error("EventBridgeTestUtil has not been setup");
}
let result: EventBridgeMessage[] = [];
let lastResults: EventBridgeMessage[] = [];
do {
try {
const events = await EventBridgeTestUtil.eventBridge.getEvents();
lastResults = events.Messages;
result = [...result, ...lastResults];
} catch (e) {
lastResults = [];
}
} while (lastResults.length !== 0);
return result;
}
It would be great if getEvents
could be renamed to be clearer, such as getEvent
and if a method getAllEvents
could be implemented :)
Thanks ;)