forked from asyncapi/modelina
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.spec.ts
24 lines (22 loc) · 907 Bytes
/
index.spec.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
const spy = jest.spyOn(global.console, 'log').mockImplementation(() => { return; });
import { generate } from './index';
function timeout(ms: number) {
return new Promise(resolve => setTimeout(resolve, ms));
}
describe('Should be able to render correct enums based on options', () => {
afterAll(() => {
jest.restoreAllMocks();
});
test('and should log expected output to console', async function testIt(): Promise<void> {
// Wait for first call to the `generate` function is over, and we can reliably know the output
if (spy.mock.calls.length !== 6) {
await timeout(50);
return testIt();
}
await generate();
//Generate is called 2 times, so even though we expect 6 console logs we double it
expect(spy.mock.calls.length).toEqual(12);
const generatedContent = spy.mock.calls.slice(6).join('\n');
expect(generatedContent).toMatchSnapshot();
});
});