appium_lib_core 5.0.0.beta1 → 5.0.0.beta2
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.
- checksums.yaml +4 -4
- data/appium_lib_core.gemspec +1 -1
- data/lib/appium_lib_core.rb +1 -4
- data/lib/appium_lib_core/common/base.rb +0 -2
- data/lib/appium_lib_core/common/base/bridge.rb +261 -1
- data/lib/appium_lib_core/common/base/driver.rb +9 -12
- data/lib/appium_lib_core/common/command.rb +259 -3
- data/lib/appium_lib_core/device.rb +1 -1
- data/lib/appium_lib_core/{patch.rb → element.rb} +2 -7
- data/lib/appium_lib_core/ios/uiautomation/patch.rb +1 -1
- data/lib/appium_lib_core/version.rb +2 -2
- data/script/commands.rb +1 -12
- metadata +5 -9
- data/lib/appium_lib_core/common/base/bridge/w3c.rb +0 -348
- data/lib/appium_lib_core/common/base/command.rb +0 -145
- data/lib/appium_lib_core/common/command/common.rb +0 -110
- data/lib/appium_lib_core/common/command/w3c.rb +0 -56
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 53abadd3b91fdcaac0c23f62bbc83b0e21ea08a50da28394a504d6839d36d2e7
|
4
|
+
data.tar.gz: 9bc2cda2b1fa8be1d602cd7ab9943594f9b4a1fce0ea5a4527491563c3687fd2
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 313ae53035edd0273b8d122325c77d031a186c5a9f60b57956ad0f204165cc8ca60420ce2a910dc28d9e0b5000fa9131262fbe4a2b796e4e4d7bd09d9e40e941
|
7
|
+
data.tar.gz: deb1d0d9c9aba7cc7a9b6040dbdbcf76896d5a0ce786a8ac419b436a11a90e1960893e2f6683a78efee7d3a8044d5eb19414d527123778cebd088a437b6a4215
|
data/appium_lib_core.gemspec
CHANGED
@@ -31,7 +31,7 @@ Gem::Specification.new do |spec|
|
|
31
31
|
spec.add_development_dependency 'minitest', '~> 5.0'
|
32
32
|
spec.add_development_dependency 'minitest-reporters', '~> 1.1'
|
33
33
|
spec.add_development_dependency 'webmock', '~> 3.12.1'
|
34
|
-
spec.add_development_dependency 'rubocop', '1.
|
34
|
+
spec.add_development_dependency 'rubocop', '1.12.0'
|
35
35
|
spec.add_development_dependency 'appium_thor', '~> 1.0'
|
36
36
|
spec.add_development_dependency 'pry'
|
37
37
|
spec.add_development_dependency 'pry-byebug'
|
data/lib/appium_lib_core.rb
CHANGED
@@ -17,11 +17,8 @@ require 'selenium-webdriver'
|
|
17
17
|
require_relative 'appium_lib_core/version'
|
18
18
|
require_relative 'appium_lib_core/common'
|
19
19
|
require_relative 'appium_lib_core/driver'
|
20
|
-
|
21
20
|
require_relative 'appium_lib_core/device'
|
22
|
-
|
23
|
-
# Call patch after requiring other files
|
24
|
-
require_relative 'appium_lib_core/patch'
|
21
|
+
require_relative 'appium_lib_core/element'
|
25
22
|
|
26
23
|
module Appium
|
27
24
|
# convert all keys (including nested) to symbols
|
@@ -34,9 +34,7 @@ require_relative 'device/orientation'
|
|
34
34
|
# The following files have selenium-webdriver related stuff.
|
35
35
|
require_relative 'base/driver'
|
36
36
|
require_relative 'base/bridge'
|
37
|
-
require_relative 'base/bridge/w3c'
|
38
37
|
require_relative 'base/capabilities'
|
39
38
|
require_relative 'base/http_default'
|
40
39
|
require_relative 'base/search_context'
|
41
|
-
require_relative 'base/command'
|
42
40
|
require_relative 'base/platform'
|
@@ -16,11 +16,36 @@ module Appium
|
|
16
16
|
module Core
|
17
17
|
class Base
|
18
18
|
class Bridge < ::Selenium::WebDriver::Remote::Bridge
|
19
|
-
|
19
|
+
include Device::DeviceLock
|
20
|
+
include Device::Keyboard
|
21
|
+
include Device::ImeActions
|
22
|
+
include Device::Setting
|
23
|
+
include Device::Context
|
24
|
+
include Device::Value
|
25
|
+
include Device::FileManagement
|
26
|
+
include Device::KeyEvent
|
27
|
+
include Device::ImageComparison
|
28
|
+
include Device::AppManagement
|
29
|
+
include Device::AppState
|
30
|
+
include Device::ScreenRecord::Command
|
31
|
+
include Device::Device
|
32
|
+
include Device::TouchActions
|
33
|
+
include Device::ExecuteDriver
|
34
|
+
include Device::Orientation
|
20
35
|
|
21
36
|
# Prefix for extra capability defined by W3C
|
22
37
|
APPIUM_PREFIX = 'appium:'
|
23
38
|
|
39
|
+
# Returns 'unknown' if no specific browser name
|
40
|
+
def browser
|
41
|
+
@browser ||= begin
|
42
|
+
name = @capabilities.browser_name
|
43
|
+
name ? name.tr(' ', '_').downcase.to_sym : 'unknown'
|
44
|
+
rescue KeyError
|
45
|
+
'unknown'
|
46
|
+
end
|
47
|
+
end
|
48
|
+
|
24
49
|
# Override
|
25
50
|
# Creates session handling both OSS and W3C dialects.
|
26
51
|
#
|
@@ -99,6 +124,241 @@ module Appium
|
|
99
124
|
def json_create(value)
|
100
125
|
::Selenium::WebDriver::Remote::Capabilities.json_create(value)
|
101
126
|
end
|
127
|
+
|
128
|
+
public
|
129
|
+
|
130
|
+
def commands(command)
|
131
|
+
::Appium::Core::Commands::COMMANDS[command]
|
132
|
+
end
|
133
|
+
|
134
|
+
# Returns all available sessions on the Appium server instance
|
135
|
+
def sessions
|
136
|
+
execute :get_all_sessions
|
137
|
+
end
|
138
|
+
|
139
|
+
def status
|
140
|
+
execute :status
|
141
|
+
end
|
142
|
+
|
143
|
+
# Perform touch actions for W3C module.
|
144
|
+
# Generate +touch+ pointer action here and users can use this via +driver.action+
|
145
|
+
# - https://seleniumhq.github.io/selenium/docs/api/rb/Selenium/WebDriver/W3CActionBuilder.html
|
146
|
+
# - https://seleniumhq.github.io/selenium/docs/api/rb/Selenium/WebDriver/PointerActions.html
|
147
|
+
# - https://seleniumhq.github.io/selenium/docs/api/rb/Selenium/WebDriver/KeyActions.html
|
148
|
+
#
|
149
|
+
# 'mouse' action is by default in the Ruby client. Appium server force the +mouse+ action to +touch+ once in
|
150
|
+
# the server side. So we don't consider the case.
|
151
|
+
#
|
152
|
+
# @example
|
153
|
+
#
|
154
|
+
# element = @driver.find_element(:id, "some id")
|
155
|
+
# @driver.action.click(element).perform # The 'click' is a part of 'PointerActions'
|
156
|
+
#
|
157
|
+
def action(async = false)
|
158
|
+
# Used for default duration of each touch actions
|
159
|
+
# Override from 250 milliseconds to 50 milliseconds
|
160
|
+
action_builder = super
|
161
|
+
action_builder.default_move_duration = 0.05
|
162
|
+
action_builder
|
163
|
+
end
|
164
|
+
|
165
|
+
# Port from MJSONWP
|
166
|
+
def get_timeouts
|
167
|
+
execute :get_timeouts
|
168
|
+
end
|
169
|
+
|
170
|
+
# Port from MJSONWP
|
171
|
+
def session_capabilities
|
172
|
+
::Selenium::WebDriver::Remote::Capabilities.json_create execute(:get_capabilities)
|
173
|
+
end
|
174
|
+
|
175
|
+
# Port from MJSONWP
|
176
|
+
def send_keys_to_active_element(key)
|
177
|
+
text = ::Selenium::WebDriver::Keys.encode(key).join('')
|
178
|
+
execute :send_keys_to_active_element, {}, { value: text.split(//) }
|
179
|
+
end
|
180
|
+
|
181
|
+
# For Appium
|
182
|
+
# override
|
183
|
+
def page_source
|
184
|
+
# For W3C
|
185
|
+
# execute_script('var source = document.documentElement.outerHTML;' \
|
186
|
+
# 'if (!source) { source = new XMLSerializer().serializeToString(document); }' \
|
187
|
+
# 'return source;')
|
188
|
+
execute :get_page_source
|
189
|
+
end
|
190
|
+
|
191
|
+
# For Appium
|
192
|
+
# override
|
193
|
+
def element_displayed?(element)
|
194
|
+
# For W3C
|
195
|
+
# https://github.com/SeleniumHQ/selenium/commit/b618499adcc3a9f667590652c5757c0caa703289
|
196
|
+
# execute_atom :isDisplayed, element
|
197
|
+
execute :is_element_displayed, id: element.ref
|
198
|
+
end
|
199
|
+
|
200
|
+
# For Appium
|
201
|
+
# override
|
202
|
+
def element_attribute(element, name)
|
203
|
+
# For W3C in Selenium Client
|
204
|
+
# execute_atom :getAttribute, element, name
|
205
|
+
execute :get_element_attribute, id: element.ref, name: name
|
206
|
+
end
|
207
|
+
|
208
|
+
# For Appium
|
209
|
+
# override
|
210
|
+
def active_element
|
211
|
+
::Appium::Core::Element.new self, element_id_from(execute(:get_active_element))
|
212
|
+
end
|
213
|
+
alias switch_to_active_element active_element
|
214
|
+
|
215
|
+
# For Appium
|
216
|
+
# override
|
217
|
+
def find_element_by(how, what, parent = nil)
|
218
|
+
how, what = convert_locators(how, what)
|
219
|
+
|
220
|
+
id = if parent
|
221
|
+
execute :find_child_element, { id: parent }, { using: how, value: what }
|
222
|
+
else
|
223
|
+
execute :find_element, {}, { using: how, value: what }
|
224
|
+
end
|
225
|
+
::Appium::Core::Element.new self, element_id_from(id)
|
226
|
+
end
|
227
|
+
|
228
|
+
# For Appium
|
229
|
+
# override
|
230
|
+
def find_elements_by(how, what, parent = nil)
|
231
|
+
how, what = convert_locators(how, what)
|
232
|
+
|
233
|
+
ids = if parent
|
234
|
+
execute :find_child_elements, { id: parent }, { using: how, value: what }
|
235
|
+
else
|
236
|
+
execute :find_elements, {}, { using: how, value: what }
|
237
|
+
end
|
238
|
+
|
239
|
+
ids.map { |id| ::Appium::Core::Element.new self, element_id_from(id) }
|
240
|
+
end
|
241
|
+
|
242
|
+
# For Appium
|
243
|
+
# @param [Hash] id The id which can get as a response from server
|
244
|
+
# @return [::Appium::Core::Element]
|
245
|
+
def convert_to_element(id)
|
246
|
+
::Appium::Core::Element.new self, element_id_from(id)
|
247
|
+
end
|
248
|
+
|
249
|
+
# For Appium
|
250
|
+
# override
|
251
|
+
# called in 'extend DriverExtensions::HasNetworkConnection'
|
252
|
+
def network_connection
|
253
|
+
execute :get_network_connection
|
254
|
+
end
|
255
|
+
|
256
|
+
# For Appium
|
257
|
+
# override
|
258
|
+
# called in 'extend DriverExtensions::HasNetworkConnection'
|
259
|
+
def network_connection=(type)
|
260
|
+
execute :set_network_connection, {}, { parameters: { type: type } }
|
261
|
+
end
|
262
|
+
|
263
|
+
# For Appium
|
264
|
+
# No implementation for W3C webdriver module
|
265
|
+
# called in 'extend DriverExtensions::HasLocation'
|
266
|
+
def location
|
267
|
+
obj = execute(:get_location) || {}
|
268
|
+
::Selenium::WebDriver::Location.new obj['latitude'], obj['longitude'], obj['altitude']
|
269
|
+
end
|
270
|
+
|
271
|
+
# For Appium
|
272
|
+
# No implementation for W3C webdriver module
|
273
|
+
def set_location(lat, lon, alt = 0.0, speed: nil)
|
274
|
+
loc = { latitude: lat, longitude: lon, altitude: alt }
|
275
|
+
loc[:speed] = speed unless speed.nil?
|
276
|
+
execute :set_location, {}, { location: loc }
|
277
|
+
end
|
278
|
+
|
279
|
+
#
|
280
|
+
# logs
|
281
|
+
#
|
282
|
+
# For Appium
|
283
|
+
# No implementation for W3C webdriver module
|
284
|
+
def available_log_types
|
285
|
+
types = execute :get_available_log_types
|
286
|
+
Array(types).map(&:to_sym)
|
287
|
+
end
|
288
|
+
|
289
|
+
# For Appium
|
290
|
+
# No implementation for W3C webdriver module
|
291
|
+
def log(type)
|
292
|
+
data = execute :get_log, {}, { type: type.to_s }
|
293
|
+
|
294
|
+
Array(data).map do |l|
|
295
|
+
begin
|
296
|
+
::Selenium::WebDriver::LogEntry.new l.fetch('level', 'UNKNOWN'), l.fetch('timestamp'), l.fetch('message')
|
297
|
+
rescue KeyError
|
298
|
+
next
|
299
|
+
end
|
300
|
+
end
|
301
|
+
end
|
302
|
+
|
303
|
+
# For Appium
|
304
|
+
def log_event(vendor, event)
|
305
|
+
execute :post_log_event, {}, { vendor: vendor, event: event }
|
306
|
+
end
|
307
|
+
|
308
|
+
# For Appium
|
309
|
+
def log_events(type = nil)
|
310
|
+
args = {}
|
311
|
+
args['type'] = type unless type.nil?
|
312
|
+
|
313
|
+
execute :get_log_events, {}, args
|
314
|
+
end
|
315
|
+
|
316
|
+
def take_viewport_screenshot
|
317
|
+
execute_script('mobile: viewportScreenshot')
|
318
|
+
end
|
319
|
+
|
320
|
+
def take_element_screenshot(element)
|
321
|
+
execute :take_element_screenshot, id: element.ref
|
322
|
+
end
|
323
|
+
|
324
|
+
private
|
325
|
+
|
326
|
+
def unwrap_script_result(arg)
|
327
|
+
case arg
|
328
|
+
when Array
|
329
|
+
arg.map { |e| unwrap_script_result(e) }
|
330
|
+
when Hash
|
331
|
+
element_id = element_id_from(arg)
|
332
|
+
return ::Appium::Core::Element.new(self, element_id) if element_id
|
333
|
+
|
334
|
+
arg.each { |k, v| arg[k] = unwrap_script_result(v) }
|
335
|
+
else
|
336
|
+
arg
|
337
|
+
end
|
338
|
+
end
|
339
|
+
|
340
|
+
def element_id_from(id)
|
341
|
+
id['ELEMENT'] || id['element-6066-11e4-a52e-4f735466cecf']
|
342
|
+
end
|
343
|
+
|
344
|
+
# Don't convert locators for Appium Client
|
345
|
+
# TODO: Only for Appium. Ideally, we'd like to keep the selenium-webdriver
|
346
|
+
def convert_locators(how, what)
|
347
|
+
# case how
|
348
|
+
# when 'class name'
|
349
|
+
# how = 'css selector'
|
350
|
+
# what = ".#{escape_css(what)}"
|
351
|
+
# when 'id'
|
352
|
+
# how = 'css selector'
|
353
|
+
# what = "##{escape_css(what)}"
|
354
|
+
# when 'name'
|
355
|
+
# how = 'css selector'
|
356
|
+
# what = "*[name='#{escape_css(what)}']"
|
357
|
+
# when 'tag name'
|
358
|
+
# how = 'css selector'
|
359
|
+
# end
|
360
|
+
[how, what]
|
361
|
+
end
|
102
362
|
end # class Bridge
|
103
363
|
end # class Base
|
104
364
|
end # module Core
|
@@ -36,6 +36,8 @@ module Appium
|
|
36
36
|
include ::Appium::Core::Base::HasLocation
|
37
37
|
include ::Appium::Core::Base::HasNetworkConnection
|
38
38
|
|
39
|
+
private
|
40
|
+
|
39
41
|
# Private API.
|
40
42
|
# Do not use this for general use. Used by flutter driver to get bridge for creating a new element
|
41
43
|
attr_reader :bridge
|
@@ -48,9 +50,8 @@ module Appium
|
|
48
50
|
# 2. Sniffs response.
|
49
51
|
# 3. Based on the response, understands which dialect we should use.
|
50
52
|
#
|
51
|
-
# @return [Bridge
|
53
|
+
# @return [::Appium::Core::Base::Bridge]
|
52
54
|
#
|
53
|
-
# TODO: Fixme
|
54
55
|
def create_bridge(**opts)
|
55
56
|
opts[:url] ||= service_url(opts)
|
56
57
|
caps = opts.delete(:capabilities)
|
@@ -73,17 +74,13 @@ module Appium
|
|
73
74
|
bridge_opts = { http_client: opts.delete(:http_client), url: opts.delete(:url) }
|
74
75
|
raise ArgumentError, "Unable to create a driver with parameters: #{opts}" unless opts.empty?
|
75
76
|
|
76
|
-
bridge = ::Appium::Core::Base::Bridge
|
77
|
+
bridge = ::Appium::Core::Base::Bridge.new(**bridge_opts)
|
77
78
|
|
78
79
|
bridge.create_session(capabilities)
|
79
80
|
bridge
|
80
81
|
end
|
81
82
|
|
82
|
-
|
83
|
-
# @return [:oss|:w3c]
|
84
|
-
def dialect
|
85
|
-
@bridge.dialect
|
86
|
-
end
|
83
|
+
public
|
87
84
|
|
88
85
|
# Update +server_url+ and HTTP clients following this arguments, protocol, host, port and path.
|
89
86
|
# After this method, +@bridge.http+ will be a new instance following them instead of +server_url+ which is
|
@@ -1074,7 +1071,7 @@ module Appium
|
|
1074
1071
|
#
|
1075
1072
|
# @param [String] img_path A path to a partial image you'd like to find
|
1076
1073
|
#
|
1077
|
-
# @return [::
|
1074
|
+
# @return [::Appium::Core::Element]
|
1078
1075
|
#
|
1079
1076
|
# @example
|
1080
1077
|
#
|
@@ -1144,14 +1141,14 @@ module Appium
|
|
1144
1141
|
@bridge.execute_driver(script: script, type: type, timeout_ms: timeout_ms)
|
1145
1142
|
end
|
1146
1143
|
|
1147
|
-
# Convert vanilla element response to ::
|
1144
|
+
# Convert vanilla element response to ::Appium::Core::Element
|
1148
1145
|
#
|
1149
1146
|
# @param [Hash] id The id which can get as a response from server
|
1150
|
-
# @return [::
|
1147
|
+
# @return [::Appium::Core::Element]
|
1151
1148
|
#
|
1152
1149
|
# @example
|
1153
1150
|
# response = {"element-6066-11e4-a52e-4f735466cecf"=>"xxxx", "ELEMENT"=>"xxxx"}
|
1154
|
-
# ele = @driver.convert_to_element(response) #=> ::
|
1151
|
+
# ele = @driver.convert_to_element(response) #=> ::Appium::Core::Element
|
1155
1152
|
# ele.rect #=> Can get the rect of the element
|
1156
1153
|
#
|
1157
1154
|
def convert_to_element(id)
|
@@ -12,6 +12,262 @@
|
|
12
12
|
# See the License for the specific language governing permissions and
|
13
13
|
# limitations under the License.
|
14
14
|
|
15
|
-
|
16
|
-
|
17
|
-
|
15
|
+
module Appium
|
16
|
+
module Core
|
17
|
+
# ref: https://github.com/appium/appium-base-driver/blob/master/lib/mjsonwp/routes.js
|
18
|
+
module Commands
|
19
|
+
# Some commands differ for each driver.
|
20
|
+
COMMAND = {
|
21
|
+
###
|
22
|
+
# W3C
|
23
|
+
###
|
24
|
+
status: [:get, 'status'],
|
25
|
+
|
26
|
+
#
|
27
|
+
# session handling
|
28
|
+
#
|
29
|
+
|
30
|
+
new_session: [:post, 'session'],
|
31
|
+
delete_session: [:delete, 'session/:session_id'],
|
32
|
+
|
33
|
+
#
|
34
|
+
# basic driver
|
35
|
+
#
|
36
|
+
|
37
|
+
get: [:post, 'session/:session_id/url'],
|
38
|
+
get_current_url: [:get, 'session/:session_id/url'],
|
39
|
+
back: [:post, 'session/:session_id/back'],
|
40
|
+
forward: [:post, 'session/:session_id/forward'],
|
41
|
+
refresh: [:post, 'session/:session_id/refresh'],
|
42
|
+
get_title: [:get, 'session/:session_id/title'],
|
43
|
+
|
44
|
+
#
|
45
|
+
# window and Frame handling
|
46
|
+
#
|
47
|
+
|
48
|
+
get_window_handle: [:get, 'session/:session_id/window'],
|
49
|
+
new_window: [:post, 'session/:session_id/window/new'],
|
50
|
+
close_window: [:delete, 'session/:session_id/window'],
|
51
|
+
switch_to_window: [:post, 'session/:session_id/window'],
|
52
|
+
get_window_handles: [:get, 'session/:session_id/window/handles'],
|
53
|
+
fullscreen_window: [:post, 'session/:session_id/window/fullscreen'],
|
54
|
+
minimize_window: [:post, 'session/:session_id/window/minimize'],
|
55
|
+
maximize_window: [:post, 'session/:session_id/window/maximize'],
|
56
|
+
set_window_size: [:post, 'session/:session_id/window/size'],
|
57
|
+
get_window_size: [:get, 'session/:session_id/window/size'],
|
58
|
+
set_window_position: [:post, 'session/:session_id/window/position'],
|
59
|
+
get_window_position: [:get, 'session/:session_id/window/position'],
|
60
|
+
set_window_rect: [:post, 'session/:session_id/window/rect'],
|
61
|
+
get_window_rect: [:get, 'session/:session_id/window/rect'],
|
62
|
+
switch_to_frame: [:post, 'session/:session_id/frame'],
|
63
|
+
switch_to_parent_frame: [:post, 'session/:session_id/frame/parent'],
|
64
|
+
|
65
|
+
#
|
66
|
+
# element
|
67
|
+
#
|
68
|
+
|
69
|
+
find_element: [:post, 'session/:session_id/element'],
|
70
|
+
find_elements: [:post, 'session/:session_id/elements'],
|
71
|
+
find_child_element: [:post, 'session/:session_id/element/:id/element'],
|
72
|
+
find_child_elements: [:post, 'session/:session_id/element/:id/elements'],
|
73
|
+
get_active_element: [:get, 'session/:session_id/element/active'],
|
74
|
+
is_element_selected: [:get, 'session/:session_id/element/:id/selected'],
|
75
|
+
get_element_attribute: [:get, 'session/:session_id/element/:id/attribute/:name'],
|
76
|
+
get_element_property: [:get, 'session/:session_id/element/:id/property/:name'],
|
77
|
+
get_element_css_value: [:get, 'session/:session_id/element/:id/css/:property_name'],
|
78
|
+
get_element_text: [:get, 'session/:session_id/element/:id/text'],
|
79
|
+
get_element_tag_name: [:get, 'session/:session_id/element/:id/name'],
|
80
|
+
get_element_rect: [:get, 'session/:session_id/element/:id/rect'],
|
81
|
+
is_element_enabled: [:get, 'session/:session_id/element/:id/enabled'],
|
82
|
+
|
83
|
+
#
|
84
|
+
# document handling
|
85
|
+
#
|
86
|
+
|
87
|
+
get_page_source: [:get, 'session/:session_id/source'],
|
88
|
+
execute_script: [:post, 'session/:session_id/execute/sync'],
|
89
|
+
execute_async_script: [:post, 'session/:session_id/execute/async'],
|
90
|
+
|
91
|
+
#
|
92
|
+
# cookies
|
93
|
+
#
|
94
|
+
|
95
|
+
get_all_cookies: [:get, 'session/:session_id/cookie'],
|
96
|
+
get_cookie: [:get, 'session/:session_id/cookie/:name'],
|
97
|
+
add_cookie: [:post, 'session/:session_id/cookie'],
|
98
|
+
delete_cookie: [:delete, 'session/:session_id/cookie/:name'],
|
99
|
+
delete_all_cookies: [:delete, 'session/:session_id/cookie'],
|
100
|
+
|
101
|
+
#
|
102
|
+
# timeouts
|
103
|
+
#
|
104
|
+
|
105
|
+
set_timeout: [:post, 'session/:session_id/timeouts'],
|
106
|
+
|
107
|
+
#
|
108
|
+
# actions
|
109
|
+
#
|
110
|
+
|
111
|
+
actions: [:post, 'session/:session_id/actions'],
|
112
|
+
release_actions: [:delete, 'session/:session_id/actions'],
|
113
|
+
print_page: [:post, 'session/:session_id/print'],
|
114
|
+
|
115
|
+
#
|
116
|
+
# Element Operations
|
117
|
+
#
|
118
|
+
|
119
|
+
element_click: [:post, 'session/:session_id/element/:id/click'],
|
120
|
+
element_tap: [:post, 'session/:session_id/element/:id/tap'],
|
121
|
+
element_clear: [:post, 'session/:session_id/element/:id/clear'],
|
122
|
+
element_send_keys: [:post, 'session/:session_id/element/:id/value'],
|
123
|
+
|
124
|
+
#
|
125
|
+
# alerts
|
126
|
+
#
|
127
|
+
|
128
|
+
dismiss_alert: [:post, 'session/:session_id/alert/dismiss'],
|
129
|
+
accept_alert: [:post, 'session/:session_id/alert/accept'],
|
130
|
+
get_alert_text: [:get, 'session/:session_id/alert/text'],
|
131
|
+
send_alert_text: [:post, 'session/:session_id/alert/text'],
|
132
|
+
|
133
|
+
#
|
134
|
+
# screenshot
|
135
|
+
#
|
136
|
+
|
137
|
+
take_screenshot: [:get, 'session/:session_id/screenshot'],
|
138
|
+
take_element_screenshot: [:get, 'session/:session_id/element/:id/screenshot'],
|
139
|
+
|
140
|
+
#
|
141
|
+
# server extensions
|
142
|
+
#
|
143
|
+
|
144
|
+
upload_file: [:post, 'session/:session_id/se/file'],
|
145
|
+
|
146
|
+
###
|
147
|
+
# Used by Appium, but no in W3C
|
148
|
+
###
|
149
|
+
|
150
|
+
# ::Appium::Core::Base::Commands::OSS has the following commands and Appium also use them.
|
151
|
+
# Delegated to ::Appium::Core::Base::Commands::OSS commands
|
152
|
+
is_element_displayed: [:get, 'session/:session_id/element/:id/displayed'], # hint: https://w3c.github.io/webdriver/#element-displayedness
|
153
|
+
|
154
|
+
get_timeouts: [:get, 'session/:session_id/timeouts'], # https://w3c.github.io/webdriver/#get-timeouts
|
155
|
+
|
156
|
+
# Add OSS commands to W3C commands. We can remove them if we would like to remove them from W3C module.
|
157
|
+
### Session capability
|
158
|
+
get_capabilities: [:get, 'session/:session_id'],
|
159
|
+
|
160
|
+
### rotatable
|
161
|
+
get_screen_orientation: [:get, 'session/:session_id/orientation'],
|
162
|
+
set_screen_orientation: [:post, 'session/:session_id/orientation'],
|
163
|
+
|
164
|
+
get_location: [:get, 'session/:session_id/location'],
|
165
|
+
set_location: [:post, 'session/:session_id/location'],
|
166
|
+
|
167
|
+
### For IME
|
168
|
+
ime_get_available_engines: [:get, 'session/:session_id/ime/available_engines'],
|
169
|
+
ime_get_active_engine: [:get, 'session/:session_id/ime/active_engine'],
|
170
|
+
ime_is_activated: [:get, 'session/:session_id/ime/activated'],
|
171
|
+
ime_deactivate: [:post, 'session/:session_id/ime/deactivate'],
|
172
|
+
ime_activate_engine: [:post, 'session/:session_id/ime/activate'],
|
173
|
+
|
174
|
+
send_keys_to_active_element: [:post, 'session/:session_id/keys'],
|
175
|
+
|
176
|
+
### Logs
|
177
|
+
get_available_log_types: [:get, 'session/:session_id/log/types'],
|
178
|
+
get_log: [:post, 'session/:session_id/log'],
|
179
|
+
|
180
|
+
###
|
181
|
+
# Appium own
|
182
|
+
###
|
183
|
+
|
184
|
+
# common
|
185
|
+
get_all_sessions: [:get, 'sessions'],
|
186
|
+
available_contexts: [:get, 'session/:session_id/contexts'],
|
187
|
+
set_context: [:post, 'session/:session_id/context'],
|
188
|
+
current_context: [:get, 'session/:session_id/context'],
|
189
|
+
|
190
|
+
touch_actions: [:post, 'session/:session_id/touch/perform'],
|
191
|
+
multi_touch: [:post, 'session/:session_id/touch/multi/perform'],
|
192
|
+
|
193
|
+
set_immediate_value: [:post, 'session/:session_id/appium/element/:id/value'],
|
194
|
+
replace_value: [:post, 'session/:session_id/appium/element/:id/replace_value'],
|
195
|
+
|
196
|
+
launch_app: [:post, 'session/:session_id/appium/app/launch'],
|
197
|
+
close_app: [:post, 'session/:session_id/appium/app/close'],
|
198
|
+
reset: [:post, 'session/:session_id/appium/app/reset'],
|
199
|
+
background_app: [:post, 'session/:session_id/appium/app/background'],
|
200
|
+
app_strings: [:post, 'session/:session_id/appium/app/strings'],
|
201
|
+
|
202
|
+
device_locked?: [:post, 'session/:session_id/appium/device/is_locked'],
|
203
|
+
unlock: [:post, 'session/:session_id/appium/device/unlock'],
|
204
|
+
lock: [:post, 'session/:session_id/appium/device/lock'],
|
205
|
+
device_time: [:get, 'session/:session_id/appium/device/system_time'],
|
206
|
+
install_app: [:post, 'session/:session_id/appium/device/install_app'],
|
207
|
+
remove_app: [:post, 'session/:session_id/appium/device/remove_app'],
|
208
|
+
app_installed?: [:post, 'session/:session_id/appium/device/app_installed'],
|
209
|
+
activate_app: [:post, 'session/:session_id/appium/device/activate_app'],
|
210
|
+
terminate_app: [:post, 'session/:session_id/appium/device/terminate_app'],
|
211
|
+
app_state: [:post, 'session/:session_id/appium/device/app_state'],
|
212
|
+
shake: [:post, 'session/:session_id/appium/device/shake'],
|
213
|
+
hide_keyboard: [:post, 'session/:session_id/appium/device/hide_keyboard'],
|
214
|
+
press_keycode: [:post, 'session/:session_id/appium/device/press_keycode'],
|
215
|
+
long_press_keycode: [:post, 'session/:session_id/appium/device/long_press_keycode'],
|
216
|
+
# keyevent is only for Selendroid
|
217
|
+
keyevent: [:post, 'session/:session_id/appium/device/keyevent'],
|
218
|
+
push_file: [:post, 'session/:session_id/appium/device/push_file'],
|
219
|
+
pull_file: [:post, 'session/:session_id/appium/device/pull_file'],
|
220
|
+
pull_folder: [:post, 'session/:session_id/appium/device/pull_folder'],
|
221
|
+
get_clipboard: [:post, 'session/:session_id/appium/device/get_clipboard'],
|
222
|
+
set_clipboard: [:post, 'session/:session_id/appium/device/set_clipboard'],
|
223
|
+
finger_print: [:post, 'session/:session_id/appium/device/finger_print'],
|
224
|
+
get_settings: [:get, 'session/:session_id/appium/settings'],
|
225
|
+
update_settings: [:post, 'session/:session_id/appium/settings'],
|
226
|
+
stop_recording_screen: [:post, 'session/:session_id/appium/stop_recording_screen'],
|
227
|
+
start_recording_screen: [:post, 'session/:session_id/appium/start_recording_screen'],
|
228
|
+
compare_images: [:post, 'session/:session_id/appium/compare_images'],
|
229
|
+
is_keyboard_shown: [:get, 'session/:session_id/appium/device/is_keyboard_shown'],
|
230
|
+
execute_driver: [:post, 'session/:session_id/appium/execute_driver'],
|
231
|
+
post_log_event: [:post, 'session/:session_id/appium/log_event'],
|
232
|
+
get_log_events: [:post, 'session/:session_id/appium/events']
|
233
|
+
}.freeze
|
234
|
+
|
235
|
+
COMMAND_ANDROID = {
|
236
|
+
open_notifications: [:post, 'session/:session_id/appium/device/open_notifications'],
|
237
|
+
toggle_airplane_mode: [:post, 'session/:session_id/appium/device/toggle_airplane_mode'],
|
238
|
+
start_activity: [:post, 'session/:session_id/appium/device/start_activity'],
|
239
|
+
current_activity: [:get, 'session/:session_id/appium/device/current_activity'],
|
240
|
+
current_package: [:get, 'session/:session_id/appium/device/current_package'],
|
241
|
+
get_system_bars: [:get, 'session/:session_id/appium/device/system_bars'],
|
242
|
+
get_display_density: [:get, 'session/:session_id/appium/device/display_density'],
|
243
|
+
toggle_wifi: [:post, 'session/:session_id/appium/device/toggle_wifi'],
|
244
|
+
toggle_data: [:post, 'session/:session_id/appium/device/toggle_data'],
|
245
|
+
toggle_location_services: [:post, 'session/:session_id/appium/device/toggle_location_services'],
|
246
|
+
end_coverage: [:post, 'session/:session_id/appium/app/end_test_coverage'],
|
247
|
+
get_performance_data_types: [:post, 'session/:session_id/appium/performanceData/types'],
|
248
|
+
get_performance_data: [:post, 'session/:session_id/appium/getPerformanceData'],
|
249
|
+
get_network_connection: [:get, 'session/:session_id/network_connection'], # defined also in OSS
|
250
|
+
set_network_connection: [:post, 'session/:session_id/network_connection'], # defined also in OSS
|
251
|
+
|
252
|
+
# only emulator
|
253
|
+
send_sms: [:post, 'session/:session_id/appium/device/send_sms'],
|
254
|
+
gsm_call: [:post, 'session/:session_id/appium/device/gsm_call'],
|
255
|
+
gsm_signal: [:post, 'session/:session_id/appium/device/gsm_signal'],
|
256
|
+
gsm_voice: [:post, 'session/:session_id/appium/device/gsm_voice'],
|
257
|
+
set_network_speed: [:post, 'session/:session_id/appium/device/network_speed'],
|
258
|
+
set_power_capacity: [:post, 'session/:session_id/appium/device/power_capacity'],
|
259
|
+
set_power_ac: [:post, 'session/:session_id/appium/device/power_ac'],
|
260
|
+
|
261
|
+
# For chromium: https://chromium.googlesource.com/chromium/src/+/master/chrome/test/chromedriver/server/http_handler.cc
|
262
|
+
chrome_send_command: [:post, 'session/:session_id/goog/cdp/execute']
|
263
|
+
}.freeze
|
264
|
+
|
265
|
+
COMMAND_IOS = {
|
266
|
+
touch_id: [:post, 'session/:session_id/appium/simulator/touch_id'],
|
267
|
+
toggle_touch_id_enrollment: [:post, 'session/:session_id/appium/simulator/toggle_touch_id_enrollment']
|
268
|
+
}.freeze
|
269
|
+
|
270
|
+
COMMANDS = {}.merge(COMMAND).merge(COMMAND_ANDROID).merge(COMMAND_IOS).freeze
|
271
|
+
end # module Commands
|
272
|
+
end # module Core
|
273
|
+
end # module Appium
|