-
Notifications
You must be signed in to change notification settings - Fork 399
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
todos, add view routing unit tests, expose a createDummyViewClosed ar…
…gs test helper.
- Loading branch information
Filip Maj
committed
Sep 19, 2024
1 parent
1c8fa6c
commit cbfa00c
Showing
5 changed files
with
150 additions
and
44 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,101 @@ | ||
import sinon, { type SinonSpy } from 'sinon'; | ||
import { | ||
FakeReceiver, | ||
type Override, | ||
createFakeLogger, | ||
createDummyViewSubmissionMiddlewareArgs, | ||
createDummyViewClosedMiddlewareArgs, | ||
importApp, | ||
mergeOverrides, | ||
noopMiddleware, | ||
withConversationContext, | ||
withMemoryStore, | ||
withNoopAppMetadata, | ||
withNoopWebClient, | ||
} from '../helpers'; | ||
import type App from '../../../src/App'; | ||
|
||
function buildOverrides(secondOverrides: Override[]): Override { | ||
return mergeOverrides( | ||
withNoopAppMetadata(), | ||
withNoopWebClient(), | ||
...secondOverrides, | ||
withMemoryStore(sinon.fake()), | ||
withConversationContext(sinon.fake.returns(noopMiddleware)), | ||
); | ||
} | ||
|
||
describe('App view() routing', () => { | ||
let fakeReceiver: FakeReceiver; | ||
let fakeHandler: SinonSpy; | ||
const fakeLogger = createFakeLogger(); | ||
let dummyAuthorizationResult: { botToken: string; botId: string }; | ||
let MockApp: Awaited<ReturnType<typeof importApp>>; | ||
let app: App; | ||
|
||
beforeEach(async () => { | ||
fakeLogger.error.reset(); | ||
fakeReceiver = new FakeReceiver(); | ||
fakeHandler = sinon.fake(); | ||
dummyAuthorizationResult = { botToken: '', botId: '' }; | ||
MockApp = await importApp(buildOverrides([])); | ||
app = new MockApp({ | ||
logger: fakeLogger, | ||
receiver: fakeReceiver, | ||
authorize: sinon.fake.resolves(dummyAuthorizationResult), | ||
}); | ||
}); | ||
|
||
it('should throw if provided a constraint with unknown view constraint keys', async () => { | ||
// @ts-ignore providing known invalid view constraint parameter | ||
app.view({ id: 'boom' }, fakeHandler); | ||
sinon.assert.calledWithMatch(fakeLogger.error, 'unknown constraint keys'); | ||
}); | ||
describe('for view submission events', () => { | ||
it('should route a view submission event to a handler registered with `view(string)` that matches the callback ID', async () => { | ||
app.view('my_id', fakeHandler); | ||
await fakeReceiver.sendEvent({ | ||
...createDummyViewSubmissionMiddlewareArgs({ callback_id: 'my_id' }), | ||
}); | ||
sinon.assert.called(fakeHandler); | ||
}); | ||
it('should route a view submission event to a handler registered with `view(RegExp)` that matches the callback ID', async () => { | ||
app.view(/my_action/, fakeHandler); | ||
await fakeReceiver.sendEvent({ | ||
...createDummyViewSubmissionMiddlewareArgs({ callback_id: 'my_action' }), | ||
}); | ||
sinon.assert.called(fakeHandler); | ||
}); | ||
it('should route a view submission event to a handler registered with `view({callback_id})` that matches callback ID', async () => { | ||
app.view({ callback_id: 'my_id' }, fakeHandler); | ||
await fakeReceiver.sendEvent({ | ||
...createDummyViewSubmissionMiddlewareArgs({ callback_id: 'my_id' }), | ||
}); | ||
sinon.assert.called(fakeHandler); | ||
}); | ||
it('should route a view submission event to a handler registered with `view({type:view_submission})`', async () => { | ||
app.view({ type: 'view_submission' }, fakeHandler); | ||
await fakeReceiver.sendEvent({ | ||
...createDummyViewSubmissionMiddlewareArgs(), | ||
}); | ||
sinon.assert.called(fakeHandler); | ||
}); | ||
}); | ||
|
||
describe('for view closed events', () => { | ||
it('should route a view closed event to a handler registered with `view({callback_id, type:view_closed})` that matches callback ID', async () => { | ||
app.view({ callback_id: 'my_id', type: 'view_closed' }, fakeHandler); | ||
await fakeReceiver.sendEvent({ | ||
...createDummyViewClosedMiddlewareArgs({ callback_id: 'my_id', type: 'view_closed' }), | ||
}); | ||
sinon.assert.called(fakeHandler); | ||
}); | ||
it('should route a view closed event to a handler registered with `view({type:view_closed})`', async () => { | ||
app.view({ type: 'view_closed' }, fakeHandler); | ||
await fakeReceiver.sendEvent({ | ||
...createDummyViewClosedMiddlewareArgs(), | ||
}); | ||
sinon.assert.called(fakeHandler); | ||
}); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters