puppeteer-ruby 0.38.0 → 0.39.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.rubocop.yml +2 -0
- data/CHANGELOG.md +7 -1
- data/docs/api_coverage.md +1 -1
- data/lib/puppeteer/aria_query_handler.rb +3 -3
- data/lib/puppeteer/browser_runner.rb +21 -10
- data/lib/puppeteer/frame_manager.rb +1 -1
- data/lib/puppeteer/launcher/chrome.rb +43 -27
- data/lib/puppeteer/launcher/firefox.rb +255 -225
- data/lib/puppeteer/launcher/launch_options.rb +2 -1
- data/lib/puppeteer/version.rb +1 -1
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: e09022ffac5da45a7c40bca6b612c8a67afece662142675625794b15b89a044b
|
4
|
+
data.tar.gz: 9af45888cfcfaff3bc368facbd1b5fb28572924ccf0c8d33b05ba310894638bb
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 580410458c1e0f2ac6dd8fb678fce42ed5f12ee6a1ff70b90600b6601b945af4342db53f6b98fe73ba249a9d85e3e8d64efb664534f7b1231265dbfbeb2f8e09
|
7
|
+
data.tar.gz: adecd0293ec7b7ade882d9c331b794b4a14e2e52999c164880e7f4b0fa3d723e7bc6b44a238a5ad04c50ad0bfc9c3d5d33e60b50ea40904dc49af1506ce3e72e
|
data/.rubocop.yml
CHANGED
data/CHANGELOG.md
CHANGED
@@ -1,7 +1,13 @@
|
|
1
|
-
### main [[diff](https://github.com/YusukeIwaki/puppeteer-ruby/compare/0.
|
1
|
+
### main [[diff](https://github.com/YusukeIwaki/puppeteer-ruby/compare/0.39.0...main)]
|
2
2
|
|
3
3
|
- xxx
|
4
4
|
|
5
|
+
### 0.39.0 [[diff](https://github.com/YusukeIwaki/puppeteer-ruby/compare/0.38.0...0.39.0)]
|
6
|
+
|
7
|
+
New features:
|
8
|
+
|
9
|
+
- Puppeteer 12.0 functionalities
|
10
|
+
|
5
11
|
### 0.38.0 [[diff](https://github.com/YusukeIwaki/puppeteer-ruby/compare/0.37.4...0.38.0)]
|
6
12
|
|
7
13
|
New features:
|
data/docs/api_coverage.md
CHANGED
@@ -7,10 +7,10 @@ class Puppeteer::AriaQueryHandler
|
|
7
7
|
private def parse_aria_selector(selector)
|
8
8
|
known_attributes = %w(name role)
|
9
9
|
query_options = {}
|
10
|
-
attribute_regexp = /\[\s*(?<attribute>\w+)\s*=\s*"(?<value
|
10
|
+
attribute_regexp = /\[\s*(?<attribute>\w+)\s*=\s*(?<quote>"|')(?<value>\\.|.*?(?=\k<quote>))\k<quote>\s*\]/
|
11
11
|
default_name = selector.gsub(attribute_regexp) do
|
12
12
|
attribute = $1.strip
|
13
|
-
value = $
|
13
|
+
value = $3
|
14
14
|
unless known_attributes.include?(attribute)
|
15
15
|
raise ArgumentError.new("Unkown aria attribute \"#{attribute}\" in selector")
|
16
16
|
end
|
@@ -39,7 +39,7 @@ class Puppeteer::AriaQueryHandler
|
|
39
39
|
def wait_for(dom_world, selector, visible: nil, hidden: nil, timeout: nil)
|
40
40
|
binding_function = Puppeteer::DOMWorld::BindingFunction.new(
|
41
41
|
name: 'ariaQuerySelector',
|
42
|
-
proc: -> (
|
42
|
+
proc: -> (sel) { query_one(dom_world.send(:document), sel) },
|
43
43
|
)
|
44
44
|
dom_world.send(:wait_for_selector_in_page,
|
45
45
|
'(_, selector) => globalThis.ariaQuerySelector(selector)',
|
@@ -4,13 +4,17 @@ require 'timeout'
|
|
4
4
|
|
5
5
|
# https://github.com/puppeteer/puppeteer/blob/master/lib/Launcher.js
|
6
6
|
class Puppeteer::BrowserRunner
|
7
|
+
include Puppeteer::DebugPrint
|
8
|
+
|
7
9
|
# @param {string} executablePath
|
8
10
|
# @param {!Array<string>} processArguments
|
9
11
|
# @param {string=} tempDirectory
|
10
|
-
def initialize(executable_path, process_arguments,
|
12
|
+
def initialize(for_firefox, executable_path, process_arguments, user_data_dir, using_temp_user_data_dir)
|
13
|
+
@for_firefox = for_firefox
|
11
14
|
@executable_path = executable_path
|
12
15
|
@process_arguments = process_arguments
|
13
|
-
@
|
16
|
+
@user_data_dir = user_data_dir
|
17
|
+
@using_temp_user_data_dir = using_temp_user_data_dir
|
14
18
|
@proc = nil
|
15
19
|
@connection = nil
|
16
20
|
@closed = true
|
@@ -90,8 +94,8 @@ class Puppeteer::BrowserRunner
|
|
90
94
|
@process_closing = -> {
|
91
95
|
@proc.dispose
|
92
96
|
@closed = true
|
93
|
-
if @
|
94
|
-
FileUtils.rm_rf(@
|
97
|
+
if @using_temp_user_data_dir
|
98
|
+
FileUtils.rm_rf(@user_data_dir)
|
95
99
|
end
|
96
100
|
}
|
97
101
|
at_exit do
|
@@ -122,7 +126,7 @@ class Puppeteer::BrowserRunner
|
|
122
126
|
def close
|
123
127
|
return if @closed
|
124
128
|
|
125
|
-
if @
|
129
|
+
if @using_temp_user_data_dir && !@for_firefox
|
126
130
|
kill
|
127
131
|
elsif @connection
|
128
132
|
begin
|
@@ -137,11 +141,18 @@ class Puppeteer::BrowserRunner
|
|
137
141
|
|
138
142
|
# @return {Promise}
|
139
143
|
def kill
|
140
|
-
if
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
|
144
|
+
# If the process failed to launch (for example if the browser executable path
|
145
|
+
# is invalid), then the process does not get a pid assigned. A call to
|
146
|
+
# `proc.kill` would error, as the `pid` to-be-killed can not be found.
|
147
|
+
@proc&.kill
|
148
|
+
|
149
|
+
# Attempt to remove temporary profile directory to avoid littering.
|
150
|
+
begin
|
151
|
+
if @using_temp_user_data_dir
|
152
|
+
FileUtils.rm_rf(@temp_directory)
|
153
|
+
end
|
154
|
+
rescue => err
|
155
|
+
debug_puts(err)
|
145
156
|
end
|
146
157
|
end
|
147
158
|
|
@@ -382,7 +382,7 @@ class Puppeteer::FrameManager
|
|
382
382
|
@isolated_worlds << context_payload['name']
|
383
383
|
end
|
384
384
|
|
385
|
-
context = Puppeteer::ExecutionContext.new(frame
|
385
|
+
context = Puppeteer::ExecutionContext.new(frame&._client || @client, context_payload, world)
|
386
386
|
if world
|
387
387
|
world.context = context
|
388
388
|
end
|
@@ -27,9 +27,6 @@ module Puppeteer::Launcher
|
|
27
27
|
@chrome_arg_options.args.dup
|
28
28
|
end
|
29
29
|
|
30
|
-
#
|
31
|
-
# let temporaryUserDataDir = null;
|
32
|
-
|
33
30
|
if chrome_arguments.none? { |arg| arg.start_with?('--remote-debugging-') }
|
34
31
|
if @launch_options.pipe?
|
35
32
|
chrome_arguments << '--remote-debugging-pipe'
|
@@ -38,10 +35,17 @@ module Puppeteer::Launcher
|
|
38
35
|
end
|
39
36
|
end
|
40
37
|
|
41
|
-
|
42
|
-
if
|
43
|
-
|
44
|
-
|
38
|
+
user_data_dir = chrome_arguments.find { |arg| arg.start_with?('--user-data-dir') }
|
39
|
+
if user_data_dir
|
40
|
+
user_data_dir = user_data_dir.split('=').last
|
41
|
+
unless File.exist?(user_data_dir)
|
42
|
+
raise ArgumentError.new("Chrome user data dir not found at '#{user_data_dir}'")
|
43
|
+
end
|
44
|
+
using_temp_user_data_dir = false
|
45
|
+
else
|
46
|
+
user_data_dir = Dir.mktmpdir('puppeteer_dev_chrome_profile-', ENV['PUPPETEER_TMP_DIR'])
|
47
|
+
chrome_arguments << "--user-data-dir=#{user_data_dir}"
|
48
|
+
using_temp_user_data_dir = true
|
45
49
|
end
|
46
50
|
|
47
51
|
chrome_executable =
|
@@ -51,7 +55,13 @@ module Puppeteer::Launcher
|
|
51
55
|
@launch_options.executable_path || fallback_executable_path
|
52
56
|
end
|
53
57
|
use_pipe = chrome_arguments.include?('--remote-debugging-pipe')
|
54
|
-
runner = Puppeteer::BrowserRunner.new(
|
58
|
+
runner = Puppeteer::BrowserRunner.new(
|
59
|
+
false,
|
60
|
+
chrome_executable,
|
61
|
+
chrome_arguments,
|
62
|
+
user_data_dir,
|
63
|
+
using_temp_user_data_dir,
|
64
|
+
)
|
55
65
|
runner.start(
|
56
66
|
handle_SIGHUP: @launch_options.handle_SIGHUP?,
|
57
67
|
handle_SIGTERM: @launch_options.handle_SIGTERM?,
|
@@ -61,33 +71,39 @@ module Puppeteer::Launcher
|
|
61
71
|
pipe: use_pipe,
|
62
72
|
)
|
63
73
|
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
74
|
+
browser =
|
75
|
+
begin
|
76
|
+
connection = runner.setup_connection(
|
77
|
+
use_pipe: use_pipe,
|
78
|
+
timeout: @launch_options.timeout,
|
79
|
+
slow_mo: @browser_options.slow_mo,
|
80
|
+
preferred_revision: @preferred_revision,
|
81
|
+
)
|
82
|
+
|
83
|
+
Puppeteer::Browser.create(
|
84
|
+
connection: connection,
|
85
|
+
context_ids: [],
|
86
|
+
ignore_https_errors: @browser_options.ignore_https_errors?,
|
87
|
+
default_viewport: @browser_options.default_viewport,
|
88
|
+
process: runner.proc,
|
89
|
+
close_callback: -> { runner.close },
|
90
|
+
)
|
91
|
+
rescue
|
92
|
+
runner.kill
|
93
|
+
raise
|
94
|
+
end
|
80
95
|
|
96
|
+
begin
|
81
97
|
browser.wait_for_target(
|
82
98
|
predicate: ->(target) { target.type == 'page' },
|
83
99
|
timeout: @launch_options.timeout,
|
84
100
|
)
|
85
|
-
|
86
|
-
browser
|
87
101
|
rescue
|
88
|
-
|
102
|
+
browser.close
|
89
103
|
raise
|
90
104
|
end
|
105
|
+
|
106
|
+
browser
|
91
107
|
end
|
92
108
|
|
93
109
|
class DefaultArgs
|
@@ -31,11 +31,20 @@ module Puppeteer::Launcher
|
|
31
31
|
firefox_arguments << "--remote-debugging-port=#{@chrome_arg_options.debugging_port}"
|
32
32
|
end
|
33
33
|
|
34
|
-
|
35
|
-
if
|
36
|
-
|
34
|
+
profile_arg_index = firefox_arguments.index { |arg| arg.start_with?('--profile') || arg.start_with?('-profile') }
|
35
|
+
if profile_arg_index
|
36
|
+
using_temp_user_data_dir = false
|
37
|
+
user_data_dir = firefox_arguments[profile_arg_index + 1]
|
38
|
+
unless File.exist?(user_data_dir)
|
39
|
+
raise ArgumentError.new("Firefox profile not found at '#{user_data_dir}'")
|
40
|
+
end
|
41
|
+
prefs = default_preferences(@launch_options.extra_prefs_firefox)
|
42
|
+
write_preferences(prefs, user_data_dir)
|
43
|
+
else
|
44
|
+
using_temp_user_data_dir = true
|
45
|
+
user_data_dir = create_profile(@launch_options.extra_prefs_firefox)
|
37
46
|
firefox_arguments << "--profile"
|
38
|
-
firefox_arguments <<
|
47
|
+
firefox_arguments << user_data_dir
|
39
48
|
end
|
40
49
|
|
41
50
|
firefox_executable =
|
@@ -44,7 +53,13 @@ module Puppeteer::Launcher
|
|
44
53
|
else
|
45
54
|
@launch_options.executable_path || fallback_executable_path
|
46
55
|
end
|
47
|
-
runner = Puppeteer::BrowserRunner.new(
|
56
|
+
runner = Puppeteer::BrowserRunner.new(
|
57
|
+
true,
|
58
|
+
firefox_executable,
|
59
|
+
firefox_arguments,
|
60
|
+
user_data_dir,
|
61
|
+
using_temp_user_data_dir,
|
62
|
+
)
|
48
63
|
runner.start(
|
49
64
|
handle_SIGHUP: @launch_options.handle_SIGHUP?,
|
50
65
|
handle_SIGTERM: @launch_options.handle_SIGTERM?,
|
@@ -54,33 +69,39 @@ module Puppeteer::Launcher
|
|
54
69
|
pipe: @launch_options.pipe?,
|
55
70
|
)
|
56
71
|
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
72
|
+
browser =
|
73
|
+
begin
|
74
|
+
connection = runner.setup_connection(
|
75
|
+
use_pipe: @launch_options.pipe?,
|
76
|
+
timeout: @launch_options.timeout,
|
77
|
+
slow_mo: @browser_options.slow_mo,
|
78
|
+
preferred_revision: @preferred_revision,
|
79
|
+
)
|
80
|
+
|
81
|
+
Puppeteer::Browser.create(
|
82
|
+
connection: connection,
|
83
|
+
context_ids: [],
|
84
|
+
ignore_https_errors: @browser_options.ignore_https_errors?,
|
85
|
+
default_viewport: @browser_options.default_viewport,
|
86
|
+
process: runner.proc,
|
87
|
+
close_callback: -> { runner.close },
|
88
|
+
)
|
89
|
+
rescue
|
90
|
+
runner.kill
|
91
|
+
raise
|
92
|
+
end
|
73
93
|
|
94
|
+
begin
|
74
95
|
browser.wait_for_target(
|
75
96
|
predicate: ->(target) { target.type == 'page' },
|
76
97
|
timeout: @launch_options.timeout,
|
77
98
|
)
|
78
|
-
|
79
|
-
browser
|
80
99
|
rescue
|
81
|
-
|
100
|
+
browser.close
|
82
101
|
raise
|
83
102
|
end
|
103
|
+
|
104
|
+
browser
|
84
105
|
end
|
85
106
|
|
86
107
|
# @return [Puppeteer::Browser]
|
@@ -190,11 +211,13 @@ module Puppeteer::Launcher
|
|
190
211
|
|
191
212
|
# @param options [Launcher::ChromeArgOptions]
|
192
213
|
def initialize(chrome_arg_options)
|
193
|
-
firefox_arguments = ['--no-remote'
|
214
|
+
firefox_arguments = ['--no-remote']
|
194
215
|
|
195
|
-
|
196
|
-
|
197
|
-
|
216
|
+
if Puppeteer.env.darwin?
|
217
|
+
firefox_arguments << '--foreground'
|
218
|
+
elsif Puppeteer.env.windows?
|
219
|
+
firefox_arguments << '--wait-for-browser'
|
220
|
+
end
|
198
221
|
|
199
222
|
if chrome_arg_options.user_data_dir
|
200
223
|
firefox_arguments << "--profile"
|
@@ -230,209 +253,216 @@ module Puppeteer::Launcher
|
|
230
253
|
DefaultArgs.new(ChromeArgOptions.new(options || {}))
|
231
254
|
end
|
232
255
|
|
233
|
-
private def
|
234
|
-
|
235
|
-
|
236
|
-
|
237
|
-
|
238
|
-
|
239
|
-
|
240
|
-
|
241
|
-
|
242
|
-
|
243
|
-
|
244
|
-
|
245
|
-
|
246
|
-
|
247
|
-
|
248
|
-
|
249
|
-
|
250
|
-
|
251
|
-
|
252
|
-
|
253
|
-
|
254
|
-
|
255
|
-
|
256
|
-
|
257
|
-
|
258
|
-
|
259
|
-
|
260
|
-
|
261
|
-
|
262
|
-
|
263
|
-
|
264
|
-
|
265
|
-
|
266
|
-
|
267
|
-
|
268
|
-
|
269
|
-
|
270
|
-
|
271
|
-
|
272
|
-
|
273
|
-
|
274
|
-
|
275
|
-
|
276
|
-
|
277
|
-
|
278
|
-
|
279
|
-
|
280
|
-
|
281
|
-
|
282
|
-
|
283
|
-
|
284
|
-
|
285
|
-
|
286
|
-
|
287
|
-
|
288
|
-
|
289
|
-
|
290
|
-
|
291
|
-
|
292
|
-
|
293
|
-
|
294
|
-
|
295
|
-
|
296
|
-
|
297
|
-
|
298
|
-
|
299
|
-
|
300
|
-
|
301
|
-
|
302
|
-
|
303
|
-
|
304
|
-
|
305
|
-
|
306
|
-
|
307
|
-
|
308
|
-
|
309
|
-
|
310
|
-
|
311
|
-
|
312
|
-
|
313
|
-
|
314
|
-
|
315
|
-
|
316
|
-
|
317
|
-
|
318
|
-
|
319
|
-
|
320
|
-
|
321
|
-
|
322
|
-
|
323
|
-
|
324
|
-
|
325
|
-
|
326
|
-
|
327
|
-
|
328
|
-
|
329
|
-
|
330
|
-
|
331
|
-
|
332
|
-
|
333
|
-
|
334
|
-
|
335
|
-
|
336
|
-
|
337
|
-
|
338
|
-
|
339
|
-
|
340
|
-
|
341
|
-
|
342
|
-
|
343
|
-
|
344
|
-
|
345
|
-
|
346
|
-
|
347
|
-
|
348
|
-
|
349
|
-
|
350
|
-
|
351
|
-
|
352
|
-
|
353
|
-
|
354
|
-
|
355
|
-
|
356
|
-
|
357
|
-
|
358
|
-
|
359
|
-
|
360
|
-
|
361
|
-
|
362
|
-
|
363
|
-
|
364
|
-
|
365
|
-
|
366
|
-
|
367
|
-
|
368
|
-
|
369
|
-
|
370
|
-
|
371
|
-
|
372
|
-
|
373
|
-
|
374
|
-
|
375
|
-
|
376
|
-
|
377
|
-
|
378
|
-
|
379
|
-
|
380
|
-
|
381
|
-
|
382
|
-
|
383
|
-
|
384
|
-
|
385
|
-
|
386
|
-
|
387
|
-
|
388
|
-
|
389
|
-
|
390
|
-
|
391
|
-
|
392
|
-
|
393
|
-
|
394
|
-
|
395
|
-
|
396
|
-
|
397
|
-
|
398
|
-
|
399
|
-
|
400
|
-
|
401
|
-
|
402
|
-
|
403
|
-
|
404
|
-
|
405
|
-
|
406
|
-
|
256
|
+
private def default_preferences(extra_prefs)
|
257
|
+
server = 'dummy.test'
|
258
|
+
default_preferences = {
|
259
|
+
# Make sure Shield doesn't hit the network.
|
260
|
+
'app.normandy.api_url': '',
|
261
|
+
# Disable Firefox old build background check
|
262
|
+
'app.update.checkInstallTime': false,
|
263
|
+
# Disable automatically upgrading Firefox
|
264
|
+
'app.update.disabledForTesting': true,
|
265
|
+
|
266
|
+
# Increase the APZ content response timeout to 1 minute
|
267
|
+
'apz.content_response_timeout': 60000,
|
268
|
+
|
269
|
+
# Prevent various error message on the console
|
270
|
+
# jest-puppeteer asserts that no error message is emitted by the console
|
271
|
+
'browser.contentblocking.features.standard': '-tp,tpPrivate,cookieBehavior0,-cm,-fp',
|
272
|
+
|
273
|
+
# Enable the dump function: which sends messages to the system
|
274
|
+
# console
|
275
|
+
# https://bugzilla.mozilla.org/show_bug.cgi?id=1543115
|
276
|
+
'browser.dom.window.dump.enabled': true,
|
277
|
+
# Disable topstories
|
278
|
+
'browser.newtabpage.activity-stream.feeds.system.topstories': false,
|
279
|
+
# Always display a blank page
|
280
|
+
'browser.newtabpage.enabled': false,
|
281
|
+
# Background thumbnails in particular cause grief: and disabling
|
282
|
+
# thumbnails in general cannot hurt
|
283
|
+
'browser.pagethumbnails.capturing_disabled': true,
|
284
|
+
|
285
|
+
# Disable safebrowsing components.
|
286
|
+
'browser.safebrowsing.blockedURIs.enabled': false,
|
287
|
+
'browser.safebrowsing.downloads.enabled': false,
|
288
|
+
'browser.safebrowsing.malware.enabled': false,
|
289
|
+
'browser.safebrowsing.passwords.enabled': false,
|
290
|
+
'browser.safebrowsing.phishing.enabled': false,
|
291
|
+
|
292
|
+
# Disable updates to search engines.
|
293
|
+
'browser.search.update': false,
|
294
|
+
# Do not restore the last open set of tabs if the browser has crashed
|
295
|
+
'browser.sessionstore.resume_from_crash': false,
|
296
|
+
# Skip check for default browser on startup
|
297
|
+
'browser.shell.checkDefaultBrowser': false,
|
298
|
+
|
299
|
+
# Disable newtabpage
|
300
|
+
'browser.startup.homepage': 'about:blank',
|
301
|
+
# Do not redirect user when a milstone upgrade of Firefox is detected
|
302
|
+
'browser.startup.homepage_override.mstone': 'ignore',
|
303
|
+
# Start with a blank page about:blank
|
304
|
+
'browser.startup.page': 0,
|
305
|
+
|
306
|
+
# Do not allow background tabs to be zombified on Android: otherwise for
|
307
|
+
# tests that open additional tabs: the test harness tab itself might get
|
308
|
+
# unloaded
|
309
|
+
'browser.tabs.disableBackgroundZombification': false,
|
310
|
+
# Do not warn when closing all other open tabs
|
311
|
+
'browser.tabs.warnOnCloseOtherTabs': false,
|
312
|
+
# Do not warn when multiple tabs will be opened
|
313
|
+
'browser.tabs.warnOnOpen': false,
|
314
|
+
|
315
|
+
# Disable the UI tour.
|
316
|
+
'browser.uitour.enabled': false,
|
317
|
+
# Turn off search suggestions in the location bar so as not to trigger
|
318
|
+
# network connections.
|
319
|
+
'browser.urlbar.suggest.searches': false,
|
320
|
+
# Disable first run splash page on Windows 10
|
321
|
+
'browser.usedOnWindows10.introURL': '',
|
322
|
+
# Do not warn on quitting Firefox
|
323
|
+
'browser.warnOnQuit': false,
|
324
|
+
|
325
|
+
# Defensively disable data reporting systems
|
326
|
+
'datareporting.healthreport.documentServerURI': "http://#{server}/dummy/healthreport/",
|
327
|
+
'datareporting.healthreport.logging.consoleEnabled': false,
|
328
|
+
'datareporting.healthreport.service.enabled': false,
|
329
|
+
'datareporting.healthreport.service.firstRun': false,
|
330
|
+
'datareporting.healthreport.uploadEnabled': false,
|
331
|
+
|
332
|
+
# Do not show datareporting policy notifications which can interfere with tests
|
333
|
+
'datareporting.policy.dataSubmissionEnabled': false,
|
334
|
+
'datareporting.policy.dataSubmissionPolicyBypassNotification': true,
|
335
|
+
|
336
|
+
# DevTools JSONViewer sometimes fails to load dependencies with its require.js.
|
337
|
+
# This doesn't affect Puppeteer but spams console (Bug 1424372)
|
338
|
+
'devtools.jsonview.enabled': false,
|
339
|
+
|
340
|
+
# Disable popup-blocker
|
341
|
+
'dom.disable_open_during_load': false,
|
342
|
+
|
343
|
+
# Enable the support for File object creation in the content process
|
344
|
+
# Required for |Page.setFileInputFiles| protocol method.
|
345
|
+
'dom.file.createInChild': true,
|
346
|
+
|
347
|
+
# Disable the ProcessHangMonitor
|
348
|
+
'dom.ipc.reportProcessHangs': false,
|
349
|
+
|
350
|
+
# Disable slow script dialogues
|
351
|
+
'dom.max_chrome_script_run_time': 0,
|
352
|
+
'dom.max_script_run_time': 0,
|
353
|
+
|
354
|
+
# Only load extensions from the application and user profile
|
355
|
+
# AddonManager.SCOPE_PROFILE + AddonManager.SCOPE_APPLICATION
|
356
|
+
'extensions.autoDisableScopes': 0,
|
357
|
+
'extensions.enabledScopes': 5,
|
358
|
+
|
359
|
+
# Disable metadata caching for installed add-ons by default
|
360
|
+
'extensions.getAddons.cache.enabled': false,
|
361
|
+
|
362
|
+
# Disable installing any distribution extensions or add-ons.
|
363
|
+
'extensions.installDistroAddons': false,
|
364
|
+
|
365
|
+
# Disabled screenshots extension
|
366
|
+
'extensions.screenshots.disabled': true,
|
367
|
+
|
368
|
+
# Turn off extension updates so they do not bother tests
|
369
|
+
'extensions.update.enabled': false,
|
370
|
+
|
371
|
+
# Turn off extension updates so they do not bother tests
|
372
|
+
'extensions.update.notifyUser': false,
|
373
|
+
|
374
|
+
# Make sure opening about:addons will not hit the network
|
375
|
+
'extensions.webservice.discoverURL': "http://#{server}/dummy/discoveryURL",
|
376
|
+
|
377
|
+
# Allow the application to have focus even it runs in the background
|
378
|
+
'focusmanager.testmode': true,
|
379
|
+
# Disable useragent updates
|
380
|
+
'general.useragent.updates.enabled': false,
|
381
|
+
# Always use network provider for geolocation tests so we bypass the
|
382
|
+
# macOS dialog raised by the corelocation provider
|
383
|
+
'geo.provider.testing': true,
|
384
|
+
# Do not scan Wifi
|
385
|
+
'geo.wifi.scan': false,
|
386
|
+
# No hang monitor
|
387
|
+
'hangmonitor.timeout': 0,
|
388
|
+
# Show chrome errors and warnings in the error console
|
389
|
+
'javascript.options.showInConsole': true,
|
390
|
+
|
391
|
+
# Disable download and usage of OpenH264: and Widevine plugins
|
392
|
+
'media.gmp-manager.updateEnabled': false,
|
393
|
+
# Prevent various error message on the console
|
394
|
+
# jest-puppeteer asserts that no error message is emitted by the console
|
395
|
+
'network.cookie.cookieBehavior': 0,
|
396
|
+
|
397
|
+
# Do not prompt for temporary redirects
|
398
|
+
'network.http.prompt-temp-redirect': false,
|
399
|
+
|
400
|
+
# Disable speculative connections so they are not reported as leaking
|
401
|
+
# when they are hanging around
|
402
|
+
'network.http.speculative-parallel-limit': 0,
|
403
|
+
|
404
|
+
# Do not automatically switch between offline and online
|
405
|
+
'network.manage-offline-status': false,
|
406
|
+
|
407
|
+
# Make sure SNTP requests do not hit the network
|
408
|
+
'network.sntp.pools': server,
|
409
|
+
|
410
|
+
# Disable Flash.
|
411
|
+
'plugin.state.flash': 0,
|
412
|
+
|
413
|
+
'privacy.trackingprotection.enabled': false,
|
414
|
+
|
415
|
+
# Enable Remote Agent
|
416
|
+
# https://bugzilla.mozilla.org/show_bug.cgi?id=1544393
|
417
|
+
'remote.enabled': true,
|
418
|
+
|
419
|
+
# Don't do network connections for mitm priming
|
420
|
+
'security.certerrors.mitm.priming.enabled': false,
|
421
|
+
# Local documents have access to all other local documents,
|
422
|
+
# including directory listings
|
423
|
+
'security.fileuri.strict_origin_policy': false,
|
424
|
+
# Do not wait for the notification button security delay
|
425
|
+
'security.notification_enable_delay': 0,
|
426
|
+
|
427
|
+
# Ensure blocklist updates do not hit the network
|
428
|
+
'services.settings.server': "http://#{server}/dummy/blocklist/",
|
429
|
+
|
430
|
+
# Do not automatically fill sign-in forms with known usernames and
|
431
|
+
# passwords
|
432
|
+
'signon.autofillForms': false,
|
433
|
+
# Disable password capture, so that tests that include forms are not
|
434
|
+
# influenced by the presence of the persistent doorhanger notification
|
435
|
+
'signon.rememberSignons': false,
|
436
|
+
|
437
|
+
# Disable first-run welcome page
|
438
|
+
'startup.homepage_welcome_url': 'about:blank',
|
407
439
|
|
408
|
-
|
409
|
-
|
410
|
-
'signon.autofillForms': false,
|
411
|
-
# Disable password capture, so that tests that include forms are not
|
412
|
-
# influenced by the presence of the persistent doorhanger notification
|
413
|
-
'signon.rememberSignons': false,
|
414
|
-
|
415
|
-
# Disable first-run welcome page
|
416
|
-
'startup.homepage_welcome_url': 'about:blank',
|
440
|
+
# Disable first-run welcome page
|
441
|
+
'startup.homepage_welcome_url.additional': '',
|
417
442
|
|
418
|
-
|
419
|
-
|
443
|
+
# Disable browser animations (tabs, fullscreen, sliding alerts)
|
444
|
+
'toolkit.cosmeticAnimations.enabled': false,
|
420
445
|
|
421
|
-
|
422
|
-
|
446
|
+
# Prevent starting into safe mode after application crashes
|
447
|
+
'toolkit.startup.max_resumed_crashes': -1,
|
448
|
+
}
|
423
449
|
|
424
|
-
|
425
|
-
|
426
|
-
}
|
450
|
+
default_preferences.merge(extra_prefs)
|
451
|
+
end
|
427
452
|
|
428
|
-
|
429
|
-
|
430
|
-
|
431
|
-
|
432
|
-
f.write("user_pref(#{JSON.generate(key)}, #{JSON.generate(value)});\n")
|
433
|
-
end
|
453
|
+
private def write_preferences(prefs, profile_path)
|
454
|
+
File.open(File.join(profile_path, 'user.js'), 'w') do |f|
|
455
|
+
prefs.each do |key, value|
|
456
|
+
f.write("user_pref(#{JSON.generate(key)}, #{JSON.generate(value)});\n")
|
434
457
|
end
|
435
|
-
|
458
|
+
end
|
459
|
+
IO.write(File.join(profile_path, 'prefs.js'), "")
|
460
|
+
end
|
461
|
+
|
462
|
+
private def create_profile(extra_prefs)
|
463
|
+
Dir.mktmpdir('puppeteer_dev_firefox_profile-', ENV['PUPPETEER_TMP_DIR']).tap do |profile_path|
|
464
|
+
prefs = default_preferences(extra_prefs)
|
465
|
+
write_preferences(prefs, profile_path)
|
436
466
|
end
|
437
467
|
end
|
438
468
|
end
|
@@ -42,9 +42,10 @@ module Puppeteer::Launcher
|
|
42
42
|
@dumpio = options[:dumpio] || false
|
43
43
|
@env = options[:env] || ENV
|
44
44
|
@pipe = options[:pipe] || false
|
45
|
+
@extra_prefs_firefox = options[:extra_prefs_firefox] || {}
|
45
46
|
end
|
46
47
|
|
47
|
-
attr_reader :channel, :executable_path, :ignore_default_args, :timeout, :env
|
48
|
+
attr_reader :channel, :executable_path, :ignore_default_args, :timeout, :env, :extra_prefs_firefox
|
48
49
|
|
49
50
|
def handle_SIGINT?
|
50
51
|
@handle_SIGINT
|
data/lib/puppeteer/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: puppeteer-ruby
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.39.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- YusukeIwaki
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2021-12-
|
11
|
+
date: 2021-12-17 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: concurrent-ruby
|