oxygen-cli 1.37.8 → 1.38.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/core/OxygenCore.js +8 -2
- package/build/core/OxygenEvents.js +4 -2
- package/build/lib/cli-util.js +26 -6
- package/build/lib/cli.js +12 -2
- package/build/lib/util.js +2 -2
- package/build/model/suite-result.js +2 -1
- package/build/ox_modules/module-web.js +12 -7
- package/build/ox_reporters/reporter-rp.js +376 -0
- package/build/reporter/ReportAggregator.js +110 -43
- package/build/reporter/ReporterBase.js +2 -2
- package/build/reporter/WebSocketReporter.js +136 -0
- package/build/runners/oxygen/index.js +37 -22
- package/package.json +3 -1
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
|
|
8
|
+
require("source-map-support/register");
|
|
9
|
+
|
|
10
|
+
var _socket = require("socket.io");
|
|
11
|
+
|
|
12
|
+
const io = new _socket.Server({
|
|
13
|
+
serveClient: false,
|
|
14
|
+
pingInterval: 10000,
|
|
15
|
+
pingTimeout: 60000,
|
|
16
|
+
maxHttpBufferSize: 256 * 1024 * 1024,
|
|
17
|
+
cookie: true,
|
|
18
|
+
cors: {
|
|
19
|
+
origin: '*'
|
|
20
|
+
},
|
|
21
|
+
transports: ['websocket']
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
class WebSocketReporter {
|
|
25
|
+
constructor(aggregator) {
|
|
26
|
+
this._aggregator = aggregator;
|
|
27
|
+
|
|
28
|
+
this._hookAggregatorEvents();
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
startAndWaitForClient(serverPort) {
|
|
32
|
+
io.listen(serverPort);
|
|
33
|
+
return new Promise((resolve, reject) => {
|
|
34
|
+
this._handleServerEvents(resolve);
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
stop() {
|
|
39
|
+
if (this._socket) {
|
|
40
|
+
io.close();
|
|
41
|
+
this._socket = undefined;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
_handleServerEvents(resolveWait) {
|
|
46
|
+
const _this = this;
|
|
47
|
+
|
|
48
|
+
io.on('connection', socket => {
|
|
49
|
+
_this._handleSocketEvents(socket);
|
|
50
|
+
|
|
51
|
+
resolveWait();
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
_handleSocketEvents(socket) {
|
|
56
|
+
this._socket = socket;
|
|
57
|
+
socket.on('disconnect', reason => {});
|
|
58
|
+
socket.on('error', err => {
|
|
59
|
+
console.error('Error in Socket:', err);
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
_hookAggregatorEvents() {
|
|
64
|
+
this._aggregator.on('runner:start', e => this._handleRunnerStart(e));
|
|
65
|
+
|
|
66
|
+
this._aggregator.on('runner:end', e => this._handleRunnerEnd(e));
|
|
67
|
+
|
|
68
|
+
this._aggregator.on('suite:start', e => this._handleSuiteStart(e));
|
|
69
|
+
|
|
70
|
+
this._aggregator.on('suite:end', e => this._handleSuiteEnd(e));
|
|
71
|
+
|
|
72
|
+
this._aggregator.on('case:start', e => this._handleCaseStart(e));
|
|
73
|
+
|
|
74
|
+
this._aggregator.on('case:end', e => this._handleCaseEnd(e));
|
|
75
|
+
|
|
76
|
+
this._aggregator.on('log', e => this._handleLog(e));
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
_handleRunnerStart(event) {
|
|
80
|
+
var _this$_socket;
|
|
81
|
+
|
|
82
|
+
(_this$_socket = this._socket) === null || _this$_socket === void 0 ? void 0 : _this$_socket.emit('runner:start', event);
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
_handleRunnerEnd(event) {
|
|
86
|
+
var _this$_socket2;
|
|
87
|
+
|
|
88
|
+
(_this$_socket2 = this._socket) === null || _this$_socket2 === void 0 ? void 0 : _this$_socket2.emit('runner:end', event);
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
_handleSuiteStart(event) {
|
|
92
|
+
var _this$_socket3;
|
|
93
|
+
|
|
94
|
+
(_this$_socket3 = this._socket) === null || _this$_socket3 === void 0 ? void 0 : _this$_socket3.emit('suite:start', event);
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
_handleSuiteEnd(event) {
|
|
98
|
+
var _this$_socket4;
|
|
99
|
+
|
|
100
|
+
(_this$_socket4 = this._socket) === null || _this$_socket4 === void 0 ? void 0 : _this$_socket4.emit('suite:end', event);
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
_handleCaseStart(event) {
|
|
104
|
+
var _this$_socket5;
|
|
105
|
+
|
|
106
|
+
(_this$_socket5 = this._socket) === null || _this$_socket5 === void 0 ? void 0 : _this$_socket5.emit('case:start', event);
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
_handleCaseEnd(event) {
|
|
110
|
+
var _this$_socket6;
|
|
111
|
+
|
|
112
|
+
(_this$_socket6 = this._socket) === null || _this$_socket6 === void 0 ? void 0 : _this$_socket6.emit('case:end', event);
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
_handleStepStart(event) {
|
|
116
|
+
var _this$_socket7;
|
|
117
|
+
|
|
118
|
+
(_this$_socket7 = this._socket) === null || _this$_socket7 === void 0 ? void 0 : _this$_socket7.emit('step:start', event);
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
_handleStepEnd(event) {
|
|
122
|
+
var _this$_socket8;
|
|
123
|
+
|
|
124
|
+
(_this$_socket8 = this._socket) === null || _this$_socket8 === void 0 ? void 0 : _this$_socket8.emit('step:end', event);
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
_handleLog(event) {
|
|
128
|
+
var _this$_socket9;
|
|
129
|
+
|
|
130
|
+
(_this$_socket9 = this._socket) === null || _this$_socket9 === void 0 ? void 0 : _this$_socket9.emit('log', event);
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
exports.default = WebSocketReporter;
|
|
136
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/reporter/WebSocketReporter.js"],"names":["io","Server","serveClient","pingInterval","pingTimeout","maxHttpBufferSize","cookie","cors","origin","transports","WebSocketReporter","constructor","aggregator","_aggregator","_hookAggregatorEvents","startAndWaitForClient","serverPort","listen","Promise","resolve","reject","_handleServerEvents","stop","_socket","close","undefined","resolveWait","_this","on","socket","_handleSocketEvents","reason","err","console","error","e","_handleRunnerStart","_handleRunnerEnd","_handleSuiteStart","_handleSuiteEnd","_handleCaseStart","_handleCaseEnd","_handleLog","event","emit","_handleStepStart","_handleStepEnd"],"mappings":"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","sourcesContent":["/*\r\n * Copyright (C) 2015-present CloudBeat Limited\r\n *\r\n * This program is free software: you can redistribute it and/or modify\r\n * it under the terms of the GNU General Public License as published by\r\n * the Free Software Foundation, either version 3 of the License, or\r\n * (at your option) any later version.\r\n */\r\nimport { Server } from 'socket.io';\r\n\r\nconst io = new Server({\r\n    serveClient: false,\r\n    pingInterval: 10000,\r\n    pingTimeout: 60000,\r\n    maxHttpBufferSize: 256 * 1024 * 1024, // 256MB\r\n    cookie: true,\r\n    cors: {\r\n        origin: '*',\r\n    },\r\n    transports: ['websocket'],\r\n});\r\n/*\r\n * WebSocket Reporter\r\n */\r\nexport default class WebSocketReporter {\r\n    constructor(aggregator) {\r\n        this._aggregator = aggregator;\r\n        this._hookAggregatorEvents();\r\n    }\r\n    startAndWaitForClient(serverPort) {\r\n        io.listen(serverPort);\r\n        return new Promise((resolve, reject) => {\r\n            this._handleServerEvents(resolve);\r\n        });\r\n    }\r\n    stop() {\r\n        if (this._socket) {\r\n            io.close();\r\n            this._socket = undefined;\r\n        }\r\n    }\r\n    _handleServerEvents(resolveWait) {\r\n        const _this = this;\r\n        io.on('connection', (socket) => {\r\n            _this._handleSocketEvents(socket);\r\n            resolveWait();\r\n        });\r\n    }\r\n    _handleSocketEvents(socket) {\r\n        this._socket = socket;\r\n        socket.on('disconnect', (reason) => {\r\n        });\r\n        socket.on('error', (err) => {\r\n            console.error('Error in Socket:', err);\r\n        });\r\n    }\r\n    _hookAggregatorEvents() {\r\n        this._aggregator.on('runner:start', e => this._handleRunnerStart(e));\r\n        this._aggregator.on('runner:end', e => this._handleRunnerEnd(e));\r\n        this._aggregator.on('suite:start', e => this._handleSuiteStart(e));\r\n        this._aggregator.on('suite:end', e => this._handleSuiteEnd(e));\r\n        this._aggregator.on('case:start', e => this._handleCaseStart(e));\r\n        this._aggregator.on('case:end', e => this._handleCaseEnd(e));\r\n        this._aggregator.on('log', e => this._handleLog(e));\r\n    }\r\n    _handleRunnerStart(event) {\r\n        this._socket?.emit('runner:start', event);\r\n    }\r\n    _handleRunnerEnd(event) {\r\n        this._socket?.emit('runner:end', event);\r\n    }\r\n    _handleSuiteStart(event) {\r\n        this._socket?.emit('suite:start', event);\r\n    }\r\n    _handleSuiteEnd(event) {\r\n        this._socket?.emit('suite:end', event);\r\n    }\r\n    _handleCaseStart(event) {\r\n        this._socket?.emit('case:start', event);\r\n    }\r\n    _handleCaseEnd(event) {\r\n        this._socket?.emit('case:end', event);\r\n    }\r\n    _handleStepStart(event) {\r\n        this._socket?.emit('step:start', event);\r\n    }\r\n    _handleStepEnd(event) {\r\n        this._socket?.emit('step:end', event);\r\n    }\r\n    _handleLog(event) {\r\n        this._socket?.emit('log', event);\r\n    }\r\n}"]}
|