-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathindex.test.js
More file actions
128 lines (103 loc) · 3.42 KB
/
index.test.js
File metadata and controls
128 lines (103 loc) · 3.42 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
import {promises as fs} from 'node:fs';
import {chromium} from 'playwright';
import {shouldFail} from './utils.js';
import {
describe, test, expect, vi, beforeEach, afterEach,
} from 'vitest';
vi.mock('playwright', () => ({
chromium: {
launch: vi.fn().mockResolvedValue({
newPage: vi.fn().mockResolvedValue({
on: vi.fn(),
goto: vi.fn(),
waitForTimeout: vi.fn(),
}),
close: vi.fn(),
}),
},
}));
vi.mock('node:fs', () => ({
promises: {
writeFile: vi.fn(),
},
}));
vi.mock('./utils.js', () => ({
filterMessage: vi.fn((level, message) => message),
shouldCapture: vi.fn(() => true),
shouldFail: vi.fn(() => false),
logLevels: ['verbose', 'info', 'warning', 'error'],
}));
describe('index.js', async () => {
let page;
let browser;
beforeEach(async () => {
browser = await chromium.launch();
page = await browser.newPage();
});
afterEach(() => {
vi.clearAllMocks();
vi.resetModules();
});
test('should capture console messages and write to file', async () => {
const consoleMessages = new Map([
['info', ['Test message']],
]);
page.on.mockImplementation((event, callback) => {
if (event === 'console') {
callback({type: () => 'log', text: () => 'Test message'});
}
});
await import('./index.js');
expect(page.goto).toHaveBeenCalled();
expect(page.waitForTimeout).toHaveBeenCalled();
expect(fs.writeFile).toHaveBeenCalledWith('console_output.json', JSON.stringify(Object.fromEntries(consoleMessages), null, 2));
});
test('should handle different log levels', async () => {
const consoleMessages = new Map([
['error', ['Error message']],
]);
page.on.mockImplementation((event, callback) => {
if (event === 'console') {
callback({type: () => 'error', text: () => 'Error message'});
}
});
await import('./index.js');
expect(fs.writeFile).toHaveBeenCalledWith('console_output.json', JSON.stringify(Object.fromEntries(consoleMessages), null, 2));
});
test('should not capture empty console messages', async () => {
const consoleMessages = new Map([
['info', ['only one message should be there']],
]);
page.on.mockImplementation((event, callback) => {
if (event === 'console') {
callback({type: () => 'log', text: () => 'only one message should be there'});
callback({type: () => 'log', text: () => ''});
callback({type: () => 'log', text: () => ''});
callback({type: () => 'log', text: () => ''});
callback({type: () => 'log', text: () => ''});
callback({type: () => 'log', text: () => ''});
}
});
await import('./index.js');
expect(fs.writeFile).toHaveBeenCalledWith('console_output.json', JSON.stringify(Object.fromEntries(consoleMessages), null, 2));
});
test('should set shouldFailAction based on log level', async () => {
vi.mocked(shouldFail).mockImplementation(level => level === 'error');
page.on.mockImplementation((event, callback) => {
if (event === 'console') {
callback({type: () => 'error', text: () => 'Error message'});
}
});
await import('./index.js');
expect(fs.writeFile).toHaveBeenCalled();
expect(process.env.SHOULD_FAIL_ACTION).toBe('true');
});
test('should handle different environment variables', async () => {
process.env.PORT = '3000';
process.env.WAIT_TIME = '1000';
process.env.WEBAPP_URL = 'http://example.com';
await import('./index.js');
expect(page.goto).toHaveBeenCalledWith('http://example.com:3000');
expect(page.waitForTimeout).toHaveBeenCalledWith(1000);
});
});