watir 6.10.1 → 6.10.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.document +5 -5
- data/.github/ISSUE_TEMPLATE.md +16 -16
- data/.gitignore +21 -21
- data/.travis.yml +72 -72
- data/CHANGES.md +4 -0
- data/Gemfile +16 -16
- data/LICENSE +23 -23
- data/README.md +106 -106
- data/Rakefile +153 -153
- data/appveyor.yml +13 -13
- data/lib/watir-webdriver.rb +2 -2
- data/lib/watir.rb +158 -158
- data/lib/watir/adjacent.rb +126 -126
- data/lib/watir/after_hooks.rb +132 -132
- data/lib/watir/alert.rb +120 -120
- data/lib/watir/aliases.rb +6 -6
- data/lib/watir/attribute_helper.rb +96 -96
- data/lib/watir/browser.rb +349 -349
- data/lib/watir/capabilities.rb +123 -123
- data/lib/watir/cell_container.rb +25 -25
- data/lib/watir/container.rb +51 -51
- data/lib/watir/cookies.rb +134 -134
- data/lib/watir/element_collection.rb +138 -138
- data/lib/watir/elements/area.rb +12 -12
- data/lib/watir/elements/button.rb +37 -37
- data/lib/watir/elements/cell.rb +17 -17
- data/lib/watir/elements/checkbox.rb +56 -56
- data/lib/watir/elements/dlist.rb +12 -12
- data/lib/watir/elements/element.rb +2 -2
- data/lib/watir/elements/file_field.rb +41 -41
- data/lib/watir/elements/font.rb +25 -25
- data/lib/watir/elements/form.rb +16 -16
- data/lib/watir/elements/hidden.rb +25 -25
- data/lib/watir/elements/html_elements.rb +2035 -2035
- data/lib/watir/elements/iframe.rb +166 -166
- data/lib/watir/elements/image.rb +21 -21
- data/lib/watir/elements/input.rb +15 -15
- data/lib/watir/elements/link.rb +18 -18
- data/lib/watir/elements/list.rb +49 -49
- data/lib/watir/elements/option.rb +72 -72
- data/lib/watir/elements/radio.rb +60 -60
- data/lib/watir/elements/row.rb +17 -17
- data/lib/watir/elements/select.rb +250 -250
- data/lib/watir/elements/svg_elements.rb +613 -613
- data/lib/watir/elements/table.rb +76 -76
- data/lib/watir/elements/table_cell.rb +31 -31
- data/lib/watir/elements/table_row.rb +32 -32
- data/lib/watir/elements/table_section.rb +15 -15
- data/lib/watir/elements/text_area.rb +5 -5
- data/lib/watir/elements/text_field.rb +39 -39
- data/lib/watir/exception.rb +16 -16
- data/lib/watir/extensions/nokogiri.rb +14 -14
- data/lib/watir/generator.rb +3 -3
- data/lib/watir/generator/base.rb +11 -11
- data/lib/watir/generator/base/generator.rb +115 -115
- data/lib/watir/generator/base/idl_sorter.rb +47 -47
- data/lib/watir/generator/base/spec_extractor.rb +138 -138
- data/lib/watir/generator/base/util.rb +21 -21
- data/lib/watir/generator/base/visitor.rb +162 -162
- data/lib/watir/generator/html.rb +15 -15
- data/lib/watir/generator/html/generator.rb +36 -36
- data/lib/watir/generator/html/spec_extractor.rb +50 -50
- data/lib/watir/generator/html/visitor.rb +21 -21
- data/lib/watir/generator/svg.rb +7 -7
- data/lib/watir/generator/svg/generator.rb +38 -38
- data/lib/watir/generator/svg/spec_extractor.rb +53 -53
- data/lib/watir/generator/svg/visitor.rb +21 -21
- data/lib/watir/has_window.rb +68 -68
- data/lib/watir/js_execution.rb +143 -143
- data/lib/watir/js_snippets.rb +16 -16
- data/lib/watir/js_snippets/backgroundColor.js +7 -7
- data/lib/watir/js_snippets/fireEvent.js +31 -31
- data/lib/watir/js_snippets/focus.js +3 -3
- data/lib/watir/js_snippets/getInnerHtml.js +19 -19
- data/lib/watir/js_snippets/getInnerText.js +19 -19
- data/lib/watir/js_snippets/getOuterHtml.js +20 -20
- data/lib/watir/js_snippets/getTextContent.js +19 -19
- data/lib/watir/js_snippets/isImageLoaded.js +3 -3
- data/lib/watir/js_snippets/selectOptionsLabel.js +10 -10
- data/lib/watir/js_snippets/selectOptionsText.js +10 -10
- data/lib/watir/js_snippets/selectOptionsValue.js +10 -10
- data/lib/watir/js_snippets/selectText.js +64 -64
- data/lib/watir/js_snippets/selectedOptions.js +11 -11
- data/lib/watir/js_snippets/setValue.js +3 -3
- data/lib/watir/legacy_wait.rb +126 -126
- data/lib/watir/locators.rb +60 -60
- data/lib/watir/locators/button/locator.rb +31 -31
- data/lib/watir/locators/button/selector_builder.rb +30 -30
- data/lib/watir/locators/button/selector_builder/xpath.rb +29 -29
- data/lib/watir/locators/button/validator.rb +15 -15
- data/lib/watir/locators/cell/locator.rb +15 -15
- data/lib/watir/locators/cell/selector_builder.rb +24 -24
- data/lib/watir/locators/element/selector_builder.rb +150 -150
- data/lib/watir/locators/element/selector_builder/xpath.rb +119 -119
- data/lib/watir/locators/element/validator.rb +18 -18
- data/lib/watir/locators/row/locator.rb +15 -15
- data/lib/watir/locators/row/selector_builder.rb +29 -29
- data/lib/watir/locators/text_area/locator.rb +13 -13
- data/lib/watir/locators/text_area/selector_builder.rb +22 -22
- data/lib/watir/locators/text_field/locator.rb +30 -30
- data/lib/watir/locators/text_field/selector_builder.rb +31 -31
- data/lib/watir/locators/text_field/selector_builder/xpath.rb +17 -17
- data/lib/watir/locators/text_field/validator.rb +12 -12
- data/lib/watir/logger.rb +109 -109
- data/lib/watir/radio_set.rb +231 -231
- data/lib/watir/row_container.rb +36 -36
- data/lib/watir/screenshot.rb +50 -50
- data/lib/watir/user_editable.rb +56 -56
- data/lib/watir/wait.rb +200 -200
- data/lib/watir/wait/timer.rb +52 -52
- data/lib/watir/window.rb +257 -257
- data/lib/watir/xpath_support.rb +20 -20
- data/lib/watirspec.rb +86 -86
- data/lib/watirspec/guards.rb +60 -60
- data/lib/watirspec/implementation.rb +51 -51
- data/lib/watirspec/rake_tasks.rb +115 -115
- data/lib/watirspec/remote_server.rb +38 -38
- data/lib/watirspec/runner.rb +53 -53
- data/lib/watirspec/server.rb +99 -99
- data/lib/watirspec/server/app.rb +76 -76
- data/spec/browser_spec.rb +278 -278
- data/spec/click_spec.rb +19 -19
- data/spec/container_spec.rb +34 -34
- data/spec/element_locator_spec.rb +517 -517
- data/spec/element_spec.rb +158 -158
- data/spec/implementation_spec.rb +24 -24
- data/spec/input_spec.rb +14 -14
- data/spec/locator_spec_helper.rb +55 -55
- data/spec/logger_spec.rb +46 -46
- data/spec/spec_helper.rb +22 -22
- data/spec/special_chars_spec.rb +13 -13
- data/spec/watirspec/adjacent_spec.rb +227 -227
- data/spec/watirspec/after_hooks_spec.rb +182 -182
- data/spec/watirspec/alert_spec.rb +108 -108
- data/spec/watirspec/attributes_spec.rb +16 -16
- data/spec/watirspec/browser_spec.rb +281 -281
- data/spec/watirspec/cookies_spec.rb +154 -154
- data/spec/watirspec/drag_and_drop_spec.rb +49 -49
- data/spec/watirspec/element_hidden_spec.rb +75 -75
- data/spec/watirspec/elements/area_spec.rb +72 -72
- data/spec/watirspec/elements/areas_spec.rb +42 -42
- data/spec/watirspec/elements/button_spec.rb +277 -277
- data/spec/watirspec/elements/buttons_spec.rb +55 -55
- data/spec/watirspec/elements/checkbox_spec.rb +275 -275
- data/spec/watirspec/elements/checkboxes_spec.rb +44 -44
- data/spec/watirspec/elements/collections_spec.rb +52 -52
- data/spec/watirspec/elements/dd_spec.rb +124 -124
- data/spec/watirspec/elements/dds_spec.rb +42 -42
- data/spec/watirspec/elements/del_spec.rb +126 -126
- data/spec/watirspec/elements/dels_spec.rb +40 -40
- data/spec/watirspec/elements/div_spec.rb +245 -245
- data/spec/watirspec/elements/divs_spec.rb +42 -42
- data/spec/watirspec/elements/dl_spec.rb +142 -142
- data/spec/watirspec/elements/dls_spec.rb +43 -43
- data/spec/watirspec/elements/dt_spec.rb +122 -122
- data/spec/watirspec/elements/dts_spec.rb +42 -42
- data/spec/watirspec/elements/element_spec.rb +483 -483
- data/spec/watirspec/elements/elements_spec.rb +47 -47
- data/spec/watirspec/elements/em_spec.rb +96 -96
- data/spec/watirspec/elements/ems_spec.rb +43 -43
- data/spec/watirspec/elements/filefield_spec.rb +170 -170
- data/spec/watirspec/elements/filefields_spec.rb +43 -43
- data/spec/watirspec/elements/font_spec.rb +29 -29
- data/spec/watirspec/elements/form_spec.rb +66 -66
- data/spec/watirspec/elements/forms_spec.rb +46 -46
- data/spec/watirspec/elements/frame_spec.rb +123 -123
- data/spec/watirspec/elements/frames_spec.rb +41 -41
- data/spec/watirspec/elements/hidden_spec.rb +104 -104
- data/spec/watirspec/elements/hiddens_spec.rb +43 -43
- data/spec/watirspec/elements/hn_spec.rb +92 -92
- data/spec/watirspec/elements/hns_spec.rb +38 -38
- data/spec/watirspec/elements/iframe_spec.rb +3 -0
- data/spec/watirspec/elements/iframes_spec.rb +47 -47
- data/spec/watirspec/elements/image_spec.rb +158 -158
- data/spec/watirspec/elements/images_spec.rb +40 -40
- data/spec/watirspec/elements/ins_spec.rb +127 -127
- data/spec/watirspec/elements/inses_spec.rb +40 -40
- data/spec/watirspec/elements/label_spec.rb +75 -75
- data/spec/watirspec/elements/labels_spec.rb +40 -40
- data/spec/watirspec/elements/li_spec.rb +111 -111
- data/spec/watirspec/elements/link_spec.rb +171 -171
- data/spec/watirspec/elements/links_spec.rb +44 -44
- data/spec/watirspec/elements/lis_spec.rb +42 -42
- data/spec/watirspec/elements/list_spec.rb +32 -32
- data/spec/watirspec/elements/map_spec.rb +75 -75
- data/spec/watirspec/elements/maps_spec.rb +41 -41
- data/spec/watirspec/elements/meta_spec.rb +23 -23
- data/spec/watirspec/elements/metas_spec.rb +40 -40
- data/spec/watirspec/elements/ol_spec.rb +87 -87
- data/spec/watirspec/elements/ols_spec.rb +40 -40
- data/spec/watirspec/elements/option_spec.rb +121 -121
- data/spec/watirspec/elements/p_spec.rb +111 -111
- data/spec/watirspec/elements/pre_spec.rb +111 -111
- data/spec/watirspec/elements/pres_spec.rb +40 -40
- data/spec/watirspec/elements/ps_spec.rb +40 -40
- data/spec/watirspec/elements/radio_spec.rb +273 -273
- data/spec/watirspec/elements/radios_spec.rb +43 -43
- data/spec/watirspec/elements/select_list_spec.rb +553 -553
- data/spec/watirspec/elements/select_lists_spec.rb +46 -46
- data/spec/watirspec/elements/span_spec.rb +128 -128
- data/spec/watirspec/elements/spans_spec.rb +40 -40
- data/spec/watirspec/elements/strong_spec.rb +88 -88
- data/spec/watirspec/elements/strongs_spec.rb +43 -43
- data/spec/watirspec/elements/table_nesting_spec.rb +51 -51
- data/spec/watirspec/elements/table_spec.rb +156 -156
- data/spec/watirspec/elements/tables_spec.rb +42 -42
- data/spec/watirspec/elements/tbody_spec.rb +93 -93
- data/spec/watirspec/elements/tbodys_spec.rb +62 -62
- data/spec/watirspec/elements/td_spec.rb +93 -93
- data/spec/watirspec/elements/tds_spec.rb +53 -53
- data/spec/watirspec/elements/text_field_spec.rb +360 -360
- data/spec/watirspec/elements/text_fields_spec.rb +44 -44
- data/spec/watirspec/elements/textarea_spec.rb +26 -26
- data/spec/watirspec/elements/textareas_spec.rb +24 -24
- data/spec/watirspec/elements/tfoot_spec.rb +86 -86
- data/spec/watirspec/elements/tfoots_spec.rb +68 -68
- data/spec/watirspec/elements/thead_spec.rb +86 -86
- data/spec/watirspec/elements/theads_spec.rb +68 -68
- data/spec/watirspec/elements/tr_spec.rb +78 -78
- data/spec/watirspec/elements/trs_spec.rb +61 -61
- data/spec/watirspec/elements/ul_spec.rb +76 -76
- data/spec/watirspec/elements/uls_spec.rb +39 -39
- data/spec/watirspec/html/alerts.html +12 -12
- data/spec/watirspec/html/aria_attributes.html +9 -9
- data/spec/watirspec/html/class_locator.html +8 -8
- data/spec/watirspec/html/clicks.html +19 -19
- data/spec/watirspec/html/closeable.html +12 -12
- data/spec/watirspec/html/collections.html +14 -14
- data/spec/watirspec/html/css/jquery-ui-1.8.17.custom.css +286 -286
- data/spec/watirspec/html/data_attributes.html +9 -9
- data/spec/watirspec/html/definition_lists.html +47 -47
- data/spec/watirspec/html/drag_and_drop.html +106 -106
- data/spec/watirspec/html/font.html +10 -10
- data/spec/watirspec/html/forms_with_input_elements.html +174 -174
- data/spec/watirspec/html/frame_1.html +22 -22
- data/spec/watirspec/html/frame_2.html +15 -15
- data/spec/watirspec/html/frames.html +10 -10
- data/spec/watirspec/html/hover.html +11 -11
- data/spec/watirspec/html/iframe_1.html +22 -22
- data/spec/watirspec/html/iframes.html +12 -12
- data/spec/watirspec/html/images.html +27 -27
- data/spec/watirspec/html/inner_outer.html +4 -4
- data/spec/watirspec/html/javascript/angular.min.js +331 -331
- data/spec/watirspec/html/javascript/helpers.js +16 -16
- data/spec/watirspec/html/javascript/jquery-1.7.1.min.js +3 -3
- data/spec/watirspec/html/javascript/jquery-ui-1.8.17.custom.min.js +67 -67
- data/spec/watirspec/html/keylogger.html +14 -14
- data/spec/watirspec/html/modal_dialog.html +9 -9
- data/spec/watirspec/html/multiple_ids.html +14 -14
- data/spec/watirspec/html/nested_elements.html +33 -33
- data/spec/watirspec/html/nested_frame_2.html +9 -9
- data/spec/watirspec/html/nested_frame_3.html +14 -14
- data/spec/watirspec/html/nested_frames.html +10 -10
- data/spec/watirspec/html/nested_iframe_2.html +12 -12
- data/spec/watirspec/html/nested_iframes.html +13 -13
- data/spec/watirspec/html/nested_tables.html +202 -202
- data/spec/watirspec/html/non_control_elements.html +140 -140
- data/spec/watirspec/html/removed_element.html +24 -24
- data/spec/watirspec/html/right_click.html +10 -10
- data/spec/watirspec/html/special_chars.html +11 -11
- data/spec/watirspec/html/tables.html +120 -120
- data/spec/watirspec/html/timeout_window_location.html +19 -19
- data/spec/watirspec/html/uneven_table.html +20 -20
- data/spec/watirspec/html/wait.html +84 -84
- data/spec/watirspec/html/window_switching.html +11 -11
- data/spec/watirspec/radio_set_spec.rb +336 -336
- data/spec/watirspec/relaxed_locate_spec.rb +99 -99
- data/spec/watirspec/screenshot_spec.rb +29 -29
- data/spec/watirspec/support/raise_exception_matchers.rb +36 -36
- data/spec/watirspec/wait_spec.rb +381 -381
- data/spec/watirspec/window_switching_spec.rb +415 -415
- data/spec/watirspec_helper.rb +161 -161
- data/support/appveyor.cmd +9 -9
- data/support/doctest_helper.rb +101 -101
- data/support/travis.sh +11 -11
- data/support/version_differ.rb +59 -59
- data/watir.gemspec +1 -1
- metadata +169 -3
data/lib/watir/capabilities.rb
CHANGED
@@ -1,124 +1,124 @@
|
|
1
|
-
module Watir
|
2
|
-
class Capabilities
|
3
|
-
|
4
|
-
attr_reader :options
|
5
|
-
|
6
|
-
def initialize(browser, options = {})
|
7
|
-
@options = options.dup
|
8
|
-
Watir.logger.info "Creating Browser instance of #{browser} with user provided options: #{@options.inspect}"
|
9
|
-
@browser = if browser == :remote && @options.key?(:browser)
|
10
|
-
@options.delete(:browser)
|
11
|
-
elsif browser == :remote && @options.key?(:desired_capabilities)
|
12
|
-
@options[:desired_capabilities].browser_name.to_sym
|
13
|
-
else
|
14
|
-
browser.to_sym
|
15
|
-
end
|
16
|
-
@selenium_browser = browser == :remote || options[:url] ? :remote : browser
|
17
|
-
|
18
|
-
@selenium_opts = {}
|
19
|
-
end
|
20
|
-
|
21
|
-
def to_args
|
22
|
-
[@selenium_browser, process_arguments]
|
23
|
-
end
|
24
|
-
|
25
|
-
private
|
26
|
-
|
27
|
-
def process_arguments
|
28
|
-
url = @options.delete(:url)
|
29
|
-
@selenium_opts[:url] = url if url
|
30
|
-
|
31
|
-
create_http_client
|
32
|
-
|
33
|
-
@selenium_opts[:port] = @options.delete(:port) if @options.key?(:port)
|
34
|
-
@selenium_opts[:driver_opts] = @options.delete(:driver_opts) if @options.key?(:driver_opts)
|
35
|
-
@selenium_opts[:listener] = @options.delete(:listener) if @options.key?(:listener)
|
36
|
-
|
37
|
-
process_browser_options
|
38
|
-
process_capabilities
|
39
|
-
Watir.logger.info "Creating Browser instance with Watir processed options: #{@selenium_opts.inspect}"
|
40
|
-
|
41
|
-
@selenium_opts
|
42
|
-
end
|
43
|
-
|
44
|
-
def create_http_client
|
45
|
-
client_timeout = @options.delete(:client_timeout)
|
46
|
-
open_timeout = @options.delete(:open_timeout)
|
47
|
-
read_timeout = @options.delete(:read_timeout)
|
48
|
-
|
49
|
-
http_client = @options.delete(:http_client)
|
50
|
-
|
51
|
-
%i(open_timeout read_timeout client_timeout).each do |t|
|
52
|
-
next if http_client.nil? || !respond_to?(t)
|
53
|
-
Watir.logger.warn "You can now pass #{t} value directly into Watir::Browser opt without needing to use :http_client"
|
54
|
-
end
|
55
|
-
|
56
|
-
http_client ||= Selenium::WebDriver::Remote::Http::Default.new
|
57
|
-
|
58
|
-
http_client.timeout = client_timeout if client_timeout
|
59
|
-
http_client.open_timeout = open_timeout if open_timeout
|
60
|
-
http_client.read_timeout = read_timeout if read_timeout
|
61
|
-
@selenium_opts[:http_client] = http_client
|
62
|
-
end
|
63
|
-
|
64
|
-
def process_browser_options
|
65
|
-
browser_options = @options.delete(:options) || {}
|
66
|
-
|
67
|
-
case @selenium_browser
|
68
|
-
when :chrome
|
69
|
-
if @options.key?(:args) || @options.key?(:switches)
|
70
|
-
browser_options ||= {}
|
71
|
-
browser_options[:args] = (@options.delete(:args) || @options.delete(:switches)).dup
|
72
|
-
end
|
73
|
-
if @options.delete(:headless)
|
74
|
-
browser_options ||= {}
|
75
|
-
browser_options[:args] ||= []
|
76
|
-
browser_options[:args] += ['--headless', '--disable-gpu']
|
77
|
-
end
|
78
|
-
@selenium_opts[:options] = browser_options if browser_options.is_a? Selenium::WebDriver::Chrome::Options
|
79
|
-
@selenium_opts[:options] ||= Selenium::WebDriver::Chrome::Options.new(browser_options)
|
80
|
-
when :firefox
|
81
|
-
profile = @options.delete(:profile)
|
82
|
-
if browser_options.is_a? Selenium::WebDriver::Firefox::Options
|
83
|
-
@selenium_opts[:options] = browser_options
|
84
|
-
Watir.logger.deprecate 'Initializing Browser with both :profile and :option', ':profile as a key inside :option' if profile
|
85
|
-
end
|
86
|
-
if @options.delete(:headless)
|
87
|
-
browser_options ||= {}
|
88
|
-
browser_options[:args] ||= []
|
89
|
-
browser_options[:args] += ['--headless']
|
90
|
-
end
|
91
|
-
@selenium_opts[:options] ||= Selenium::WebDriver::Firefox::Options.new(browser_options)
|
92
|
-
@selenium_opts[:options].profile = profile if profile
|
93
|
-
when :safari
|
94
|
-
Selenium::WebDriver::Safari.technology_preview! if @options.delete(:technology_preview)
|
95
|
-
when :remote
|
96
|
-
if @browser == :chrome && @options.delete(:headless)
|
97
|
-
args = @options.delete(:args) || @options.delete(:switches) || []
|
98
|
-
@options['chromeOptions'] = {'args' => args + ['--headless', '--disable-gpu']}
|
99
|
-
end
|
100
|
-
if @browser == :firefox && @options.delete(:headless)
|
101
|
-
args = @options.delete(:args) || @options.delete(:switches) || []
|
102
|
-
@options[Selenium::WebDriver::Firefox::Options.KEY] = {'args' => args + ['--headless']}
|
103
|
-
end
|
104
|
-
if @browser == :safari && @options.delete(:technology_preview)
|
105
|
-
@options["safari.options"] = {'technologyPreview' => true}
|
106
|
-
end
|
107
|
-
end
|
108
|
-
end
|
109
|
-
|
110
|
-
def process_capabilities
|
111
|
-
caps = @options.delete(:desired_capabilities)
|
112
|
-
|
113
|
-
if caps
|
114
|
-
Watir.logger.warn 'You can now pass values directly into Watir::Browser opt without needing to use :desired_capabilities'
|
115
|
-
@selenium_opts.merge!(@options)
|
116
|
-
else
|
117
|
-
caps = Selenium::WebDriver::Remote::Capabilities.send @browser, @options
|
118
|
-
end
|
119
|
-
|
120
|
-
@selenium_opts[:desired_capabilities] = caps
|
121
|
-
end
|
122
|
-
|
123
|
-
end
|
1
|
+
module Watir
|
2
|
+
class Capabilities
|
3
|
+
|
4
|
+
attr_reader :options
|
5
|
+
|
6
|
+
def initialize(browser, options = {})
|
7
|
+
@options = options.dup
|
8
|
+
Watir.logger.info "Creating Browser instance of #{browser} with user provided options: #{@options.inspect}"
|
9
|
+
@browser = if browser == :remote && @options.key?(:browser)
|
10
|
+
@options.delete(:browser)
|
11
|
+
elsif browser == :remote && @options.key?(:desired_capabilities)
|
12
|
+
@options[:desired_capabilities].browser_name.to_sym
|
13
|
+
else
|
14
|
+
browser.to_sym
|
15
|
+
end
|
16
|
+
@selenium_browser = browser == :remote || options[:url] ? :remote : browser
|
17
|
+
|
18
|
+
@selenium_opts = {}
|
19
|
+
end
|
20
|
+
|
21
|
+
def to_args
|
22
|
+
[@selenium_browser, process_arguments]
|
23
|
+
end
|
24
|
+
|
25
|
+
private
|
26
|
+
|
27
|
+
def process_arguments
|
28
|
+
url = @options.delete(:url)
|
29
|
+
@selenium_opts[:url] = url if url
|
30
|
+
|
31
|
+
create_http_client
|
32
|
+
|
33
|
+
@selenium_opts[:port] = @options.delete(:port) if @options.key?(:port)
|
34
|
+
@selenium_opts[:driver_opts] = @options.delete(:driver_opts) if @options.key?(:driver_opts)
|
35
|
+
@selenium_opts[:listener] = @options.delete(:listener) if @options.key?(:listener)
|
36
|
+
|
37
|
+
process_browser_options
|
38
|
+
process_capabilities
|
39
|
+
Watir.logger.info "Creating Browser instance with Watir processed options: #{@selenium_opts.inspect}"
|
40
|
+
|
41
|
+
@selenium_opts
|
42
|
+
end
|
43
|
+
|
44
|
+
def create_http_client
|
45
|
+
client_timeout = @options.delete(:client_timeout)
|
46
|
+
open_timeout = @options.delete(:open_timeout)
|
47
|
+
read_timeout = @options.delete(:read_timeout)
|
48
|
+
|
49
|
+
http_client = @options.delete(:http_client)
|
50
|
+
|
51
|
+
%i(open_timeout read_timeout client_timeout).each do |t|
|
52
|
+
next if http_client.nil? || !respond_to?(t)
|
53
|
+
Watir.logger.warn "You can now pass #{t} value directly into Watir::Browser opt without needing to use :http_client"
|
54
|
+
end
|
55
|
+
|
56
|
+
http_client ||= Selenium::WebDriver::Remote::Http::Default.new
|
57
|
+
|
58
|
+
http_client.timeout = client_timeout if client_timeout
|
59
|
+
http_client.open_timeout = open_timeout if open_timeout
|
60
|
+
http_client.read_timeout = read_timeout if read_timeout
|
61
|
+
@selenium_opts[:http_client] = http_client
|
62
|
+
end
|
63
|
+
|
64
|
+
def process_browser_options
|
65
|
+
browser_options = @options.delete(:options) || {}
|
66
|
+
|
67
|
+
case @selenium_browser
|
68
|
+
when :chrome
|
69
|
+
if @options.key?(:args) || @options.key?(:switches)
|
70
|
+
browser_options ||= {}
|
71
|
+
browser_options[:args] = (@options.delete(:args) || @options.delete(:switches)).dup
|
72
|
+
end
|
73
|
+
if @options.delete(:headless)
|
74
|
+
browser_options ||= {}
|
75
|
+
browser_options[:args] ||= []
|
76
|
+
browser_options[:args] += ['--headless', '--disable-gpu']
|
77
|
+
end
|
78
|
+
@selenium_opts[:options] = browser_options if browser_options.is_a? Selenium::WebDriver::Chrome::Options
|
79
|
+
@selenium_opts[:options] ||= Selenium::WebDriver::Chrome::Options.new(browser_options)
|
80
|
+
when :firefox
|
81
|
+
profile = @options.delete(:profile)
|
82
|
+
if browser_options.is_a? Selenium::WebDriver::Firefox::Options
|
83
|
+
@selenium_opts[:options] = browser_options
|
84
|
+
Watir.logger.deprecate 'Initializing Browser with both :profile and :option', ':profile as a key inside :option' if profile
|
85
|
+
end
|
86
|
+
if @options.delete(:headless)
|
87
|
+
browser_options ||= {}
|
88
|
+
browser_options[:args] ||= []
|
89
|
+
browser_options[:args] += ['--headless']
|
90
|
+
end
|
91
|
+
@selenium_opts[:options] ||= Selenium::WebDriver::Firefox::Options.new(browser_options)
|
92
|
+
@selenium_opts[:options].profile = profile if profile
|
93
|
+
when :safari
|
94
|
+
Selenium::WebDriver::Safari.technology_preview! if @options.delete(:technology_preview)
|
95
|
+
when :remote
|
96
|
+
if @browser == :chrome && @options.delete(:headless)
|
97
|
+
args = @options.delete(:args) || @options.delete(:switches) || []
|
98
|
+
@options['chromeOptions'] = {'args' => args + ['--headless', '--disable-gpu']}
|
99
|
+
end
|
100
|
+
if @browser == :firefox && @options.delete(:headless)
|
101
|
+
args = @options.delete(:args) || @options.delete(:switches) || []
|
102
|
+
@options[Selenium::WebDriver::Firefox::Options.KEY] = {'args' => args + ['--headless']}
|
103
|
+
end
|
104
|
+
if @browser == :safari && @options.delete(:technology_preview)
|
105
|
+
@options["safari.options"] = {'technologyPreview' => true}
|
106
|
+
end
|
107
|
+
end
|
108
|
+
end
|
109
|
+
|
110
|
+
def process_capabilities
|
111
|
+
caps = @options.delete(:desired_capabilities)
|
112
|
+
|
113
|
+
if caps
|
114
|
+
Watir.logger.warn 'You can now pass values directly into Watir::Browser opt without needing to use :desired_capabilities'
|
115
|
+
@selenium_opts.merge!(@options)
|
116
|
+
else
|
117
|
+
caps = Selenium::WebDriver::Remote::Capabilities.send @browser, @options
|
118
|
+
end
|
119
|
+
|
120
|
+
@selenium_opts[:desired_capabilities] = caps
|
121
|
+
end
|
122
|
+
|
123
|
+
end
|
124
124
|
end
|
data/lib/watir/cell_container.rb
CHANGED
@@ -1,25 +1,25 @@
|
|
1
|
-
module Watir
|
2
|
-
module CellContainer
|
3
|
-
|
4
|
-
#
|
5
|
-
# Returns table cell.
|
6
|
-
#
|
7
|
-
# @return [Cell]
|
8
|
-
#
|
9
|
-
|
10
|
-
def cell(*args)
|
11
|
-
Cell.new(self, extract_selector(args).merge(tag_name: /^(th|td)$/))
|
12
|
-
end
|
13
|
-
|
14
|
-
#
|
15
|
-
# Returns table cells collection.
|
16
|
-
#
|
17
|
-
# @return [Cell]
|
18
|
-
#
|
19
|
-
|
20
|
-
def cells(*args)
|
21
|
-
CellCollection.new(self, extract_selector(args).merge(tag_name: /^(th|td)$/))
|
22
|
-
end
|
23
|
-
|
24
|
-
end # CellContainer
|
25
|
-
end # Watir
|
1
|
+
module Watir
|
2
|
+
module CellContainer
|
3
|
+
|
4
|
+
#
|
5
|
+
# Returns table cell.
|
6
|
+
#
|
7
|
+
# @return [Cell]
|
8
|
+
#
|
9
|
+
|
10
|
+
def cell(*args)
|
11
|
+
Cell.new(self, extract_selector(args).merge(tag_name: /^(th|td)$/))
|
12
|
+
end
|
13
|
+
|
14
|
+
#
|
15
|
+
# Returns table cells collection.
|
16
|
+
#
|
17
|
+
# @return [Cell]
|
18
|
+
#
|
19
|
+
|
20
|
+
def cells(*args)
|
21
|
+
CellCollection.new(self, extract_selector(args).merge(tag_name: /^(th|td)$/))
|
22
|
+
end
|
23
|
+
|
24
|
+
end # CellContainer
|
25
|
+
end # Watir
|
data/lib/watir/container.rb
CHANGED
@@ -1,51 +1,51 @@
|
|
1
|
-
module Watir
|
2
|
-
module Container
|
3
|
-
include XpathSupport
|
4
|
-
include JSSnippets
|
5
|
-
|
6
|
-
#
|
7
|
-
# Returns element.
|
8
|
-
#
|
9
|
-
# @example
|
10
|
-
# browser.element(data_bind: 'func')
|
11
|
-
#
|
12
|
-
# @return [HTMLElement]
|
13
|
-
#
|
14
|
-
|
15
|
-
def element(*args)
|
16
|
-
HTMLElement.new(self, extract_selector(args))
|
17
|
-
end
|
18
|
-
|
19
|
-
#
|
20
|
-
# Returns element collection.
|
21
|
-
#
|
22
|
-
# @example
|
23
|
-
# browser.elements(data_bind: 'func')
|
24
|
-
#
|
25
|
-
# @return [HTMLElementCollection]
|
26
|
-
#
|
27
|
-
|
28
|
-
def elements(*args)
|
29
|
-
HTMLElementCollection.new(self, extract_selector(args))
|
30
|
-
end
|
31
|
-
|
32
|
-
#
|
33
|
-
# @api private
|
34
|
-
#
|
35
|
-
|
36
|
-
def extract_selector(selectors)
|
37
|
-
case selectors.size
|
38
|
-
when 2
|
39
|
-
return { selectors[0] => selectors[1] }
|
40
|
-
when 1
|
41
|
-
obj = selectors.first
|
42
|
-
return obj if obj.kind_of? Hash
|
43
|
-
when 0
|
44
|
-
return {}
|
45
|
-
end
|
46
|
-
|
47
|
-
raise ArgumentError, "expected Hash or (:how, 'what'), got #{selectors.inspect}"
|
48
|
-
end
|
49
|
-
|
50
|
-
end # Container
|
51
|
-
end # Watir
|
1
|
+
module Watir
|
2
|
+
module Container
|
3
|
+
include XpathSupport
|
4
|
+
include JSSnippets
|
5
|
+
|
6
|
+
#
|
7
|
+
# Returns element.
|
8
|
+
#
|
9
|
+
# @example
|
10
|
+
# browser.element(data_bind: 'func')
|
11
|
+
#
|
12
|
+
# @return [HTMLElement]
|
13
|
+
#
|
14
|
+
|
15
|
+
def element(*args)
|
16
|
+
HTMLElement.new(self, extract_selector(args))
|
17
|
+
end
|
18
|
+
|
19
|
+
#
|
20
|
+
# Returns element collection.
|
21
|
+
#
|
22
|
+
# @example
|
23
|
+
# browser.elements(data_bind: 'func')
|
24
|
+
#
|
25
|
+
# @return [HTMLElementCollection]
|
26
|
+
#
|
27
|
+
|
28
|
+
def elements(*args)
|
29
|
+
HTMLElementCollection.new(self, extract_selector(args))
|
30
|
+
end
|
31
|
+
|
32
|
+
#
|
33
|
+
# @api private
|
34
|
+
#
|
35
|
+
|
36
|
+
def extract_selector(selectors)
|
37
|
+
case selectors.size
|
38
|
+
when 2
|
39
|
+
return { selectors[0] => selectors[1] }
|
40
|
+
when 1
|
41
|
+
obj = selectors.first
|
42
|
+
return obj if obj.kind_of? Hash
|
43
|
+
when 0
|
44
|
+
return {}
|
45
|
+
end
|
46
|
+
|
47
|
+
raise ArgumentError, "expected Hash or (:how, 'what'), got #{selectors.inspect}"
|
48
|
+
end
|
49
|
+
|
50
|
+
end # Container
|
51
|
+
end # Watir
|
data/lib/watir/cookies.rb
CHANGED
@@ -1,134 +1,134 @@
|
|
1
|
-
require 'yaml'
|
2
|
-
|
3
|
-
module Watir
|
4
|
-
class Cookies
|
5
|
-
|
6
|
-
def initialize(control)
|
7
|
-
@control = control
|
8
|
-
end
|
9
|
-
|
10
|
-
#
|
11
|
-
# Returns array of cookies.
|
12
|
-
#
|
13
|
-
# @example
|
14
|
-
# browser.cookies.to_a
|
15
|
-
# #=> {:name=>"my_session", :value=>"BAh7B0kiD3Nlc3Npb25faWQGOgZFRkk", :domain=>"mysite.com"}
|
16
|
-
#
|
17
|
-
# @return [Array<Hash>]
|
18
|
-
#
|
19
|
-
|
20
|
-
def to_a
|
21
|
-
@control.all_cookies.map do |e|
|
22
|
-
e.merge(expires: e[:expires] ? to_time(e[:expires]) : nil)
|
23
|
-
end
|
24
|
-
end
|
25
|
-
|
26
|
-
#
|
27
|
-
# Returns a cookie by name.
|
28
|
-
#
|
29
|
-
# @example
|
30
|
-
# browser.cookies[:my_session]
|
31
|
-
# #=> {:name=>"my_session", :value=>"BAh7B0kiD3Nlc3Npb25faWQGOgZFRkk", :domain=>"mysite.com"}
|
32
|
-
#
|
33
|
-
# @param [Symbol] name
|
34
|
-
# @return <Hash> or nil if not found
|
35
|
-
#
|
36
|
-
|
37
|
-
def [](name)
|
38
|
-
to_a.find { |c| c[:name] == name.to_s }
|
39
|
-
end
|
40
|
-
|
41
|
-
#
|
42
|
-
# Adds new cookie.
|
43
|
-
#
|
44
|
-
# @example
|
45
|
-
# browser.cookies.add 'my_session', 'BAh7B0kiD3Nlc3Npb25faWQGOgZFRkk', secure: true
|
46
|
-
#
|
47
|
-
# @param [String] name
|
48
|
-
# @param [String] value
|
49
|
-
# @param [Hash] opts
|
50
|
-
# @option opts [Boolean] :secure
|
51
|
-
# @option opts [String] :path
|
52
|
-
# @option opts [Time, DateTime, NilClass] :expires
|
53
|
-
# @option opts [String] :domain
|
54
|
-
#
|
55
|
-
|
56
|
-
def add(name, value, opts = {})
|
57
|
-
cookie = {
|
58
|
-
name: name,
|
59
|
-
value: value}
|
60
|
-
cookie[:secure] = opts[:secure] if opts.key?(:secure)
|
61
|
-
cookie[:path] = opts[:path] if opts.key?(:path)
|
62
|
-
expires = opts[:expires]
|
63
|
-
if expires
|
64
|
-
cookie[:expires] = ::Time.parse(expires) if expires.is_a?(String) else expires
|
65
|
-
end
|
66
|
-
cookie[:domain] = opts[:domain] if opts.key?(:domain)
|
67
|
-
|
68
|
-
@control.add_cookie cookie
|
69
|
-
end
|
70
|
-
|
71
|
-
#
|
72
|
-
# Deletes cookie by given name.
|
73
|
-
#
|
74
|
-
# @example
|
75
|
-
# browser.cookies.delete 'my_session'
|
76
|
-
#
|
77
|
-
# @param [String] name
|
78
|
-
#
|
79
|
-
|
80
|
-
def delete(name)
|
81
|
-
@control.delete_cookie(name)
|
82
|
-
end
|
83
|
-
|
84
|
-
#
|
85
|
-
# Deletes all cookies.
|
86
|
-
#
|
87
|
-
# @example
|
88
|
-
# browser.cookies.clear
|
89
|
-
#
|
90
|
-
|
91
|
-
def clear
|
92
|
-
@control.delete_all_cookies
|
93
|
-
end
|
94
|
-
|
95
|
-
#
|
96
|
-
# Save cookies to file
|
97
|
-
#
|
98
|
-
# @example
|
99
|
-
# browser.cookies.save '.cookies'
|
100
|
-
#
|
101
|
-
# @param [String] file
|
102
|
-
#
|
103
|
-
|
104
|
-
def save(file = '.cookies')
|
105
|
-
IO.write(file, to_a.to_yaml)
|
106
|
-
end
|
107
|
-
|
108
|
-
#
|
109
|
-
# Load cookies from file
|
110
|
-
#
|
111
|
-
# @example
|
112
|
-
# browser.cookies.load '.cookies'
|
113
|
-
#
|
114
|
-
# @param [String] file
|
115
|
-
#
|
116
|
-
|
117
|
-
def load(file = '.cookies')
|
118
|
-
YAML.load(IO.read(file)).each do |c|
|
119
|
-
add(c.delete(:name), c.delete(:value), c)
|
120
|
-
end
|
121
|
-
end
|
122
|
-
|
123
|
-
private
|
124
|
-
|
125
|
-
def to_time(t)
|
126
|
-
if t.respond_to?(:to_time)
|
127
|
-
t.to_time
|
128
|
-
else
|
129
|
-
::Time.local t.year, t.month, t.day, t.hour, t.min, t.sec
|
130
|
-
end
|
131
|
-
end
|
132
|
-
|
133
|
-
end # Cookies
|
134
|
-
end # Watir
|
1
|
+
require 'yaml'
|
2
|
+
|
3
|
+
module Watir
|
4
|
+
class Cookies
|
5
|
+
|
6
|
+
def initialize(control)
|
7
|
+
@control = control
|
8
|
+
end
|
9
|
+
|
10
|
+
#
|
11
|
+
# Returns array of cookies.
|
12
|
+
#
|
13
|
+
# @example
|
14
|
+
# browser.cookies.to_a
|
15
|
+
# #=> {:name=>"my_session", :value=>"BAh7B0kiD3Nlc3Npb25faWQGOgZFRkk", :domain=>"mysite.com"}
|
16
|
+
#
|
17
|
+
# @return [Array<Hash>]
|
18
|
+
#
|
19
|
+
|
20
|
+
def to_a
|
21
|
+
@control.all_cookies.map do |e|
|
22
|
+
e.merge(expires: e[:expires] ? to_time(e[:expires]) : nil)
|
23
|
+
end
|
24
|
+
end
|
25
|
+
|
26
|
+
#
|
27
|
+
# Returns a cookie by name.
|
28
|
+
#
|
29
|
+
# @example
|
30
|
+
# browser.cookies[:my_session]
|
31
|
+
# #=> {:name=>"my_session", :value=>"BAh7B0kiD3Nlc3Npb25faWQGOgZFRkk", :domain=>"mysite.com"}
|
32
|
+
#
|
33
|
+
# @param [Symbol] name
|
34
|
+
# @return <Hash> or nil if not found
|
35
|
+
#
|
36
|
+
|
37
|
+
def [](name)
|
38
|
+
to_a.find { |c| c[:name] == name.to_s }
|
39
|
+
end
|
40
|
+
|
41
|
+
#
|
42
|
+
# Adds new cookie.
|
43
|
+
#
|
44
|
+
# @example
|
45
|
+
# browser.cookies.add 'my_session', 'BAh7B0kiD3Nlc3Npb25faWQGOgZFRkk', secure: true
|
46
|
+
#
|
47
|
+
# @param [String] name
|
48
|
+
# @param [String] value
|
49
|
+
# @param [Hash] opts
|
50
|
+
# @option opts [Boolean] :secure
|
51
|
+
# @option opts [String] :path
|
52
|
+
# @option opts [Time, DateTime, NilClass] :expires
|
53
|
+
# @option opts [String] :domain
|
54
|
+
#
|
55
|
+
|
56
|
+
def add(name, value, opts = {})
|
57
|
+
cookie = {
|
58
|
+
name: name,
|
59
|
+
value: value}
|
60
|
+
cookie[:secure] = opts[:secure] if opts.key?(:secure)
|
61
|
+
cookie[:path] = opts[:path] if opts.key?(:path)
|
62
|
+
expires = opts[:expires]
|
63
|
+
if expires
|
64
|
+
cookie[:expires] = ::Time.parse(expires) if expires.is_a?(String) else expires
|
65
|
+
end
|
66
|
+
cookie[:domain] = opts[:domain] if opts.key?(:domain)
|
67
|
+
|
68
|
+
@control.add_cookie cookie
|
69
|
+
end
|
70
|
+
|
71
|
+
#
|
72
|
+
# Deletes cookie by given name.
|
73
|
+
#
|
74
|
+
# @example
|
75
|
+
# browser.cookies.delete 'my_session'
|
76
|
+
#
|
77
|
+
# @param [String] name
|
78
|
+
#
|
79
|
+
|
80
|
+
def delete(name)
|
81
|
+
@control.delete_cookie(name)
|
82
|
+
end
|
83
|
+
|
84
|
+
#
|
85
|
+
# Deletes all cookies.
|
86
|
+
#
|
87
|
+
# @example
|
88
|
+
# browser.cookies.clear
|
89
|
+
#
|
90
|
+
|
91
|
+
def clear
|
92
|
+
@control.delete_all_cookies
|
93
|
+
end
|
94
|
+
|
95
|
+
#
|
96
|
+
# Save cookies to file
|
97
|
+
#
|
98
|
+
# @example
|
99
|
+
# browser.cookies.save '.cookies'
|
100
|
+
#
|
101
|
+
# @param [String] file
|
102
|
+
#
|
103
|
+
|
104
|
+
def save(file = '.cookies')
|
105
|
+
IO.write(file, to_a.to_yaml)
|
106
|
+
end
|
107
|
+
|
108
|
+
#
|
109
|
+
# Load cookies from file
|
110
|
+
#
|
111
|
+
# @example
|
112
|
+
# browser.cookies.load '.cookies'
|
113
|
+
#
|
114
|
+
# @param [String] file
|
115
|
+
#
|
116
|
+
|
117
|
+
def load(file = '.cookies')
|
118
|
+
YAML.load(IO.read(file)).each do |c|
|
119
|
+
add(c.delete(:name), c.delete(:value), c)
|
120
|
+
end
|
121
|
+
end
|
122
|
+
|
123
|
+
private
|
124
|
+
|
125
|
+
def to_time(t)
|
126
|
+
if t.respond_to?(:to_time)
|
127
|
+
t.to_time
|
128
|
+
else
|
129
|
+
::Time.local t.year, t.month, t.day, t.hour, t.min, t.sec
|
130
|
+
end
|
131
|
+
end
|
132
|
+
|
133
|
+
end # Cookies
|
134
|
+
end # Watir
|