-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest.js
65 lines (53 loc) · 1.62 KB
/
test.js
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
const Karma = require('karma');
const Logger = require('log-ng');
const Mocha = require('mocha');
const path = require('path');
Logger({logLevel: 'error', logFile: 'APIClient.log'});
const logger = new Logger(path.basename(__filename));
const app = require('./testServer');
const mocha = new Mocha();
function runServerTests(specPath){
logger.info('Starting Mocha tests');
mocha.addFile(specPath);
mocha.run((err) => {
logger.debug(err);
});
}
function runBrowserTests(configPath){
return new Promise((res, rej) => {
logger.info('Starting Karma tests');
const config = Karma.config.parseConfig(configPath, {});
const server = new Karma.Server(config, (exitCode) => {
if(exitCode === 0){
logger.info('Karma tests completed');
res();
}else{
rej(new Error(`Karma tests failed with exit code ${exitCode}`));
}
});
server.on('browser_log', (browser, log, type) => {
logger.info(`Browser log [${type}]: ${log} (${browser})`);
});
server.on('browser_error', (browser, error) => {
logger.error(`Error in browser: ${error} (${browser})`);
});
server.on('run_complete', (browser) => {
logger.debug(`Run complete: ${JSON.stringify(browser, null, 2)}`);
});
server.start();
});
};
const testServer = app.listen(3000, 'localhost', async () => {
try{
logger.info('Test server started');
runServerTests('./server.spec.js');
await runBrowserTests(__dirname + '/karma.conf.js', {});
logger.info('Karma tests completed successfully');
}catch(error){
logger.error('Error running Karma tests:', error);
}finally{
testServer.close(() => {
logger.info('Test server closed');
});
}
});