@applitools/core 4.61.0 → 4.61.1-debug.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/CHANGELOG.md +94 -0
- package/dist/classic/utils/extract-default-environments.js +2 -2
- package/dist/cli/cli.js +160 -0
- package/dist/open-eyes.js +16 -11
- package/dist/ufg/check.js +1 -0
- package/dist/ufg/create-render-target-from-snapshot.js +1 -0
- package/dist/universal/core-server-process.js +31 -0
- package/dist/universal/core-server.js +216 -0
- package/dist/universal/history.js +90 -0
- package/dist/universal/refer.js +67 -0
- package/dist/universal/spec-driver.js +189 -0
- package/dist/universal/types.js +2 -0
- package/dist/universal/ws-server.js +66 -0
- package/dist/utils/extract-git-info.js +738 -140
- package/package.json +15 -12
- package/types/automation/types.d.ts +1 -0
- package/types/cli/cli.d.ts +2 -0
- package/types/universal/core-server-process.d.ts +9 -0
- package/types/universal/core-server.d.ts +18 -0
- package/types/universal/history.d.ts +2 -0
- package/types/universal/refer.d.ts +8 -0
- package/types/universal/spec-driver.d.ts +15 -0
- package/types/universal/types.d.ts +205 -0
- package/types/universal/ws-server.d.ts +15 -0
- package/types/utils/extract-git-info.d.ts +146 -6
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.withHistory = void 0;
|
|
4
|
+
//TODO Design a better history tracker
|
|
5
|
+
function withHistory(socket) {
|
|
6
|
+
const history = {
|
|
7
|
+
managers: new Map(),
|
|
8
|
+
eyes: new Map(),
|
|
9
|
+
startedAt: new Date().toISOString(),
|
|
10
|
+
unknownEvents: [],
|
|
11
|
+
};
|
|
12
|
+
const originalCommand = socket.command;
|
|
13
|
+
socket.command = function command(name, fn) {
|
|
14
|
+
return originalCommand(name, async (payload) => {
|
|
15
|
+
let result, error;
|
|
16
|
+
try {
|
|
17
|
+
result = await fn(payload);
|
|
18
|
+
return result;
|
|
19
|
+
}
|
|
20
|
+
catch (err) {
|
|
21
|
+
error = err;
|
|
22
|
+
throw error;
|
|
23
|
+
}
|
|
24
|
+
finally {
|
|
25
|
+
if (name === 'Core.makeManager') {
|
|
26
|
+
const managerRef = result;
|
|
27
|
+
history.managers.set(extractRefId(managerRef), { ...payload, manager: result, eyes: [] });
|
|
28
|
+
}
|
|
29
|
+
else if (name.startsWith('EyesManager.')) {
|
|
30
|
+
const managerRef = payload.manager;
|
|
31
|
+
const managerHistory = history.managers.get(extractRefId(managerRef));
|
|
32
|
+
if (managerHistory) {
|
|
33
|
+
if (name === 'EyesManager.openEyes') {
|
|
34
|
+
if (error) {
|
|
35
|
+
managerHistory.eyes.push({ ...payload, error });
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
const eyesRef = result;
|
|
39
|
+
managerHistory.eyes.push(eyesRef);
|
|
40
|
+
history.eyes.set(extractRefId(eyesRef), { ...payload, eyes: eyesRef, commands: [] });
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
else if (name.startsWith('Eyes.')) {
|
|
46
|
+
const eyesRef = payload.eyes;
|
|
47
|
+
const eyesHistory = history.eyes.get(extractRefId(eyesRef));
|
|
48
|
+
if (eyesHistory) {
|
|
49
|
+
if (name === 'Eyes.check') {
|
|
50
|
+
const command = { name, ...payload };
|
|
51
|
+
if (error)
|
|
52
|
+
command.error = error;
|
|
53
|
+
else
|
|
54
|
+
command.result = result;
|
|
55
|
+
eyesHistory.commands.push(command);
|
|
56
|
+
}
|
|
57
|
+
else if (name === 'Eyes.close') {
|
|
58
|
+
eyesHistory.closed = true;
|
|
59
|
+
}
|
|
60
|
+
else if (name === 'Eyes.abort') {
|
|
61
|
+
eyesHistory.aborted = true;
|
|
62
|
+
}
|
|
63
|
+
else if (name === 'Eyes.getResults') {
|
|
64
|
+
eyesHistory.result = error !== null && error !== void 0 ? error : result;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
history.unknownEvents.push({ name, payload });
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
};
|
|
74
|
+
return function getHistory() {
|
|
75
|
+
return {
|
|
76
|
+
managers: Array.from(history.managers.values(), managerMeta => ({
|
|
77
|
+
...managerMeta,
|
|
78
|
+
eyes: managerMeta.eyes.map(eyesRefOrError => {
|
|
79
|
+
return eyesRefOrError instanceof Error ? eyesRefOrError : history.eyes.get(extractRefId(eyesRefOrError));
|
|
80
|
+
}),
|
|
81
|
+
})),
|
|
82
|
+
startedAt: history.startedAt,
|
|
83
|
+
requestedAt: new Date().toISOString(),
|
|
84
|
+
};
|
|
85
|
+
};
|
|
86
|
+
function extractRefId(ref) {
|
|
87
|
+
return ref['applitools-ref-id'];
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
exports.withHistory = withHistory;
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.makeRefer = void 0;
|
|
27
|
+
const utils = __importStar(require("@applitools/utils"));
|
|
28
|
+
const REF_ID = 'applitools-ref-id';
|
|
29
|
+
function makeRefer() {
|
|
30
|
+
const store = new Map();
|
|
31
|
+
const relation = new Map();
|
|
32
|
+
return { isRef, ref, deref, destroy };
|
|
33
|
+
function isRef(ref) {
|
|
34
|
+
return Boolean(ref[REF_ID]);
|
|
35
|
+
}
|
|
36
|
+
function ref(value, parentRef) {
|
|
37
|
+
const ref = utils.general.guid();
|
|
38
|
+
store.set(ref, value);
|
|
39
|
+
if (parentRef) {
|
|
40
|
+
let childRefs = relation.get(parentRef[REF_ID]);
|
|
41
|
+
if (!childRefs) {
|
|
42
|
+
childRefs = new Set();
|
|
43
|
+
relation.set(parentRef[REF_ID], childRefs);
|
|
44
|
+
}
|
|
45
|
+
childRefs.add({ [REF_ID]: ref });
|
|
46
|
+
}
|
|
47
|
+
return { [REF_ID]: ref };
|
|
48
|
+
}
|
|
49
|
+
function deref(ref) {
|
|
50
|
+
if (isRef(ref)) {
|
|
51
|
+
return store.get(ref[REF_ID]);
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
return ref;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
function destroy(ref) {
|
|
58
|
+
if (!isRef(ref))
|
|
59
|
+
return;
|
|
60
|
+
const childRefs = relation.get(ref[REF_ID]);
|
|
61
|
+
if (childRefs) {
|
|
62
|
+
childRefs.forEach(childRef => destroy(childRef));
|
|
63
|
+
}
|
|
64
|
+
store.delete(ref[REF_ID]);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
exports.makeRefer = makeRefer;
|
|
@@ -0,0 +1,189 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.makeSpec = void 0;
|
|
27
|
+
const utils = __importStar(require("@applitools/utils"));
|
|
28
|
+
function makeSpec({ socket, spec, }) {
|
|
29
|
+
const commands = {
|
|
30
|
+
isDriver(driver) {
|
|
31
|
+
return utils.types.has(driver, 'applitools-ref-id');
|
|
32
|
+
},
|
|
33
|
+
isContext(context) {
|
|
34
|
+
return utils.types.has(context, 'applitools-ref-id');
|
|
35
|
+
},
|
|
36
|
+
isElement(element) {
|
|
37
|
+
return utils.types.has(element, ['applitools-ref-id', 'type']) && element.type === 'element';
|
|
38
|
+
},
|
|
39
|
+
isSelector(selector) {
|
|
40
|
+
return ((utils.types.has(selector, ['applitools-ref-id', 'type']) && selector.type === 'selector') ||
|
|
41
|
+
utils.types.isString(selector) ||
|
|
42
|
+
(utils.types.isPlainObject(selector) &&
|
|
43
|
+
utils.types.has(selector, 'selector') &&
|
|
44
|
+
(utils.types.isString(selector.selector) || utils.types.has(selector, 'applitools-ref-id'))));
|
|
45
|
+
},
|
|
46
|
+
async isEqualElements(context, element1, element2) {
|
|
47
|
+
return socket.request('Driver.isEqualElements', { context, element1, element2 });
|
|
48
|
+
},
|
|
49
|
+
isStaleElementError(error) {
|
|
50
|
+
return error === null || error === void 0 ? void 0 : error.isStaleElementError;
|
|
51
|
+
},
|
|
52
|
+
extractContext(driver) {
|
|
53
|
+
return driver.context;
|
|
54
|
+
},
|
|
55
|
+
extractSelector(element) {
|
|
56
|
+
return element.selector;
|
|
57
|
+
},
|
|
58
|
+
async executeScript(context, script, arg) {
|
|
59
|
+
return socket.request('Driver.executeScript', { context, script: script.toString(), arg });
|
|
60
|
+
},
|
|
61
|
+
async findElement(context, selector, parent) {
|
|
62
|
+
return socket.request('Driver.findElement', { context, selector, parent });
|
|
63
|
+
},
|
|
64
|
+
async findElements(context, selector, parent) {
|
|
65
|
+
return socket.request('Driver.findElements', { context, selector, parent });
|
|
66
|
+
},
|
|
67
|
+
async waitForSelector(context, selector, parent, options) {
|
|
68
|
+
return socket.request('Driver.waitForSelector', { context, selector, parent, options });
|
|
69
|
+
},
|
|
70
|
+
async getElementText(context, element) {
|
|
71
|
+
return socket.request('Driver.getElementText', { context, element });
|
|
72
|
+
},
|
|
73
|
+
async setElementText(context, element, text) {
|
|
74
|
+
return socket.request('Driver.setElementText', { context, element, text });
|
|
75
|
+
},
|
|
76
|
+
async getElementRegion(context, element) {
|
|
77
|
+
return socket.request('Driver.getElementRegion', { context, element });
|
|
78
|
+
},
|
|
79
|
+
async getElementAttribute(context, element, attr) {
|
|
80
|
+
return socket.request('Driver.getElementAttribute', { context, element, attr });
|
|
81
|
+
},
|
|
82
|
+
async hover(context, element) {
|
|
83
|
+
return socket.request('Driver.hover', { context, element });
|
|
84
|
+
},
|
|
85
|
+
async click(context, element) {
|
|
86
|
+
return socket.request('Driver.click', { context, element });
|
|
87
|
+
},
|
|
88
|
+
async mainContext(context) {
|
|
89
|
+
return socket.request('Driver.mainContext', { context });
|
|
90
|
+
},
|
|
91
|
+
async parentContext(context) {
|
|
92
|
+
return socket.request('Driver.parentContext', { context });
|
|
93
|
+
},
|
|
94
|
+
async childContext(context, element) {
|
|
95
|
+
return socket.request('Driver.childContext', { context, element });
|
|
96
|
+
},
|
|
97
|
+
async getCapabilities(driver) {
|
|
98
|
+
return socket.request('Driver.getCapabilities', { driver });
|
|
99
|
+
},
|
|
100
|
+
async getDriverInfo(driver) {
|
|
101
|
+
return socket.request('Driver.getDriverInfo', { driver });
|
|
102
|
+
},
|
|
103
|
+
async getWindowSize(driver) {
|
|
104
|
+
return socket.request('Driver.getWindowSize', { driver });
|
|
105
|
+
},
|
|
106
|
+
async setWindowSize(driver, size) {
|
|
107
|
+
return socket.request('Driver.setWindowSize', { driver, size });
|
|
108
|
+
},
|
|
109
|
+
async getViewportSize(driver) {
|
|
110
|
+
return socket.request('Driver.getViewportSize', { driver });
|
|
111
|
+
},
|
|
112
|
+
async setViewportSize(driver, size) {
|
|
113
|
+
return socket.request('Driver.setViewportSize', { driver, size });
|
|
114
|
+
},
|
|
115
|
+
async getSystemBars(driver) {
|
|
116
|
+
return socket.request('Driver.getSystemBars', { driver });
|
|
117
|
+
},
|
|
118
|
+
async getOrientation(driver) {
|
|
119
|
+
return socket.request('Driver.getOrientation', { driver });
|
|
120
|
+
},
|
|
121
|
+
async setOrientation(driver, orientation) {
|
|
122
|
+
return socket.request('Driver.setOrientation', { driver, orientation });
|
|
123
|
+
},
|
|
124
|
+
async getCookies(driver, context) {
|
|
125
|
+
return socket.request('Driver.getCookies', { driver, context });
|
|
126
|
+
},
|
|
127
|
+
async getTitle(driver) {
|
|
128
|
+
return socket.request('Driver.getTitle', { driver });
|
|
129
|
+
},
|
|
130
|
+
async getUrl(driver) {
|
|
131
|
+
return socket.request('Driver.getUrl', { driver });
|
|
132
|
+
},
|
|
133
|
+
async takeScreenshot(driver) {
|
|
134
|
+
return socket.request('Driver.takeScreenshot', { driver });
|
|
135
|
+
},
|
|
136
|
+
async performAction(driver, steps) {
|
|
137
|
+
return socket.request('Driver.performAction', { driver, steps });
|
|
138
|
+
},
|
|
139
|
+
async visit(driver, url) {
|
|
140
|
+
return socket.request('Driver.visit', { driver, url });
|
|
141
|
+
},
|
|
142
|
+
async getCurrentWorld(driver) {
|
|
143
|
+
return socket.request('Driver.getCurrentWorld', { driver });
|
|
144
|
+
},
|
|
145
|
+
async getWorlds(driver) {
|
|
146
|
+
return socket.request('Driver.getWorlds', { driver });
|
|
147
|
+
},
|
|
148
|
+
async switchWorld(driver, name) {
|
|
149
|
+
return socket.request('Driver.switchWorld', { driver, name });
|
|
150
|
+
},
|
|
151
|
+
async reload(driver) {
|
|
152
|
+
return socket.request('Driver.reload', { driver });
|
|
153
|
+
},
|
|
154
|
+
async isUserFunction(ref) {
|
|
155
|
+
return utils.types.has(ref, 'applitools-ref-id');
|
|
156
|
+
},
|
|
157
|
+
async executeUserFunction(userFunction) {
|
|
158
|
+
return socket.request('Driver.executeUserFunction', userFunction);
|
|
159
|
+
},
|
|
160
|
+
async executeBrowserCommands(driver, commands) {
|
|
161
|
+
return socket.request('Driver.executeBrowserCommands', { driver, commands });
|
|
162
|
+
},
|
|
163
|
+
async bringToFront(driver) {
|
|
164
|
+
return socket.request('Driver.bringToFront', { driver });
|
|
165
|
+
},
|
|
166
|
+
};
|
|
167
|
+
// add default commands to spec (if not already there) such as `isUserFunction`
|
|
168
|
+
spec = addDefaultCommands(spec);
|
|
169
|
+
return spec.reduce((spec, name) => {
|
|
170
|
+
return Object.assign(spec, { [name]: commands[name] });
|
|
171
|
+
}, {});
|
|
172
|
+
}
|
|
173
|
+
exports.makeSpec = makeSpec;
|
|
174
|
+
// returns a new clone of the spec commands array with additional commands universal can support even if the spec doesn't
|
|
175
|
+
function addDefaultCommands(spec) {
|
|
176
|
+
const defaultCommands = [
|
|
177
|
+
{
|
|
178
|
+
command: 'isUserFunction',
|
|
179
|
+
dependsOn: ['executeUserFunction'],
|
|
180
|
+
},
|
|
181
|
+
];
|
|
182
|
+
const commands = spec.slice();
|
|
183
|
+
defaultCommands.forEach(({ command, dependsOn }) => {
|
|
184
|
+
if (!commands.includes(command) && dependsOn.every(dep => commands.includes(dep))) {
|
|
185
|
+
commands.push(command);
|
|
186
|
+
}
|
|
187
|
+
});
|
|
188
|
+
return commands;
|
|
189
|
+
}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.makeServer = void 0;
|
|
4
|
+
const http_1 = require("http");
|
|
5
|
+
const https_1 = require("https");
|
|
6
|
+
const ws_1 = require("ws");
|
|
7
|
+
const { name, version } = require('../../package.json');
|
|
8
|
+
const TOKEN_HEADER = 'x-eyes-universal-token';
|
|
9
|
+
const TOKEN = `${name}@${version}`;
|
|
10
|
+
async function makeServer(options = {}, logger) {
|
|
11
|
+
const { port = 21077, singleton = true, debug = false, portResolutionMode = 'next', cert, key } = options;
|
|
12
|
+
const secure = Boolean(cert && key);
|
|
13
|
+
const http = secure ? new https_1.Server({ cert, key }) : new http_1.Server();
|
|
14
|
+
http.on('request', (request, response) => {
|
|
15
|
+
if (request.url === '/handshake') {
|
|
16
|
+
const token = debug ? request.headers[TOKEN_HEADER] : TOKEN;
|
|
17
|
+
if (request.headers[TOKEN_HEADER] === token) {
|
|
18
|
+
response.writeHead(200, { [TOKEN_HEADER]: token });
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
response.writeHead(400);
|
|
22
|
+
}
|
|
23
|
+
response.end();
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
const hostName = process.env.APPLITOOLS_UNIVERSAL_HOST_NAME || 'localhost';
|
|
27
|
+
http.listen(port, hostName);
|
|
28
|
+
return new Promise((resolve, reject) => {
|
|
29
|
+
http.on('listening', () => {
|
|
30
|
+
const ws = new ws_1.Server({ server: http, path: '/eyes', maxPayload: 256 * 1024 * 1024 });
|
|
31
|
+
ws.on('close', () => {
|
|
32
|
+
logger.log('Core universal server is closed');
|
|
33
|
+
http.close();
|
|
34
|
+
});
|
|
35
|
+
ws.on('error', err => {
|
|
36
|
+
logger.log('Core universal server error', err);
|
|
37
|
+
});
|
|
38
|
+
resolve({ server: ws, port: http.address().port });
|
|
39
|
+
});
|
|
40
|
+
http.on('error', async (err) => {
|
|
41
|
+
if (portResolutionMode !== 'lazy' && err.code === 'EADDRINUSE') {
|
|
42
|
+
if (singleton && (await isHandshakable({ port, secure }))) {
|
|
43
|
+
return resolve({ port });
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
return resolve(await makeServer({ ...options, port: portResolutionMode === 'next' ? port + 1 : 0 }, logger));
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
reject(err);
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
exports.makeServer = makeServer;
|
|
54
|
+
async function isHandshakable({ port, secure }) {
|
|
55
|
+
const request = secure ? https_1.request : http_1.request;
|
|
56
|
+
return new Promise(resolve => {
|
|
57
|
+
const handshake = request(`${secure ? 'https' : 'http'}://localhost:${port}/handshake`, {
|
|
58
|
+
headers: { [TOKEN_HEADER]: TOKEN },
|
|
59
|
+
});
|
|
60
|
+
handshake.on('response', ({ statusCode, headers }) => {
|
|
61
|
+
resolve(statusCode === 200 && headers[TOKEN_HEADER] === TOKEN);
|
|
62
|
+
});
|
|
63
|
+
handshake.on('error', () => resolve(false));
|
|
64
|
+
handshake.end();
|
|
65
|
+
});
|
|
66
|
+
}
|