patchright-core 1.49.2 → 1.50.1
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/ThirdPartyNotices.txt +380 -12
- package/bin/reinstall_msedge_beta_linux.sh +6 -0
- package/bin/reinstall_msedge_dev_linux.sh +6 -0
- package/bin/reinstall_msedge_stable_linux.sh +6 -0
- package/browsers.json +17 -16
- package/lib/androidServerImpl.js +1 -1
- package/lib/cli/program.js +6 -30
- package/lib/client/channelOwner.js +35 -55
- package/lib/client/clientInstrumentation.js +2 -0
- package/lib/client/connection.js +3 -3
- package/lib/client/network.js +3 -1
- package/lib/client/waiter.js +1 -1
- package/lib/generated/consoleApiSource.js +1 -1
- package/lib/generated/injectedScriptSource.js +1 -1
- package/lib/generated/pollingRecorderSource.js +1 -1
- package/lib/inProcessFactory.js +2 -0
- package/lib/protocol/debug.js +1 -1
- package/lib/protocol/validator.js +2 -2
- package/lib/remote/playwrightConnection.js +4 -3
- package/lib/remote/playwrightServer.js +2 -1
- package/lib/server/bidi/bidiBrowser.js +9 -6
- package/lib/server/bidi/bidiExecutionContext.js +20 -1
- package/lib/server/bidi/bidiInput.js +7 -5
- package/lib/server/bidi/bidiNetworkManager.js +8 -9
- package/lib/server/bidi/bidiPage.js +9 -20
- package/lib/server/bidi/third_party/bidiKeyboard.js +9 -7
- package/lib/server/browserContext.js +24 -16
- package/lib/server/chromium/crBrowser.js +10 -10
- package/lib/server/chromium/crExecutionContext.js +1 -5
- package/lib/server/chromium/crInput.js +15 -4
- package/lib/server/chromium/crPage.js +17 -31
- package/lib/server/codegen/csharp.js +12 -2
- package/lib/server/codegen/java.js +14 -3
- package/lib/server/codegen/javascript.js +10 -2
- package/lib/server/codegen/jsonl.js +1 -1
- package/lib/server/codegen/python.js +5 -4
- package/lib/server/debugController.js +15 -40
- package/lib/server/debugger.js +1 -1
- package/lib/server/deviceDescriptorsSource.json +50 -50
- package/lib/server/dispatchers/browserContextDispatcher.js +2 -13
- package/lib/server/dispatchers/debugControllerDispatcher.js +4 -2
- package/lib/server/dispatchers/frameDispatcher.js +3 -2
- package/lib/server/dispatchers/pageDispatcher.js +1 -1
- package/lib/server/dispatchers/webSocketRouteDispatcher.js +10 -11
- package/lib/server/dom.js +7 -2
- package/lib/server/fetch.js +14 -20
- package/lib/server/firefox/ffBrowser.js +9 -7
- package/lib/server/firefox/ffInput.js +15 -4
- package/lib/server/firefox/ffPage.js +13 -28
- package/lib/server/frames.js +25 -30
- package/lib/server/har/harTracer.js +1 -1
- package/lib/server/input.js +2 -3
- package/lib/server/network.js +2 -2
- package/lib/server/page.js +23 -16
- package/lib/server/recorder/chat.js +177 -0
- package/lib/server/recorder/contextRecorder.js +6 -15
- package/lib/server/recorder/recorderApp.js +1 -1
- package/lib/server/recorder/recorderCollection.js +5 -17
- package/lib/server/recorder/recorderRunner.js +7 -3
- package/lib/server/recorder/recorderUtils.js +5 -29
- package/lib/server/recorder.js +12 -9
- package/lib/server/registry/browserFetcher.js +1 -1
- package/lib/server/registry/dependencies.js +5 -5
- package/lib/server/registry/index.js +118 -5
- package/lib/server/registry/nativeDeps.js +7 -4
- package/lib/server/socksClientCertificatesInterceptor.js +1 -1
- package/lib/server/trace/recorder/snapshotterInjected.js +12 -5
- package/lib/server/trace/viewer/traceViewer.js +6 -1
- package/lib/server/transport.js +1 -0
- package/lib/server/webkit/webkit.js +1 -1
- package/lib/server/webkit/wkBrowser.js +6 -6
- package/lib/server/webkit/wkExecutionContext.js +1 -0
- package/lib/server/webkit/wkInput.js +15 -5
- package/lib/server/webkit/wkPage.js +7 -25
- package/lib/utils/comparators.js +16 -10
- package/lib/utils/debugLogger.js +3 -1
- package/lib/utils/hostPlatform.js +14 -8
- package/lib/utils/httpServer.js +0 -4
- package/lib/utils/isomorphic/ariaSnapshot.js +176 -52
- package/lib/utils/isomorphic/cssParser.js +4 -4
- package/lib/utils/isomorphic/locatorGenerators.js +2 -2
- package/lib/utils/isomorphic/locatorParser.js +18 -12
- package/lib/utils/isomorphic/urlMatch.js +2 -4
- package/lib/utils/network.js +1 -1
- package/lib/utils/processLauncher.js +1 -1
- package/lib/utils/wsServer.js +1 -0
- package/lib/utils/zones.js +18 -20
- package/lib/utilsBundleImpl/index.js +104 -104
- package/lib/vite/htmlReport/index.html +14 -14
- package/lib/vite/{traceViewer/assets/codeMirrorModule-VZNWuWvU.js → recorder/assets/codeMirrorModule-CNAqJrkA.js} +1 -1
- package/lib/vite/recorder/assets/{index-CqeZmzx8.js → index-DGS0JLxS.js} +78 -78
- package/lib/vite/recorder/assets/{index-iA1aAGZg.css → index-eHBmevrY.css} +1 -1
- package/lib/vite/recorder/index.html +2 -2
- package/lib/vite/{recorder/assets/codeMirrorModule-DUzBrnvO.js → traceViewer/assets/codeMirrorModule-D55P_UuL.js} +10 -10
- package/lib/vite/traceViewer/assets/defaultSettingsView-B-uNoFsX.js +243 -0
- package/lib/vite/traceViewer/defaultSettingsView.2xeEXCXv.css +1 -0
- package/lib/vite/traceViewer/index.BfvuujqP.js +2 -0
- package/lib/vite/traceViewer/index.html +4 -7
- package/lib/vite/traceViewer/sw.bundle.js +3 -3
- package/lib/vite/traceViewer/{uiMode.voC1ZiOQ.css → uiMode.BatfzHMG.css} +1 -1
- package/lib/vite/traceViewer/uiMode.CStJu6jo.js +5 -0
- package/lib/vite/traceViewer/uiMode.html +4 -7
- package/package.json +1 -1
- package/types/protocol.d.ts +269 -20
- package/types/types.d.ts +69 -30
- package/bin/PrintDeps.exe +0 -0
- package/bin/README.md +0 -2
- package/lib/server/ariaSnapshot.js +0 -33
- package/lib/server/recorder/recorderInTraceViewer.js +0 -144
- package/lib/utils/isomorphic/recorderUtils.js +0 -227
- package/lib/vite/traceViewer/assets/inspectorTab-BV-Uf3j9.js +0 -68
- package/lib/vite/traceViewer/assets/testServerConnection-DeE2kSzz.js +0 -1
- package/lib/vite/traceViewer/assets/workbench-B4WPcYi9.js +0 -9
- package/lib/vite/traceViewer/embedded.BLPSqdbm.js +0 -2
- package/lib/vite/traceViewer/embedded.html +0 -18
- package/lib/vite/traceViewer/embedded.w7WN2u1R.css +0 -1
- package/lib/vite/traceViewer/index.BGZfFXXF.js +0 -2
- package/lib/vite/traceViewer/inspectorTab.DEOUW62d.css +0 -1
- package/lib/vite/traceViewer/recorder.B_SY1GJM.css +0 -0
- package/lib/vite/traceViewer/recorder.eWs2vuTG.js +0 -2
- package/lib/vite/traceViewer/recorder.html +0 -17
- package/lib/vite/traceViewer/uiMode.CW2d9h0S.js +0 -5
- package/lib/vite/traceViewer/workbench.C-zR9ysA.css +0 -1
- /package/lib/vite/recorder/assets/{codeMirrorModule-ez37Vkbh.css → codeMirrorModule-C3UTv-Ge.css} +0 -0
- /package/lib/vite/traceViewer/assets/{xtermModule-BeNbaIVa.js → xtermModule-c-SNdYZy.js} +0 -0
- /package/lib/vite/traceViewer/{codeMirrorModule.ez37Vkbh.css → codeMirrorModule.C3UTv-Ge.css} +0 -0
- /package/lib/vite/traceViewer/{index.CrbWWHbf.css → index.CFOW-Ezb.css} +0 -0
- /package/lib/vite/traceViewer/{xtermModule.DSXBckUd.css → xtermModule.Beg8tuEN.css} +0 -0
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.Chat = void 0;
|
|
7
|
+
exports.asString = asString;
|
|
8
|
+
var _transport = require("../transport");
|
|
9
|
+
/**
|
|
10
|
+
* Copyright (c) Microsoft Corporation.
|
|
11
|
+
*
|
|
12
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
13
|
+
* you may not use this file except in compliance with the License.
|
|
14
|
+
* You may obtain a copy of the License at
|
|
15
|
+
*
|
|
16
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
17
|
+
*
|
|
18
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
19
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
20
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
21
|
+
* See the License for the specific language governing permissions and
|
|
22
|
+
* limitations under the License.
|
|
23
|
+
*/
|
|
24
|
+
|
|
25
|
+
class Chat {
|
|
26
|
+
constructor(wsEndpoint) {
|
|
27
|
+
this._history = [];
|
|
28
|
+
this._connectionPromise = void 0;
|
|
29
|
+
this._chatSinks = new Map();
|
|
30
|
+
this._wsEndpoint = void 0;
|
|
31
|
+
this._wsEndpoint = wsEndpoint;
|
|
32
|
+
}
|
|
33
|
+
clearHistory() {
|
|
34
|
+
this._history = [];
|
|
35
|
+
}
|
|
36
|
+
async post(prompt) {
|
|
37
|
+
await this._append('user', prompt);
|
|
38
|
+
let text = await asString(await this._post());
|
|
39
|
+
if (text.startsWith('```json') && text.endsWith('```')) text = text.substring('```json'.length, text.length - '```'.length);
|
|
40
|
+
for (let i = 0; i < 3; ++i) {
|
|
41
|
+
try {
|
|
42
|
+
return JSON.parse(text);
|
|
43
|
+
} catch (e) {
|
|
44
|
+
await this._append('user', String(e));
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
throw new Error('Failed to parse response: ' + text);
|
|
48
|
+
}
|
|
49
|
+
async _append(user, content) {
|
|
50
|
+
this._history.push({
|
|
51
|
+
user,
|
|
52
|
+
content
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
async _connection() {
|
|
56
|
+
if (!this._connectionPromise) {
|
|
57
|
+
this._connectionPromise = _transport.WebSocketTransport.connect(undefined, this._wsEndpoint).then(transport => {
|
|
58
|
+
return new Connection(transport, (method, params) => this._dispatchEvent(method, params), () => {});
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
return this._connectionPromise;
|
|
62
|
+
}
|
|
63
|
+
_dispatchEvent(method, params) {
|
|
64
|
+
if (method === 'chatChunk') {
|
|
65
|
+
const {
|
|
66
|
+
chatId,
|
|
67
|
+
chunk
|
|
68
|
+
} = params;
|
|
69
|
+
const chunkSink = this._chatSinks.get(chatId);
|
|
70
|
+
chunkSink(chunk);
|
|
71
|
+
if (!chunk) this._chatSinks.delete(chatId);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
async _post() {
|
|
75
|
+
const connection = await this._connection();
|
|
76
|
+
const result = await connection.send('chat', {
|
|
77
|
+
history: this._history
|
|
78
|
+
});
|
|
79
|
+
const {
|
|
80
|
+
chatId
|
|
81
|
+
} = result;
|
|
82
|
+
const {
|
|
83
|
+
iterable,
|
|
84
|
+
addChunk
|
|
85
|
+
} = iterablePump();
|
|
86
|
+
this._chatSinks.set(chatId, addChunk);
|
|
87
|
+
return iterable;
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
exports.Chat = Chat;
|
|
91
|
+
async function asString(stream) {
|
|
92
|
+
let result = '';
|
|
93
|
+
for await (const chunk of stream) result += chunk;
|
|
94
|
+
return result;
|
|
95
|
+
}
|
|
96
|
+
function iterablePump() {
|
|
97
|
+
let controller;
|
|
98
|
+
const stream = new ReadableStream({
|
|
99
|
+
start: c => controller = c
|
|
100
|
+
});
|
|
101
|
+
const iterable = async function* () {
|
|
102
|
+
const reader = stream.getReader();
|
|
103
|
+
while (true) {
|
|
104
|
+
const {
|
|
105
|
+
done,
|
|
106
|
+
value
|
|
107
|
+
} = await reader.read();
|
|
108
|
+
if (done) break;
|
|
109
|
+
yield value;
|
|
110
|
+
}
|
|
111
|
+
}();
|
|
112
|
+
return {
|
|
113
|
+
iterable,
|
|
114
|
+
addChunk: chunk => {
|
|
115
|
+
if (chunk) controller.enqueue(chunk);else controller.close();
|
|
116
|
+
}
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
class Connection {
|
|
120
|
+
constructor(transport, onEvent, onClose) {
|
|
121
|
+
this._transport = void 0;
|
|
122
|
+
this._lastId = 0;
|
|
123
|
+
this._closed = false;
|
|
124
|
+
this._pending = new Map();
|
|
125
|
+
this._onEvent = void 0;
|
|
126
|
+
this._onClose = void 0;
|
|
127
|
+
this._transport = transport;
|
|
128
|
+
this._onEvent = onEvent;
|
|
129
|
+
this._onClose = onClose;
|
|
130
|
+
this._transport.onmessage = this._dispatchMessage.bind(this);
|
|
131
|
+
this._transport.onclose = this._close.bind(this);
|
|
132
|
+
}
|
|
133
|
+
send(method, params) {
|
|
134
|
+
const id = this._lastId++;
|
|
135
|
+
const message = {
|
|
136
|
+
id,
|
|
137
|
+
method,
|
|
138
|
+
params
|
|
139
|
+
};
|
|
140
|
+
this._transport.send(message);
|
|
141
|
+
return new Promise((resolve, reject) => {
|
|
142
|
+
this._pending.set(id, {
|
|
143
|
+
resolve,
|
|
144
|
+
reject
|
|
145
|
+
});
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
_dispatchMessage(message) {
|
|
149
|
+
if (message.id === undefined) {
|
|
150
|
+
this._onEvent(message.method, message.params);
|
|
151
|
+
return;
|
|
152
|
+
}
|
|
153
|
+
const callback = this._pending.get(message.id);
|
|
154
|
+
this._pending.delete(message.id);
|
|
155
|
+
if (!callback) return;
|
|
156
|
+
if (message.error) {
|
|
157
|
+
callback.reject(new Error(message.error.message));
|
|
158
|
+
return;
|
|
159
|
+
}
|
|
160
|
+
callback.resolve(message.result);
|
|
161
|
+
}
|
|
162
|
+
_close() {
|
|
163
|
+
this._closed = true;
|
|
164
|
+
this._transport.onmessage = undefined;
|
|
165
|
+
this._transport.onclose = undefined;
|
|
166
|
+
for (const {
|
|
167
|
+
reject
|
|
168
|
+
} of this._pending.values()) reject(new Error('Connection closed'));
|
|
169
|
+
this._onClose();
|
|
170
|
+
}
|
|
171
|
+
isClosed() {
|
|
172
|
+
return this._closed;
|
|
173
|
+
}
|
|
174
|
+
close() {
|
|
175
|
+
if (!this._closed) this._transport.close();
|
|
176
|
+
}
|
|
177
|
+
}
|
|
@@ -35,7 +35,7 @@ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e;
|
|
|
35
35
|
*/
|
|
36
36
|
|
|
37
37
|
class ContextRecorder extends _events.EventEmitter {
|
|
38
|
-
constructor(
|
|
38
|
+
constructor(context, params, delegate) {
|
|
39
39
|
super();
|
|
40
40
|
this._collection = void 0;
|
|
41
41
|
this._pageAliases = new Map();
|
|
@@ -49,8 +49,6 @@ class ContextRecorder extends _events.EventEmitter {
|
|
|
49
49
|
this._throttledOutputFile = null;
|
|
50
50
|
this._orderedLanguages = [];
|
|
51
51
|
this._listeners = [];
|
|
52
|
-
this._codegenMode = void 0;
|
|
53
|
-
this._codegenMode = codegenMode;
|
|
54
52
|
this._context = context;
|
|
55
53
|
this._params = params;
|
|
56
54
|
this._delegate = delegate;
|
|
@@ -112,7 +110,7 @@ class ContextRecorder extends _events.EventEmitter {
|
|
|
112
110
|
var _this$_throttledOutpu3;
|
|
113
111
|
(_this$_throttledOutpu3 = this._throttledOutputFile) === null || _this$_throttledOutpu3 === void 0 || _this$_throttledOutpu3.flush();
|
|
114
112
|
}));
|
|
115
|
-
this.setEnabled(
|
|
113
|
+
this.setEnabled(params.mode === 'recording');
|
|
116
114
|
}
|
|
117
115
|
setOutput(codegenId, outputFile) {
|
|
118
116
|
var _this$_collection;
|
|
@@ -145,14 +143,6 @@ class ContextRecorder extends _events.EventEmitter {
|
|
|
145
143
|
}
|
|
146
144
|
setEnabled(enabled) {
|
|
147
145
|
this._collection.setEnabled(enabled);
|
|
148
|
-
if (this._codegenMode === 'trace-events') {
|
|
149
|
-
if (enabled) this._context.tracing.startChunk({
|
|
150
|
-
name: 'trace',
|
|
151
|
-
title: 'trace'
|
|
152
|
-
}).catch(() => {});else this._context.tracing.stopChunk({
|
|
153
|
-
mode: 'discard'
|
|
154
|
-
}).catch(() => {});
|
|
155
|
-
}
|
|
156
146
|
}
|
|
157
147
|
dispose() {
|
|
158
148
|
_utils.eventsHelper.removeEventListeners(this._listeners);
|
|
@@ -198,6 +188,9 @@ class ContextRecorder extends _events.EventEmitter {
|
|
|
198
188
|
for (const page of this._context.pages()) this._onFrameNavigated(page.mainFrame(), page);
|
|
199
189
|
}
|
|
200
190
|
}
|
|
191
|
+
runTask(task) {
|
|
192
|
+
// TODO: implement
|
|
193
|
+
}
|
|
201
194
|
_describeMainFrame(page) {
|
|
202
195
|
return {
|
|
203
196
|
pageAlias: this._pageAliases.get(page),
|
|
@@ -289,9 +282,7 @@ async function generateFrameSelectorInParent(parent, frame) {
|
|
|
289
282
|
return injected.generateSelectorSimple(element);
|
|
290
283
|
}, frameElement);
|
|
291
284
|
return selector;
|
|
292
|
-
} catch (e) {
|
|
293
|
-
return e.toString();
|
|
294
|
-
}
|
|
285
|
+
} catch (e) {}
|
|
295
286
|
}, (0, _utils.monotonicTime)() + 2000);
|
|
296
287
|
if (!result.timedOut && result.result) return result.result;
|
|
297
288
|
if (frame.name()) return `iframe[name=${(0, _utils.quoteCSSAttributeValue)(frame.name())}]`;
|
|
@@ -87,7 +87,7 @@ class RecorderApp extends _events.EventEmitter {
|
|
|
87
87
|
}).catch(() => {});
|
|
88
88
|
});
|
|
89
89
|
const mainFrame = this._page.mainFrame();
|
|
90
|
-
await mainFrame.goto((0, _instrumentation.serverSideCallMetadata)(), 'https://playwright/index.html');
|
|
90
|
+
await mainFrame.goto((0, _instrumentation.serverSideCallMetadata)(), process.env.PW_HMR ? 'http://localhost:44225' : 'https://playwright/index.html');
|
|
91
91
|
}
|
|
92
92
|
static factory(context) {
|
|
93
93
|
return async recorder => {
|
|
@@ -7,7 +7,6 @@ exports.RecorderCollection = void 0;
|
|
|
7
7
|
var _events = require("events");
|
|
8
8
|
var _time = require("../../utils/time");
|
|
9
9
|
var _recorderUtils = require("./recorderUtils");
|
|
10
|
-
var _errors = require("../errors");
|
|
11
10
|
var _recorderRunner = require("./recorderRunner");
|
|
12
11
|
var _debug = require("../../utils/debug");
|
|
13
12
|
/**
|
|
@@ -42,8 +41,8 @@ class RecorderCollection extends _events.EventEmitter {
|
|
|
42
41
|
this._enabled = enabled;
|
|
43
42
|
}
|
|
44
43
|
async performAction(actionInContext) {
|
|
45
|
-
await this._addAction(actionInContext, async
|
|
46
|
-
await (0, _recorderRunner.performAction)(
|
|
44
|
+
await this._addAction(actionInContext, async () => {
|
|
45
|
+
await (0, _recorderRunner.performAction)(this._pageAliases, actionInContext);
|
|
47
46
|
});
|
|
48
47
|
}
|
|
49
48
|
addRecordedAction(actionInContext) {
|
|
@@ -61,21 +60,10 @@ class RecorderCollection extends _events.EventEmitter {
|
|
|
61
60
|
this._fireChange();
|
|
62
61
|
return;
|
|
63
62
|
}
|
|
64
|
-
const {
|
|
65
|
-
callMetadata,
|
|
66
|
-
mainFrame
|
|
67
|
-
} = (0, _recorderUtils.callMetadataForAction)(this._pageAliases, actionInContext);
|
|
68
|
-
await mainFrame.instrumentation.onBeforeCall(mainFrame, callMetadata);
|
|
69
63
|
this._actions.push(actionInContext);
|
|
70
64
|
this._fireChange();
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
actionInContext.endTime = callMetadata.endTime;
|
|
74
|
-
callMetadata.error = error ? (0, _errors.serializeError)(error) : undefined;
|
|
75
|
-
// Do not wait for onAfterCall so that performAction returned immediately after the action.
|
|
76
|
-
mainFrame.instrumentation.onAfterCall(mainFrame, callMetadata).then(() => {
|
|
77
|
-
this._fireChange();
|
|
78
|
-
}).catch(() => {});
|
|
65
|
+
await (callback === null || callback === void 0 ? void 0 : callback().catch());
|
|
66
|
+
actionInContext.endTime = (0, _time.monotonicTime)();
|
|
79
67
|
}
|
|
80
68
|
signal(pageAlias, frame, signal) {
|
|
81
69
|
if (!this._enabled) return;
|
|
@@ -84,7 +72,7 @@ class RecorderCollection extends _events.EventEmitter {
|
|
|
84
72
|
const lastAction = this._actions[this._actions.length - 1];
|
|
85
73
|
const signalThreshold = (0, _debug.isUnderTest)() ? 500 : 5000;
|
|
86
74
|
let generateGoto = false;
|
|
87
|
-
if (!lastAction) generateGoto = true;else if (lastAction.action.name !== 'click' && lastAction.action.name !== 'press') generateGoto = true;else if (timestamp - lastAction.startTime > signalThreshold) generateGoto = true;
|
|
75
|
+
if (!lastAction) generateGoto = true;else if (lastAction.action.name !== 'click' && lastAction.action.name !== 'press' && lastAction.action.name !== 'fill') generateGoto = true;else if (timestamp - lastAction.startTime > signalThreshold) generateGoto = true;
|
|
88
76
|
if (generateGoto) {
|
|
89
77
|
this.addRecordedAction({
|
|
90
78
|
frame: {
|
|
@@ -7,8 +7,8 @@ exports.performAction = performAction;
|
|
|
7
7
|
exports.toClickOptions = toClickOptions;
|
|
8
8
|
var _utils = require("../../utils");
|
|
9
9
|
var _language = require("../codegen/language");
|
|
10
|
+
var _instrumentation = require("../instrumentation");
|
|
10
11
|
var _recorderUtils = require("./recorderUtils");
|
|
11
|
-
var _recorderUtils2 = require("../../utils/isomorphic/recorderUtils");
|
|
12
12
|
/**
|
|
13
13
|
* Copyright (c) Microsoft Corporation.
|
|
14
14
|
*
|
|
@@ -25,7 +25,8 @@ var _recorderUtils2 = require("../../utils/isomorphic/recorderUtils");
|
|
|
25
25
|
* limitations under the License.
|
|
26
26
|
*/
|
|
27
27
|
|
|
28
|
-
async function performAction(
|
|
28
|
+
async function performAction(pageAliases, actionInContext) {
|
|
29
|
+
const callMetadata = (0, _instrumentation.serverSideCallMetadata)();
|
|
29
30
|
const mainFrame = (0, _recorderUtils.mainFrameForAction)(pageAliases, actionInContext);
|
|
30
31
|
const {
|
|
31
32
|
action
|
|
@@ -42,7 +43,7 @@ async function performAction(callMetadata, pageAliases, actionInContext) {
|
|
|
42
43
|
await mainFrame._page.close(callMetadata);
|
|
43
44
|
return;
|
|
44
45
|
}
|
|
45
|
-
const selector = (0,
|
|
46
|
+
const selector = (0, _recorderUtils.buildFullSelector)(actionInContext.frame.framePath, action.selector);
|
|
46
47
|
if (action.name === 'click') {
|
|
47
48
|
const options = toClickOptions(action);
|
|
48
49
|
await mainFrame.click(callMetadata, selector, {
|
|
@@ -105,6 +106,9 @@ async function performAction(callMetadata, pageAliases, actionInContext) {
|
|
|
105
106
|
await mainFrame.expect(callMetadata, selector, {
|
|
106
107
|
selector,
|
|
107
108
|
expression: 'to.be.checked',
|
|
109
|
+
expectedValue: {
|
|
110
|
+
checked: action.checked
|
|
111
|
+
},
|
|
108
112
|
isNot: !action.checked,
|
|
109
113
|
timeout: kActionTimeout
|
|
110
114
|
});
|
|
@@ -3,13 +3,11 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.
|
|
6
|
+
exports.buildFullSelector = buildFullSelector;
|
|
7
7
|
exports.collapseActions = collapseActions;
|
|
8
8
|
exports.frameForAction = frameForAction;
|
|
9
9
|
exports.mainFrameForAction = mainFrameForAction;
|
|
10
10
|
exports.metadataToCallLog = metadataToCallLog;
|
|
11
|
-
var _utils = require("../../utils");
|
|
12
|
-
var _recorderUtils = require("../../utils/isomorphic/recorderUtils");
|
|
13
11
|
/**
|
|
14
12
|
* Copyright (c) Microsoft Corporation.
|
|
15
13
|
*
|
|
@@ -26,6 +24,9 @@ var _recorderUtils = require("../../utils/isomorphic/recorderUtils");
|
|
|
26
24
|
* limitations under the License.
|
|
27
25
|
*/
|
|
28
26
|
|
|
27
|
+
function buildFullSelector(framePath, selector) {
|
|
28
|
+
return [...framePath, selector].join(' >> internal:control=enter-frame >> ');
|
|
29
|
+
}
|
|
29
30
|
function metadataToCallLog(metadata, status) {
|
|
30
31
|
var _metadata$params, _metadata$params2, _metadata$error;
|
|
31
32
|
let title = metadata.apiName || metadata.method;
|
|
@@ -64,36 +65,11 @@ async function frameForAction(pageAliases, actionInContext, action) {
|
|
|
64
65
|
const pageAlias = actionInContext.frame.pageAlias;
|
|
65
66
|
const page = (_find2 = [...pageAliases.entries()].find(([, alias]) => pageAlias === alias)) === null || _find2 === void 0 ? void 0 : _find2[0];
|
|
66
67
|
if (!page) throw new Error('Internal error: page not found');
|
|
67
|
-
const fullSelector =
|
|
68
|
+
const fullSelector = buildFullSelector(actionInContext.frame.framePath, action.selector);
|
|
68
69
|
const result = await page.mainFrame().selectors.resolveFrameForSelector(fullSelector);
|
|
69
70
|
if (!result) throw new Error('Internal error: frame not found');
|
|
70
71
|
return result.frame;
|
|
71
72
|
}
|
|
72
|
-
function callMetadataForAction(pageAliases, actionInContext) {
|
|
73
|
-
const mainFrame = mainFrameForAction(pageAliases, actionInContext);
|
|
74
|
-
const {
|
|
75
|
-
method,
|
|
76
|
-
apiName,
|
|
77
|
-
params
|
|
78
|
-
} = (0, _recorderUtils.traceParamsForAction)(actionInContext);
|
|
79
|
-
const callMetadata = {
|
|
80
|
-
id: `call@${(0, _utils.createGuid)()}`,
|
|
81
|
-
apiName,
|
|
82
|
-
objectId: mainFrame.guid,
|
|
83
|
-
pageId: mainFrame._page.guid,
|
|
84
|
-
frameId: mainFrame.guid,
|
|
85
|
-
startTime: actionInContext.startTime,
|
|
86
|
-
endTime: 0,
|
|
87
|
-
type: 'Frame',
|
|
88
|
-
method,
|
|
89
|
-
params,
|
|
90
|
-
log: []
|
|
91
|
-
};
|
|
92
|
-
return {
|
|
93
|
-
callMetadata,
|
|
94
|
-
mainFrame
|
|
95
|
-
};
|
|
96
|
-
}
|
|
97
73
|
function collapseActions(actions) {
|
|
98
74
|
const result = [];
|
|
99
75
|
for (const action of actions) {
|
package/lib/server/recorder.js
CHANGED
|
@@ -12,7 +12,6 @@ var _browserContext = require("./browserContext");
|
|
|
12
12
|
var _debugger = require("./debugger");
|
|
13
13
|
var _contextRecorder = require("./recorder/contextRecorder");
|
|
14
14
|
var _recorderUtils = require("./recorder/recorderUtils");
|
|
15
|
-
var _recorderUtils2 = require("../utils/isomorphic/recorderUtils");
|
|
16
15
|
var _selectorParser = require("../utils/isomorphic/selectorParser");
|
|
17
16
|
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
18
17
|
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
@@ -36,26 +35,26 @@ const recorderSymbol = Symbol('recorderSymbol');
|
|
|
36
35
|
class Recorder {
|
|
37
36
|
static async showInspector(context, params, recorderAppFactory) {
|
|
38
37
|
if ((0, _utils.isUnderTest)()) params.language = process.env.TEST_INSPECTOR_LANGUAGE;
|
|
39
|
-
return await Recorder.show(
|
|
38
|
+
return await Recorder.show(context, recorderAppFactory, params);
|
|
40
39
|
}
|
|
41
40
|
static showInspectorNoReply(context, recorderAppFactory) {
|
|
42
41
|
Recorder.showInspector(context, {}, recorderAppFactory).catch(() => {});
|
|
43
42
|
}
|
|
44
|
-
static show(
|
|
43
|
+
static show(context, recorderAppFactory, params) {
|
|
45
44
|
let recorderPromise = context[recorderSymbol];
|
|
46
45
|
if (!recorderPromise) {
|
|
47
|
-
recorderPromise = Recorder._create(
|
|
46
|
+
recorderPromise = Recorder._create(context, recorderAppFactory, params);
|
|
48
47
|
context[recorderSymbol] = recorderPromise;
|
|
49
48
|
}
|
|
50
49
|
return recorderPromise;
|
|
51
50
|
}
|
|
52
|
-
static async _create(
|
|
53
|
-
const recorder = new Recorder(
|
|
51
|
+
static async _create(context, recorderAppFactory, params = {}) {
|
|
52
|
+
const recorder = new Recorder(context, params);
|
|
54
53
|
const recorderApp = await recorderAppFactory(recorder);
|
|
55
54
|
await recorder._install(recorderApp);
|
|
56
55
|
return recorder;
|
|
57
56
|
}
|
|
58
|
-
constructor(
|
|
57
|
+
constructor(context, params) {
|
|
59
58
|
this.handleSIGINT = void 0;
|
|
60
59
|
this._context = void 0;
|
|
61
60
|
this._mode = void 0;
|
|
@@ -73,7 +72,7 @@ class Recorder {
|
|
|
73
72
|
this._currentLanguage = void 0;
|
|
74
73
|
this._mode = params.mode || 'none';
|
|
75
74
|
this.handleSIGINT = params.handleSIGINT;
|
|
76
|
-
this._contextRecorder = new _contextRecorder.ContextRecorder(
|
|
75
|
+
this._contextRecorder = new _contextRecorder.ContextRecorder(context, params, {});
|
|
77
76
|
this._context = context;
|
|
78
77
|
this._omitCallTracking = !!params.omitCallTracking;
|
|
79
78
|
this._debugger = context.debugger();
|
|
@@ -121,6 +120,10 @@ class Recorder {
|
|
|
121
120
|
this._contextRecorder.clearScript();
|
|
122
121
|
return;
|
|
123
122
|
}
|
|
123
|
+
if (data.event === 'runTask') {
|
|
124
|
+
this._contextRecorder.runTask(data.params.task);
|
|
125
|
+
return;
|
|
126
|
+
}
|
|
124
127
|
});
|
|
125
128
|
await Promise.all([recorderApp.setMode(this._mode), recorderApp.setPaused(this._debugger.isPaused()), this._pushAllSources()]);
|
|
126
129
|
this._context.once(_browserContext.BrowserContext.Events.Close, () => {
|
|
@@ -165,7 +168,7 @@ class Recorder {
|
|
|
165
168
|
var _this$_recorderApp2;
|
|
166
169
|
const selectorChain = await (0, _contextRecorder.generateFrameSelector)(frame);
|
|
167
170
|
await ((_this$_recorderApp2 = this._recorderApp) === null || _this$_recorderApp2 === void 0 ? void 0 : _this$_recorderApp2.elementPicked({
|
|
168
|
-
selector: (0,
|
|
171
|
+
selector: (0, _recorderUtils.buildFullSelector)(selectorChain, elementInfo.selector),
|
|
169
172
|
ariaSnapshot: elementInfo.ariaSnapshot
|
|
170
173
|
}, true));
|
|
171
174
|
});
|
|
@@ -41,7 +41,7 @@ async function downloadBrowserWithProgressBar(title, browserDirectory, executabl
|
|
|
41
41
|
}
|
|
42
42
|
const zipPath = _path.default.join(_os.default.tmpdir(), downloadFileName);
|
|
43
43
|
try {
|
|
44
|
-
const retryCount =
|
|
44
|
+
const retryCount = 5;
|
|
45
45
|
for (let attempt = 1; attempt <= retryCount; ++attempt) {
|
|
46
46
|
_debugLogger.debugLogger.log('install', `downloading ${title} - attempt #${attempt}`);
|
|
47
47
|
const url = downloadURLs[(attempt - 1) % downloadURLs.length];
|
|
@@ -104,7 +104,7 @@ async function installDependenciesLinux(targets, dryRun) {
|
|
|
104
104
|
for (const target of targets) {
|
|
105
105
|
const info = _nativeDeps.deps[platform];
|
|
106
106
|
if (!info) {
|
|
107
|
-
console.warn(`Cannot install dependencies for ${platform}!`); // eslint-disable-line no-console
|
|
107
|
+
console.warn(`Cannot install dependencies for ${platform} with Playwright ${(0, _userAgent.getPlaywrightVersion)()}!`); // eslint-disable-line no-console
|
|
108
108
|
return;
|
|
109
109
|
}
|
|
110
110
|
libraries.push(...info[target]);
|
|
@@ -132,11 +132,11 @@ async function installDependenciesLinux(targets, dryRun) {
|
|
|
132
132
|
child.on('error', reject);
|
|
133
133
|
});
|
|
134
134
|
}
|
|
135
|
-
async function validateDependenciesWindows(windowsExeAndDllDirectories) {
|
|
135
|
+
async function validateDependenciesWindows(sdkLanguage, windowsExeAndDllDirectories) {
|
|
136
136
|
const directoryPaths = windowsExeAndDllDirectories;
|
|
137
137
|
const lddPaths = [];
|
|
138
138
|
for (const directoryPath of directoryPaths) lddPaths.push(...(await executablesOrSharedLibraries(directoryPath)));
|
|
139
|
-
const allMissingDeps = await Promise.all(lddPaths.map(lddPath => missingFileDependenciesWindows(lddPath)));
|
|
139
|
+
const allMissingDeps = await Promise.all(lddPaths.map(lddPath => missingFileDependenciesWindows(sdkLanguage, lddPath)));
|
|
140
140
|
const missingDeps = new Set();
|
|
141
141
|
for (const deps of allMissingDeps) {
|
|
142
142
|
for (const dep of deps) missingDeps.add(dep);
|
|
@@ -238,8 +238,8 @@ async function executablesOrSharedLibraries(directoryPath) {
|
|
|
238
238
|
}))).filter(Boolean);
|
|
239
239
|
return executablersOrLibraries;
|
|
240
240
|
}
|
|
241
|
-
async function missingFileDependenciesWindows(filePath) {
|
|
242
|
-
const executable =
|
|
241
|
+
async function missingFileDependenciesWindows(sdkLanguage, filePath) {
|
|
242
|
+
const executable = _.registry.findExecutable('winldd').executablePathOrDie(sdkLanguage);
|
|
243
243
|
const dirname = _path.default.dirname(filePath);
|
|
244
244
|
const {
|
|
245
245
|
stdout,
|