selenium-webdriver 3.141.0 → 3.142.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGES +125 -0
- data/Gemfile +2 -0
- data/LICENSE +1 -1
- data/lib/selenium-webdriver.rb +2 -0
- data/lib/selenium/server.rb +9 -7
- data/lib/selenium/webdriver.rb +3 -1
- data/lib/selenium/webdriver/atoms.rb +20 -1
- data/lib/selenium/webdriver/atoms/getAttribute.js +6 -7
- data/lib/selenium/webdriver/atoms/isDisplayed.js +60 -59
- data/lib/selenium/webdriver/chrome.rb +10 -4
- data/lib/selenium/webdriver/chrome/bridge.rb +5 -3
- data/lib/selenium/webdriver/chrome/driver.rb +10 -13
- data/lib/selenium/webdriver/chrome/options.rb +4 -4
- data/lib/selenium/webdriver/chrome/profile.rb +4 -3
- data/lib/selenium/webdriver/chrome/service.rb +13 -13
- data/lib/selenium/webdriver/common.rb +4 -2
- data/lib/selenium/webdriver/common/action_builder.rb +2 -0
- data/lib/selenium/webdriver/common/alert.rb +2 -0
- data/lib/selenium/webdriver/common/bridge_helper.rb +8 -5
- data/lib/selenium/webdriver/common/driver.rb +22 -7
- data/lib/selenium/webdriver/common/driver_extensions/downloads_files.rb +2 -0
- data/lib/selenium/webdriver/common/driver_extensions/has_addons.rb +2 -0
- data/lib/selenium/webdriver/common/driver_extensions/has_debugger.rb +2 -0
- data/lib/selenium/webdriver/common/driver_extensions/has_location.rb +3 -3
- data/lib/selenium/webdriver/common/driver_extensions/has_network_conditions.rb +2 -0
- data/lib/selenium/webdriver/common/driver_extensions/has_network_connection.rb +3 -1
- data/lib/selenium/webdriver/common/driver_extensions/has_permissions.rb +2 -0
- data/lib/selenium/webdriver/common/driver_extensions/has_remote_status.rb +2 -0
- data/lib/selenium/webdriver/common/driver_extensions/has_session_id.rb +2 -0
- data/lib/selenium/webdriver/common/driver_extensions/has_touch_screen.rb +2 -0
- data/lib/selenium/webdriver/common/driver_extensions/has_web_storage.rb +2 -0
- data/lib/selenium/webdriver/common/driver_extensions/rotatable.rb +3 -1
- data/lib/selenium/webdriver/common/driver_extensions/takes_screenshot.rb +2 -0
- data/lib/selenium/webdriver/common/driver_extensions/uploads_files.rb +3 -3
- data/lib/selenium/webdriver/common/element.rb +3 -1
- data/lib/selenium/webdriver/common/error.rb +74 -18
- data/lib/selenium/webdriver/common/file_reaper.rb +3 -3
- data/lib/selenium/webdriver/common/html5/local_storage.rb +2 -0
- data/lib/selenium/webdriver/common/html5/session_storage.rb +2 -0
- data/lib/selenium/webdriver/common/html5/shared_web_storage.rb +4 -1
- data/lib/selenium/webdriver/common/interactions/input_device.rb +3 -0
- data/lib/selenium/webdriver/common/interactions/interaction.rb +3 -0
- data/lib/selenium/webdriver/common/interactions/interactions.rb +3 -1
- data/lib/selenium/webdriver/common/interactions/key_actions.rb +2 -0
- data/lib/selenium/webdriver/common/interactions/key_input.rb +4 -0
- data/lib/selenium/webdriver/common/interactions/none_input.rb +3 -0
- data/lib/selenium/webdriver/common/interactions/pointer_actions.rb +2 -0
- data/lib/selenium/webdriver/common/interactions/pointer_input.rb +7 -0
- data/lib/selenium/webdriver/common/keyboard.rb +4 -1
- data/lib/selenium/webdriver/common/keys.rb +3 -0
- data/lib/selenium/webdriver/common/log_entry.rb +4 -2
- data/lib/selenium/webdriver/common/logger.rb +15 -40
- data/lib/selenium/webdriver/common/logs.rb +2 -0
- data/lib/selenium/webdriver/common/{options.rb → manager.rb} +27 -1
- data/lib/selenium/webdriver/common/mouse.rb +3 -0
- data/lib/selenium/webdriver/common/navigation.rb +2 -0
- data/lib/selenium/webdriver/common/platform.rb +26 -30
- data/lib/selenium/webdriver/common/port_prober.rb +6 -19
- data/lib/selenium/webdriver/common/profile_helper.rb +2 -0
- data/lib/selenium/webdriver/common/proxy.rb +13 -5
- data/lib/selenium/webdriver/common/search_context.rb +6 -8
- data/lib/selenium/webdriver/common/service.rb +87 -29
- data/lib/selenium/webdriver/common/socket_lock.rb +10 -3
- data/lib/selenium/webdriver/common/socket_poller.rb +26 -18
- data/lib/selenium/webdriver/common/target_locator.rb +6 -4
- data/lib/selenium/webdriver/common/timeouts.rb +2 -0
- data/lib/selenium/webdriver/common/touch_action_builder.rb +5 -6
- data/lib/selenium/webdriver/common/touch_screen.rb +4 -1
- data/lib/selenium/webdriver/common/w3c_action_builder.rb +3 -0
- data/lib/selenium/webdriver/common/{w3c_options.rb → w3c_manager.rb} +3 -1
- data/lib/selenium/webdriver/common/wait.rb +13 -5
- data/lib/selenium/webdriver/common/window.rb +2 -0
- data/lib/selenium/webdriver/common/zipper.rb +3 -3
- data/lib/selenium/webdriver/edge.rb +11 -5
- data/lib/selenium/webdriver/edge/bridge.rb +2 -0
- data/lib/selenium/webdriver/edge/driver.rb +5 -12
- data/lib/selenium/webdriver/edge/options.rb +3 -0
- data/lib/selenium/webdriver/edge/service.rb +8 -12
- data/lib/selenium/webdriver/firefox.rb +10 -4
- data/lib/selenium/webdriver/firefox/binary.rb +7 -6
- data/lib/selenium/webdriver/firefox/bridge.rb +47 -0
- data/lib/selenium/webdriver/firefox/driver.rb +2 -0
- data/lib/selenium/webdriver/firefox/extension.rb +4 -4
- data/lib/selenium/webdriver/firefox/launcher.rb +3 -0
- data/lib/selenium/webdriver/firefox/legacy/driver.rb +7 -3
- data/lib/selenium/webdriver/firefox/marionette/bridge.rb +4 -2
- data/lib/selenium/webdriver/firefox/marionette/driver.rb +5 -11
- data/lib/selenium/webdriver/firefox/options.rb +20 -7
- data/lib/selenium/webdriver/firefox/profile.rb +7 -8
- data/lib/selenium/webdriver/firefox/profiles_ini.rb +3 -0
- data/lib/selenium/webdriver/firefox/service.rb +8 -19
- data/lib/selenium/webdriver/firefox/util.rb +2 -0
- data/lib/selenium/webdriver/ie.rb +10 -4
- data/lib/selenium/webdriver/ie/driver.rb +4 -10
- data/lib/selenium/webdriver/ie/options.rb +4 -2
- data/lib/selenium/webdriver/ie/service.rb +8 -12
- data/lib/selenium/webdriver/remote.rb +2 -0
- data/lib/selenium/webdriver/remote/bridge.rb +6 -4
- data/lib/selenium/webdriver/remote/capabilities.rb +23 -10
- data/lib/selenium/webdriver/remote/commands.rb +156 -0
- data/lib/selenium/webdriver/remote/driver.rb +2 -0
- data/lib/selenium/webdriver/remote/http/common.rb +11 -4
- data/lib/selenium/webdriver/remote/http/curb.rb +4 -2
- data/lib/selenium/webdriver/remote/http/default.rb +31 -25
- data/lib/selenium/webdriver/remote/http/persistent.rb +3 -1
- data/lib/selenium/webdriver/remote/oss/bridge.rb +5 -2
- data/lib/selenium/webdriver/remote/oss/commands.rb +106 -104
- data/lib/selenium/webdriver/remote/response.rb +11 -3
- data/lib/selenium/webdriver/remote/server_error.rb +2 -0
- data/lib/selenium/webdriver/remote/w3c/bridge.rb +28 -13
- data/lib/selenium/webdriver/remote/w3c/capabilities.rb +37 -21
- data/lib/selenium/webdriver/remote/w3c/commands.rb +61 -58
- data/lib/selenium/webdriver/safari.rb +11 -4
- data/lib/selenium/webdriver/safari/bridge.rb +5 -3
- data/lib/selenium/webdriver/safari/driver.rb +8 -10
- data/lib/selenium/webdriver/safari/options.rb +2 -0
- data/lib/selenium/webdriver/safari/service.rb +6 -25
- data/lib/selenium/webdriver/support.rb +2 -0
- data/lib/selenium/webdriver/support/abstract_event_listener.rb +2 -0
- data/lib/selenium/webdriver/support/block_event_listener.rb +3 -1
- data/lib/selenium/webdriver/support/color.rb +11 -9
- data/lib/selenium/webdriver/support/escaper.rb +2 -0
- data/lib/selenium/webdriver/support/event_firing_bridge.rb +3 -1
- data/lib/selenium/webdriver/support/select.rb +19 -18
- data/lib/selenium/webdriver/version.rb +3 -1
- data/selenium-webdriver.gemspec +14 -7
- metadata +89 -23
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
# Licensed to the Software Freedom Conservancy (SFC) under one
|
2
4
|
# or more contributor license agreements. See the NOTICE file
|
3
5
|
# distributed with this work for additional information
|
@@ -45,16 +47,21 @@ module Selenium
|
|
45
47
|
private
|
46
48
|
|
47
49
|
def lock
|
48
|
-
max_time =
|
50
|
+
max_time = current_time + @timeout
|
49
51
|
|
50
|
-
sleep 0.1 until can_lock? ||
|
52
|
+
sleep 0.1 until can_lock? || current_time >= max_time
|
51
53
|
|
52
54
|
return if did_lock?
|
55
|
+
|
53
56
|
raise Error::WebDriverError, "unable to bind to locking port #{@port} within #{@timeout} seconds"
|
54
57
|
end
|
55
58
|
|
59
|
+
def current_time
|
60
|
+
Process.clock_gettime(Process::CLOCK_MONOTONIC)
|
61
|
+
end
|
62
|
+
|
56
63
|
def release
|
57
|
-
@server
|
64
|
+
@server&.close
|
58
65
|
end
|
59
66
|
|
60
67
|
def can_lock?
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
# Licensed to the Software Freedom Conservancy (SFC) under one
|
2
4
|
# or more contributor license agreements. See the NOTICE file
|
3
5
|
# distributed with this work for additional information
|
@@ -54,12 +56,14 @@ module Selenium
|
|
54
56
|
|
55
57
|
CONNECT_TIMEOUT = 5
|
56
58
|
|
57
|
-
NOT_CONNECTED_ERRORS = [Errno::ECONNREFUSED, Errno::ENOTCONN, SocketError]
|
58
|
-
|
59
|
+
NOT_CONNECTED_ERRORS = [Errno::ECONNREFUSED, Errno::ENOTCONN, SocketError].tap { |arr|
|
60
|
+
arr << Errno::EPERM if Platform.cygwin?
|
61
|
+
}.freeze
|
59
62
|
|
60
|
-
CONNECTED_ERRORS = [Errno::EISCONN]
|
61
|
-
|
62
|
-
|
63
|
+
CONNECTED_ERRORS = [Errno::EISCONN].tap { |arr|
|
64
|
+
arr << Errno::EINVAL if Platform.windows?
|
65
|
+
arr << Errno::EALREADY if Platform.wsl?
|
66
|
+
}.freeze
|
63
67
|
|
64
68
|
if Platform.jruby?
|
65
69
|
# we use a plain TCPSocket here since JRuby has issues select()ing on a connecting socket
|
@@ -79,7 +83,7 @@ module Selenium
|
|
79
83
|
begin
|
80
84
|
sock.connect_nonblock sockaddr
|
81
85
|
rescue Errno::EINPROGRESS
|
82
|
-
retry if
|
86
|
+
retry if socket_writable?(sock) && conn_completed?(sock)
|
83
87
|
raise Errno::ECONNREFUSED
|
84
88
|
rescue *CONNECTED_ERRORS
|
85
89
|
# yay!
|
@@ -88,30 +92,34 @@ module Selenium
|
|
88
92
|
sock.close
|
89
93
|
true
|
90
94
|
rescue *NOT_CONNECTED_ERRORS
|
91
|
-
sock
|
95
|
+
sock&.close
|
92
96
|
WebDriver.logger.debug("polling for socket on #{[@host, @port].inspect}")
|
93
97
|
false
|
94
98
|
end
|
95
99
|
end
|
96
100
|
|
101
|
+
def socket_writable?(sock)
|
102
|
+
IO.select(nil, [sock], nil, CONNECT_TIMEOUT)
|
103
|
+
end
|
104
|
+
|
105
|
+
def conn_completed?(sock)
|
106
|
+
sock.getsockopt(Socket::SOL_SOCKET, Socket::SO_ERROR).int.zero?
|
107
|
+
end
|
108
|
+
|
97
109
|
def with_timeout
|
98
|
-
max_time =
|
110
|
+
max_time = current_time + @timeout
|
99
111
|
|
100
|
-
|
112
|
+
until current_time > max_time
|
101
113
|
return true if yield
|
102
|
-
wait
|
103
|
-
) until time_now > max_time
|
104
114
|
|
105
|
-
|
106
|
-
|
115
|
+
sleep @interval
|
116
|
+
end
|
107
117
|
|
108
|
-
|
109
|
-
sleep @interval
|
118
|
+
false
|
110
119
|
end
|
111
120
|
|
112
|
-
|
113
|
-
|
114
|
-
Time.now
|
121
|
+
def current_time
|
122
|
+
Process.clock_gettime(Process::CLOCK_MONOTONIC)
|
115
123
|
end
|
116
124
|
end # SocketPoller
|
117
125
|
end # WebDriver
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
# Licensed to the Software Freedom Conservancy (SFC) under one
|
2
4
|
# or more contributor license agreements. See the NOTICE file
|
3
5
|
# distributed with this work for additional information
|
@@ -55,10 +57,10 @@ module Selenium
|
|
55
57
|
def window(id)
|
56
58
|
if block_given?
|
57
59
|
original = begin
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
60
|
+
@bridge.window_handle
|
61
|
+
rescue Error::NoSuchWindowError
|
62
|
+
nil
|
63
|
+
end
|
62
64
|
|
63
65
|
unless @bridge.window_handles.include? id
|
64
66
|
raise Error::NoSuchWindowError, "The specified identifier '#{id}' is not found in the window handle list"
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
# Licensed to the Software Freedom Conservancy (SFC) under one
|
2
4
|
# or more contributor license agreements. See the NOTICE file
|
3
5
|
# distributed with this work for additional information
|
@@ -23,23 +25,20 @@ module Selenium
|
|
23
25
|
#
|
24
26
|
|
25
27
|
def initialize(mouse, keyboard, touch_screen)
|
28
|
+
WebDriver.logger.deprecate(self.class.name)
|
26
29
|
super(mouse, keyboard)
|
27
30
|
@devices[:touch_screen] = touch_screen
|
28
31
|
end
|
29
32
|
|
30
33
|
def scroll(*args)
|
31
|
-
unless [2, 3].include? args.size
|
32
|
-
raise ArgumentError, "wrong number of arguments, expected 2..3, got #{args.size}"
|
33
|
-
end
|
34
|
+
raise ArgumentError, "wrong number of arguments, expected 2..3, got #{args.size}" unless [2, 3].include? args.size
|
34
35
|
|
35
36
|
@actions << [:touch_screen, :scroll, args]
|
36
37
|
self
|
37
38
|
end
|
38
39
|
|
39
40
|
def flick(*args)
|
40
|
-
unless [2, 4].include? args.size
|
41
|
-
raise ArgumentError, "wrong number of arguments, expected 2 or 4, got #{args.size}"
|
42
|
-
end
|
41
|
+
raise ArgumentError, "wrong number of arguments, expected 2 or 4, got #{args.size}" unless [2, 4].include? args.size
|
43
42
|
|
44
43
|
@actions << [:touch_screen, :flick, args]
|
45
44
|
self
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
# Licensed to the Software Freedom Conservancy (SFC) under one
|
2
4
|
# or more contributor license agreements. See the NOTICE file
|
3
5
|
# distributed with this work for additional information
|
@@ -82,7 +84,7 @@ module Selenium
|
|
82
84
|
|
83
85
|
assert_element element
|
84
86
|
|
85
|
-
if (speed.is_a?(String) || speed.is_a?(Symbol)) && FLICK_SPEED.
|
87
|
+
if (speed.is_a?(String) || speed.is_a?(Symbol)) && FLICK_SPEED.key?(speed.to_sym)
|
86
88
|
WebDriver.logger.deprecate "Passing #{speed.inspect} speed",
|
87
89
|
"Integer or Selenium::WebDriver::TouchScreen::FLICK_SPEED[:#{speed}]"
|
88
90
|
speed = FLICK_SPEED[speed.to_sym]
|
@@ -113,6 +115,7 @@ module Selenium
|
|
113
115
|
|
114
116
|
def assert_element(element)
|
115
117
|
return if element.is_a? Element
|
118
|
+
|
116
119
|
raise TypeError, "expected #{Element}, got #{element.inspect}:#{element.class}"
|
117
120
|
end
|
118
121
|
end # TouchScreen
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
# Licensed to the Software Freedom Conservancy (SFC) under one
|
2
4
|
# or more contributor license agreements. See the NOTICE file
|
3
5
|
# distributed with this work for additional information
|
@@ -190,6 +192,7 @@ module Selenium
|
|
190
192
|
|
191
193
|
def tick(*action_devices)
|
192
194
|
return if @async
|
195
|
+
|
193
196
|
@devices.each { |device| device.create_pause unless action_devices.include? device }
|
194
197
|
end
|
195
198
|
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
# Licensed to the Software Freedom Conservancy (SFC) under one
|
2
4
|
# or more contributor license agreements. See the NOTICE file
|
3
5
|
# distributed with this work for additional information
|
@@ -17,7 +19,7 @@
|
|
17
19
|
|
18
20
|
module Selenium
|
19
21
|
module WebDriver
|
20
|
-
class
|
22
|
+
class W3CManager < Manager
|
21
23
|
|
22
24
|
#
|
23
25
|
# Get the cookie with the given name
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
# Licensed to the Software Freedom Conservancy (SFC) under one
|
2
4
|
# or more contributor license agreements. See the NOTICE file
|
3
5
|
# distributed with this work for additional information
|
@@ -41,15 +43,15 @@ module Selenium
|
|
41
43
|
#
|
42
44
|
# Wait until the given block returns a true value.
|
43
45
|
#
|
44
|
-
# @raise [Error::
|
46
|
+
# @raise [Error::TimeoutError]
|
45
47
|
# @return [Object] the result of the block
|
46
48
|
#
|
47
49
|
|
48
50
|
def until
|
49
|
-
end_time =
|
51
|
+
end_time = current_time + @timeout
|
50
52
|
last_error = nil
|
51
53
|
|
52
|
-
until
|
54
|
+
until current_time > end_time
|
53
55
|
begin
|
54
56
|
result = yield
|
55
57
|
return result if result
|
@@ -63,12 +65,18 @@ module Selenium
|
|
63
65
|
msg = if @message
|
64
66
|
@message.dup
|
65
67
|
else
|
66
|
-
"timed out after #{@timeout} seconds"
|
68
|
+
+"timed out after #{@timeout} seconds"
|
67
69
|
end
|
68
70
|
|
69
71
|
msg << " (#{last_error.message})" if last_error
|
70
72
|
|
71
|
-
raise Error::
|
73
|
+
raise Error::TimeoutError, msg
|
74
|
+
end
|
75
|
+
|
76
|
+
private
|
77
|
+
|
78
|
+
def current_time
|
79
|
+
Process.clock_gettime(Process::CLOCK_MONOTONIC)
|
72
80
|
end
|
73
81
|
end # Wait
|
74
82
|
end # WebDriver
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
# Licensed to the Software Freedom Conservancy (SFC) under one
|
2
4
|
# or more contributor license agreements. See the NOTICE file
|
3
5
|
# distributed with this work for additional information
|
@@ -50,9 +52,7 @@ module Selenium
|
|
50
52
|
def zip(path)
|
51
53
|
with_tmp_zip do |zip|
|
52
54
|
::Find.find(path) do |file|
|
53
|
-
unless File.directory?(file)
|
54
|
-
add_zip_entry zip, file, file.sub("#{path}/", '')
|
55
|
-
end
|
55
|
+
add_zip_entry zip, file, file.sub("#{path}/", '') unless File.directory?(file)
|
56
56
|
end
|
57
57
|
|
58
58
|
zip.commit
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
# Licensed to the Software Freedom Conservancy (SFC) under one
|
2
4
|
# or more contributor license agreements. See the NOTICE file
|
3
5
|
# distributed with this work for additional information
|
@@ -20,19 +22,23 @@ require 'net/http'
|
|
20
22
|
require 'selenium/webdriver/edge/bridge'
|
21
23
|
require 'selenium/webdriver/edge/driver'
|
22
24
|
require 'selenium/webdriver/edge/options'
|
23
|
-
require 'selenium/webdriver/edge/service'
|
24
25
|
|
25
26
|
module Selenium
|
26
27
|
module WebDriver
|
27
28
|
module Edge
|
28
29
|
def self.driver_path=(path)
|
29
|
-
|
30
|
-
|
30
|
+
WebDriver.logger.deprecate 'Selenium::WebDriver::Edge#driver_path=',
|
31
|
+
'Selenium::WebDriver::Edge::Service#driver_path='
|
32
|
+
Selenium::WebDriver::Edge::Service.driver_path = path
|
31
33
|
end
|
32
34
|
|
33
|
-
def self.driver_path
|
34
|
-
|
35
|
+
def self.driver_path
|
36
|
+
WebDriver.logger.deprecate 'Selenium::WebDriver::Edge#driver_path',
|
37
|
+
'Selenium::WebDriver::Edge::Service#driver_path'
|
38
|
+
Selenium::WebDriver::Edge::Service.driver_path
|
35
39
|
end
|
36
40
|
end # Edge
|
37
41
|
end # WebDriver
|
38
42
|
end # Selenium
|
43
|
+
|
44
|
+
require 'selenium/webdriver/edge/service'
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
# Licensed to the Software Freedom Conservancy (SFC) under one
|
2
4
|
# or more contributor license agreements. See the NOTICE file
|
3
5
|
# distributed with this work for additional information
|
@@ -28,18 +30,9 @@ module Selenium
|
|
28
30
|
include DriverExtensions::TakesScreenshot
|
29
31
|
|
30
32
|
def initialize(opts = {})
|
31
|
-
opts[:desired_capabilities] ||= Remote::
|
32
|
-
|
33
|
-
unless opts.key?(:url)
|
34
|
-
driver_path = opts.delete(:driver_path) || Edge.driver_path
|
35
|
-
driver_opts = opts.delete(:driver_opts) || {}
|
36
|
-
port = opts.delete(:port) || Service::DEFAULT_PORT
|
33
|
+
opts[:desired_capabilities] ||= Remote::Capabilities.edge
|
37
34
|
|
38
|
-
|
39
|
-
@service.host = 'localhost' if @service.host == '127.0.0.1'
|
40
|
-
@service.start
|
41
|
-
opts[:url] = @service.uri
|
42
|
-
end
|
35
|
+
opts[:url] ||= service_url(opts)
|
43
36
|
|
44
37
|
listener = opts.delete(:listener)
|
45
38
|
|
@@ -64,7 +57,7 @@ module Selenium
|
|
64
57
|
def quit
|
65
58
|
super
|
66
59
|
ensure
|
67
|
-
@service
|
60
|
+
@service&.stop
|
68
61
|
end
|
69
62
|
|
70
63
|
end # Driver
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
# Licensed to the Software Freedom Conservancy (SFC) under one
|
2
4
|
# or more contributor license agreements. See the NOTICE file
|
3
5
|
# distributed with this work for additional information
|
@@ -55,6 +57,7 @@ module Selenium
|
|
55
57
|
|
56
58
|
def add_extension_path(path)
|
57
59
|
raise Error::WebDriverError, "could not find extension at #{path.inspect}" unless File.directory?(path)
|
60
|
+
|
58
61
|
@extension_paths << path
|
59
62
|
end
|
60
63
|
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
# Licensed to the Software Freedom Conservancy (SFC) under one
|
2
4
|
# or more contributor license agreements. See the NOTICE file
|
3
5
|
# distributed with this work for additional information
|
@@ -23,27 +25,21 @@ module Selenium
|
|
23
25
|
#
|
24
26
|
|
25
27
|
class Service < WebDriver::Service
|
26
|
-
|
27
|
-
@executable = 'MicrosoftWebDriver'
|
28
|
-
@missing_text =
|
28
|
+
@default_port = 17556
|
29
|
+
@executable = 'MicrosoftWebDriver'
|
30
|
+
@missing_text = <<~ERROR
|
29
31
|
Unable to find MicrosoftWebDriver. Please download the server from
|
30
32
|
https://www.microsoft.com/en-us/download/details.aspx?id=48212 and place it somewhere on your PATH.
|
31
33
|
More info at https://github.com/SeleniumHQ/selenium/wiki/MicrosoftWebDriver.
|
32
34
|
ERROR
|
35
|
+
@shutdown_supported = true
|
33
36
|
|
34
37
|
private
|
35
38
|
|
36
|
-
|
37
|
-
@process = build_process(@executable_path, "--port=#{@port}", *@extra_args)
|
38
|
-
@process.start
|
39
|
-
end
|
40
|
-
|
41
|
-
def cannot_connect_error_text
|
42
|
-
"unable to connect to MicrosoftWebDriver #{@host}:#{@port}"
|
43
|
-
end
|
44
|
-
|
39
|
+
# Note: This processing is deprecated
|
45
40
|
def extract_service_args(driver_opts)
|
46
41
|
driver_args = super
|
42
|
+
driver_opts = driver_opts.dup
|
47
43
|
driver_args << "--host=#{driver_opts[:host]}" if driver_opts.key? :host
|
48
44
|
driver_args << "--package=#{driver_opts[:package]}" if driver_opts.key? :package
|
49
45
|
driver_args << "--silent" if driver_opts[:silent] == true
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
# Licensed to the Software Freedom Conservancy (SFC) under one
|
2
4
|
# or more contributor license agreements. See the NOTICE file
|
3
5
|
# distributed with this work for additional information
|
@@ -32,7 +34,6 @@ require 'selenium/webdriver/firefox/legacy/driver'
|
|
32
34
|
require 'selenium/webdriver/firefox/marionette/bridge'
|
33
35
|
require 'selenium/webdriver/firefox/marionette/driver'
|
34
36
|
require 'selenium/webdriver/firefox/options'
|
35
|
-
require 'selenium/webdriver/firefox/service'
|
36
37
|
|
37
38
|
module Selenium
|
38
39
|
module WebDriver
|
@@ -44,12 +45,15 @@ module Selenium
|
|
44
45
|
DEFAULT_LOAD_NO_FOCUS_LIB = false
|
45
46
|
|
46
47
|
def self.driver_path=(path)
|
47
|
-
|
48
|
-
|
48
|
+
WebDriver.logger.deprecate 'Selenium::WebDriver::Firefox#driver_path=',
|
49
|
+
'Selenium::WebDriver::Firefox::Service#driver_path='
|
50
|
+
Selenium::WebDriver::Firefox::Service.driver_path = path
|
49
51
|
end
|
50
52
|
|
51
53
|
def self.driver_path
|
52
|
-
|
54
|
+
WebDriver.logger.deprecate 'Selenium::WebDriver::Firefox#driver_path',
|
55
|
+
'Selenium::WebDriver::Firefox::Service#driver_path'
|
56
|
+
Selenium::WebDriver::Firefox::Service.driver_path
|
53
57
|
end
|
54
58
|
|
55
59
|
def self.path=(path)
|
@@ -58,3 +62,5 @@ module Selenium
|
|
58
62
|
end # Firefox
|
59
63
|
end # WebDriver
|
60
64
|
end # Selenium
|
65
|
+
|
66
|
+
require 'selenium/webdriver/firefox/service'
|