awetestlib 0.0.3-x86-mingw32 → 0.1.0-x86-mingw32
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.
- data/.gitattributes +22 -0
- data/.gitignore +2 -3
- data/AwetestLib Instructions.rtf +0 -0
- data/ext/Rakefile +1 -0
- data/lib/regression/browser.rb +1259 -0
- data/lib/regression/drag_and_drop.rb +374 -0
- data/lib/regression/find.rb +426 -0
- data/lib/regression/legacy.rb +10 -4693
- data/lib/regression/page_data.rb +185 -0
- data/lib/regression/runner.rb +16 -2
- data/lib/regression/tables.rb +486 -0
- data/lib/regression/user_input.rb +1255 -0
- data/lib/regression/utilities.rb +891 -0
- data/lib/regression/validations.rb +179 -508
- data/lib/regression/waits.rb +387 -0
- data/lib/version.rb +2 -2
- data/rdoc_test.bat +1 -0
- data/test/create_zoho.rb +65 -0
- data/{create_zoho_account1.rb → test/create_zoho_account1.rb} +0 -0
- data/{create_zoho_account2.rb → test/create_zoho_account2.rb} +2 -1
- data/{demo.rb → test/demo.rb} +0 -0
- data/{google_search1.rb → test/google_search1.rb} +0 -0
- data/{google_search2.rb → test/google_search2.rb} +0 -0
- data/{zoho_util.rb → test/zoho_util.rb} +0 -0
- data/{zoho_variables.xls → test/zoho_variables.xls} +0 -0
- metadata +27 -12
@@ -32,200 +32,38 @@ module Validations
|
|
32
32
|
end
|
33
33
|
end
|
34
34
|
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
known false errors and handle container elements that don't respond to the .text method.
|
39
|
-
category: bullet-proofing
|
40
|
-
tags: system, http, fatal, error
|
41
|
-
example: See click()
|
42
|
-
related methods: rescue_me()
|
43
|
-
=end
|
44
|
-
def validate(browser, fileName = '', lnbr = __LINE__, dbg = false)
|
45
|
-
debug_to_log("#{__method__} begin") if dbg
|
46
|
-
msg = ''
|
47
|
-
myOK = true
|
48
|
-
if not browser
|
49
|
-
msg = "#{fileName}----browser is nil object. (#{lnbr})"
|
50
|
-
myOK = false
|
51
|
-
elsif not is_browser?(browser)
|
52
|
-
msg = "#{fileName}----not a browser. (#{lnbr})"
|
53
|
-
debug_to_log(browser.inspect)
|
54
|
-
myOK = false
|
55
|
-
|
56
|
-
else
|
57
|
-
if browser.respond_to?(:url)
|
58
|
-
if not browser.url == @currentURL
|
59
|
-
@currentURL = browser.url
|
60
|
-
debug_to_log("Current URL: [#{@currentURL}]")
|
61
|
-
# mark_testlevel( "Current URL: [#{@currentURL}]", 1 )
|
62
|
-
end
|
63
|
-
end
|
64
|
-
|
65
|
-
if @capture_js_errors
|
66
|
-
if browser.respond_to?(:status)
|
67
|
-
if browser.status.downcase =~ /errors? on page/ and
|
68
|
-
not browser.status.downcase.include?('Waiting for')
|
69
|
-
capture_js_error(browser)
|
70
|
-
end
|
71
|
-
end
|
72
|
-
end
|
73
|
-
|
74
|
-
begin
|
75
|
-
browser_text = browser.text.downcase
|
76
|
-
rescue => e
|
77
|
-
if not rescue_me(e, __method__, "browser.text.downcase", "#{browser.class}", browser)
|
78
|
-
debug_to_log("browser.text.downcase in #{__method__} #{browser.class}")
|
79
|
-
debug_to_log("#{get_callers}")
|
80
|
-
raise e
|
81
|
-
else
|
82
|
-
return true
|
83
|
-
end
|
84
|
-
end
|
85
|
-
|
86
|
-
if browser_text
|
87
|
-
if browser_text.match(/unrecognized error condition has occurred/i)
|
88
|
-
msg = "#{fileName}----Unrecognized Exception occurred. (#{lnbr})"
|
89
|
-
myOK = false
|
90
|
-
|
91
|
-
elsif browser_text.match(/cannot find server or dns error/i)
|
92
|
-
msg = "#{fileName}----Cannot find server error or DNS error. (#{lnbr})"
|
93
|
-
myOK = false
|
94
|
-
|
95
|
-
elsif browser_text.match(/the rpc server is unavailable/i)
|
96
|
-
msg = "#{fileName}----RPC server unavailable. (#{lnbr})"
|
97
|
-
myOK = false
|
98
|
-
|
99
|
-
elsif browser_text.match(/404 not found/i) or
|
100
|
-
browser_text.match(/the page you were looking for does\s*n[o']t exist/i)
|
101
|
-
msg = "#{fileName}----RFC 2068 HTTP/1.1: 404 URI Not Found. (#{lnbr})"
|
102
|
-
myOK = false
|
103
|
-
|
104
|
-
elsif browser_text.match(/we're sorry, but something went wrong/i) or
|
105
|
-
browser_text.match(/http status 500/i)
|
106
|
-
msg = "#{fileName}----RFC 2068 HTTP/1.1: 500 Internal Server Error. (#{lnbr})"
|
107
|
-
myOK = false
|
108
|
-
|
109
|
-
elsif browser_text.match(/internet explorer cannot display the webpage/i)
|
110
|
-
msg = "#{fileName}----Probably RFC 2068 HTTP/1.1: 500 Internal Server Error. (#{lnbr})"
|
111
|
-
myOK = false
|
112
|
-
|
113
|
-
elsif browser_text.match(/503.*service unavailable/i)
|
114
|
-
msg = "#{fileName}----RFC 2068 HTTP/1.1: 503 Service Unavailable. (#{lnbr})"
|
115
|
-
myOK = false
|
116
|
-
|
117
|
-
elsif browser_text.match(/java.lang.NullPointerException/i)
|
118
|
-
msg = "#{fileName}----java.lang.NullPointerException. (#{lnbr})"
|
119
|
-
myOK = false
|
120
|
-
|
121
|
-
elsif browser_text.match(/due to unscheduled maintenance/i)
|
122
|
-
msg = "#{fileName}----Due to unscheduled maintenance. (#{lnbr})"
|
123
|
-
myOK = false
|
124
|
-
|
125
|
-
elsif browser_text.match(/network\s+error\s*(.+)$/i)
|
126
|
-
$1.chomp!
|
127
|
-
msg = "#{fileName}----Network Error #{$1}. (#{lnbr})"
|
128
|
-
myOK = false
|
129
|
-
|
130
|
-
elsif browser_text.match(/warning: page has expired/i)
|
131
|
-
msg = "#{fileName}----Page using information from form has expired. Not automatically resubmitted. (#{lnbr})"
|
132
|
-
myOK = false
|
133
|
-
|
134
|
-
elsif browser_text.match(/no backend server available/i)
|
135
|
-
msg = "#{fileName}----Cannot Reach Server (#{lnbr})"
|
136
|
-
myOK = false
|
137
|
-
|
138
|
-
elsif browser_text.match(/sign on\s+.+\s+unsuccessful/i)
|
139
|
-
msg = "#{fileName}----Invalid Id or Password (#{lnbr})"
|
140
|
-
myOK = false
|
141
|
-
|
142
|
-
elsif browser_text.match(/you are not authorized/i)
|
143
|
-
msg = "#{fileName}----Not authorized to view this page. (#{lnbr})"
|
144
|
-
myOK = false
|
145
|
-
|
146
|
-
elsif browser_text.match(/too many incorrect login attempts have been made/i)
|
147
|
-
msg = "#{fileName}----Invalid Id or Password. Too many tries. (#{lnbr})"
|
148
|
-
myOK = false
|
149
|
-
|
150
|
-
elsif browser_text.match(/system error\.\s+an error has occurred/i)
|
151
|
-
msg = "#{fileName}----System Error. An error has occurred. Please try again or call the Help Line for assistance. (#{lnbr})"
|
152
|
-
myOK = false
|
153
|
-
|
154
|
-
elsif browser_text.match(/Internal Server failure,\s+NSAPI plugin/i)
|
155
|
-
msg = "#{fileName}----Internal Server failure, NSAPI plugin. (#{lnbr})"
|
156
|
-
myOK = false
|
157
|
-
|
158
|
-
elsif browser_text.match(/Error Page/i)
|
159
|
-
msg = "#{fileName}----Error Page. (#{lnbr})"
|
160
|
-
myOK = false
|
161
|
-
|
162
|
-
elsif browser_text.match(/The website cannot display the page/i)
|
163
|
-
msg = "#{fileName}----HTTP 500. (#{lnbr})"
|
164
|
-
myOK = false
|
165
|
-
|
166
|
-
# elsif browser_text.match(/Insufficient Data/i)
|
167
|
-
# msg = "#{fileName}----Insufficient Data. (#{lnbr})"
|
168
|
-
# myOK = false
|
169
|
-
|
170
|
-
elsif browser_text.match(/The timeout period elapsed/i)
|
171
|
-
msg = "#{fileName}----Time out period elapsed or server not responding. (#{lnbr})"
|
172
|
-
myOK = false
|
173
|
-
|
174
|
-
elsif browser_text.match(/Unexpected\s+errors*\s+occur+ed\.\s+(?:-+)\s+(.+)/i)
|
175
|
-
msg = "#{fileName}----Unexpected errors occurred. #{$2.slice(0, 120)} (#{lnbr})"
|
176
|
-
if not browser_text.match(/close the window and try again/i)
|
177
|
-
myOK = false
|
178
|
-
else
|
179
|
-
debug_to_log("#{msg}")
|
180
|
-
end
|
181
|
-
|
182
|
-
elsif browser_text.match(/Server Error in (.+) Application\.\s+(?:-+)\s+(.+)/i)
|
183
|
-
msg = "#{fileName}----Server Error in #{1} Application. #{$2.slice(0, 100)} (#{lnbr})"
|
184
|
-
myOK = false
|
185
|
-
|
186
|
-
elsif browser_text.match(/Server Error in (.+) Application\./i)
|
187
|
-
msg = "#{fileName}----Server Error in #{1} Application. '#{browser_text.slice(0, 250)}...' (#{lnbr})"
|
188
|
-
myOK = false
|
189
|
-
|
190
|
-
elsif browser_text.match(/An error has occur+ed\. Please contact support/i)
|
191
|
-
msg = "#{fileName}----An error has occurred. Please contact support (#{lnbr})"
|
192
|
-
myOK = false
|
193
|
-
|
194
|
-
end
|
195
|
-
else
|
196
|
-
debug_to_log("browser.text returned nil")
|
197
|
-
end
|
35
|
+
def validate_message(browser, message)
|
36
|
+
if validate(browser, @myName, __LINE__)
|
37
|
+
message_to_log(message)
|
198
38
|
end
|
39
|
+
end
|
199
40
|
|
200
|
-
|
201
|
-
|
202
|
-
|
203
|
-
|
204
|
-
|
205
|
-
|
206
|
-
|
41
|
+
def validate_style_value(browser, element, how, what, type, expected, desc = '')
|
42
|
+
#TODO: works only with watir-webdriver
|
43
|
+
msg = "Expected CSS style #{type} value '#{expected}' in #{element} with #{how} = #{what}"
|
44
|
+
msg << " #{desc}" if desc.length > 0
|
45
|
+
case element
|
46
|
+
when :link
|
47
|
+
actual = browser.link(how => what).style type
|
48
|
+
when :button
|
49
|
+
actual = browser.button(how => what).style type
|
50
|
+
when :image
|
51
|
+
actual = browser.image(how => what).style type
|
52
|
+
when :span
|
53
|
+
actual = browser.span(how => what).style type
|
54
|
+
when :div
|
55
|
+
actual = browser.div(how => what).style type
|
56
|
+
end
|
57
|
+
if expected == actual
|
58
|
+
passed_to_log(msg)
|
207
59
|
else
|
208
|
-
|
209
|
-
return myOK
|
60
|
+
failed_to_log(msg)
|
210
61
|
end
|
211
|
-
|
212
62
|
rescue
|
213
|
-
|
214
|
-
if errmsg.match(msg)
|
215
|
-
errmsg = ''
|
216
|
-
end
|
217
|
-
bail_out(browser, lnbr, "#{msg} #{errmsg}")
|
63
|
+
failed_to_log( "Unable to validate #{msg} '#{$!}'")
|
218
64
|
end
|
219
65
|
|
220
|
-
|
221
|
-
|
222
|
-
def validate_message(browser, message)
|
223
|
-
if validate(browser, @myName, __LINE__)
|
224
|
-
message_to_log(message)
|
225
|
-
end
|
226
|
-
end
|
227
|
-
|
228
|
-
##### begin core validation methods #####
|
66
|
+
##### begin core validation methods #####
|
229
67
|
|
230
68
|
def arrays_match?(exp, act, dir, col, org = nil)
|
231
69
|
if exp == act
|
@@ -242,7 +80,8 @@ related methods: rescue_me()
|
|
242
80
|
alias arrays_match arrays_match?
|
243
81
|
|
244
82
|
def enabled?(browser, element, how, what, desc = '')
|
245
|
-
msg = "#{element.to_s.titlecase} by #{how}=>'#{what}' is enabled.
|
83
|
+
msg = "#{element.to_s.titlecase} by #{how}=>'#{what}' is enabled.}"
|
84
|
+
msg << " #{desc}" if desc.length > 0
|
246
85
|
case element
|
247
86
|
when :textfield, :textarea, :text_area, :text_field
|
248
87
|
rtrn = browser.text_field(how, what).enabled? and not browser.text_field(how, what).readonly?
|
@@ -320,6 +159,7 @@ related methods: rescue_me()
|
|
320
159
|
alias validate_disabled disabled?
|
321
160
|
|
322
161
|
def verify_text_in_table_with_text(table, text, value)
|
162
|
+
#TODO This needs clarification, renaming
|
323
163
|
msg = "Table :id=>#{table.id} with text '#{text} contains '#{value}."
|
324
164
|
index = get_index_of_row_with_text(table, text)
|
325
165
|
if table[index].text =~ value
|
@@ -400,6 +240,24 @@ related methods: rescue_me()
|
|
400
240
|
alias checkbox_checked? checked?
|
401
241
|
alias checkbox_set? checked?
|
402
242
|
|
243
|
+
def not_checked?(browser, how, what, desc = '')
|
244
|
+
msg = "Checkbox #{how}=>#{what} is not checked."
|
245
|
+
msg << " #{desc}" if desc.length > 0
|
246
|
+
if not browser.checkbox(how, what).checked?
|
247
|
+
if validate(browser, @myName, __LINE__)
|
248
|
+
passed_to_log(msg)
|
249
|
+
true
|
250
|
+
end
|
251
|
+
else
|
252
|
+
failed_to_log(msg)
|
253
|
+
end
|
254
|
+
rescue
|
255
|
+
failed_to_log("Unable to validate #{msg}: '#{$!}'")
|
256
|
+
end
|
257
|
+
|
258
|
+
alias checkbox_checked? checked?
|
259
|
+
alias checkbox_set? checked?
|
260
|
+
|
403
261
|
def exists?(browser, element, how, what, value = nil, desc = '')
|
404
262
|
msg = "#{element.to_s.titlecase} with #{how}=>'#{what}' "
|
405
263
|
msg << "and value=>'#{value}' " if value
|
@@ -433,6 +291,7 @@ related methods: rescue_me()
|
|
433
291
|
alias not_exist? does_not_exist?
|
434
292
|
|
435
293
|
def set?(browser, how, what, desc = '', no_fail = false)
|
294
|
+
#TODO Needs to handle radio value as well
|
436
295
|
msg = "Radio #{how}=>#{what} is selected."
|
437
296
|
msg << " #{desc}" if desc.length > 0
|
438
297
|
if browser.radio(how, what).set?
|
@@ -455,25 +314,90 @@ related methods: rescue_me()
|
|
455
314
|
alias radio_checked? set?
|
456
315
|
alias radio_selected? set?
|
457
316
|
|
458
|
-
def
|
317
|
+
def not_set?(browser, how, what, desc = '', no_fail = false)
|
318
|
+
#TODO Needs to handle radio value as well
|
319
|
+
msg = "Radio #{how}=>#{what} is not selectedd."
|
320
|
+
msg << " #{desc}" if desc.length > 0
|
321
|
+
if not browser.radio(how, what).set?
|
322
|
+
if validate(browser, @myName, __LINE__)
|
323
|
+
passed_to_log(msg)
|
324
|
+
true
|
325
|
+
end
|
326
|
+
else
|
327
|
+
if no_fail
|
328
|
+
passed_to_log("Radio #{how}=>#{what} is not selected.")
|
329
|
+
else
|
330
|
+
failed_to_log(msg)
|
331
|
+
end
|
332
|
+
end
|
333
|
+
rescue
|
334
|
+
failed_to_log("Unable to validate #{msg}: '#{$!}'")
|
335
|
+
end
|
336
|
+
|
337
|
+
alias radio_not_set? not_set?
|
338
|
+
alias radio_not_checked? not_set?
|
339
|
+
alias radio_not_selected? not_set?
|
340
|
+
|
341
|
+
def radio_with_value_set?(browser, how, what, value, desc = '', no_fail = false)
|
342
|
+
msg = "Radio #{how}=>#{what} :value=>#{value} is selected."
|
343
|
+
msg << " #{desc}" if desc.length > 0
|
344
|
+
if browser.radio(how, what, value).set?
|
345
|
+
if validate(browser, @myName, __LINE__)
|
346
|
+
passed_to_log(msg)
|
347
|
+
true
|
348
|
+
end
|
349
|
+
else
|
350
|
+
if no_fail
|
351
|
+
passed_to_log("Radio #{how}=>#{what} :value=>#{value} is not selected.")
|
352
|
+
else
|
353
|
+
failed_to_log(msg)
|
354
|
+
end
|
355
|
+
end
|
356
|
+
rescue
|
357
|
+
failed_to_log("Unable to validate #{msg}: '#{$!}'")
|
358
|
+
end
|
359
|
+
|
360
|
+
alias radio_set_with_value? radio_with_value_set?
|
361
|
+
|
362
|
+
def select_list_includes?(browser, how, what, option, desc = '')
|
363
|
+
msg = "Select list #{how}=>#{what} includes option '#{option}'."
|
364
|
+
msg << " #{desc}" if desc.length > 0
|
459
365
|
select_list = browser.select_list(how, what)
|
460
366
|
options = select_list.options
|
461
367
|
if option
|
462
368
|
if options.include?(option)
|
463
|
-
passed_to_log(
|
369
|
+
passed_to_log(msg)
|
464
370
|
true
|
465
371
|
else
|
466
|
-
failed_to_log(
|
372
|
+
failed_to_log(msg)
|
467
373
|
nil
|
468
374
|
end
|
469
375
|
end
|
470
376
|
rescue
|
471
|
-
failed_to_log("Unable to verify
|
377
|
+
failed_to_log("Unable to verify #{msg}. '#{$!}'")
|
472
378
|
end
|
473
379
|
|
474
380
|
alias validate_select_list_contains select_list_includes?
|
475
381
|
alias select_list_contains? select_list_includes?
|
476
382
|
|
383
|
+
def select_list_does_not_include?(browser, how, what, option, desc = '')
|
384
|
+
msg = "Select list #{how}=>#{what} does not include option '#{option}'."
|
385
|
+
msg << " #{desc}" if desc.length > 0
|
386
|
+
select_list = browser.select_list(how, what)
|
387
|
+
options = select_list.options
|
388
|
+
if option
|
389
|
+
if not options.include?(option)
|
390
|
+
passed_to_log(msg)
|
391
|
+
true
|
392
|
+
else
|
393
|
+
failed_to_log(msg)
|
394
|
+
nil
|
395
|
+
end
|
396
|
+
end
|
397
|
+
rescue
|
398
|
+
failed_to_log("Unable to verify #{msg}. '#{$!}'")
|
399
|
+
end
|
400
|
+
|
477
401
|
def string_equals?(actual, target, desc = '')
|
478
402
|
msg = "Assert actual '#{actual}' equals expected '#{target}'. #{desc} "
|
479
403
|
if actual == target
|
@@ -491,6 +415,20 @@ related methods: rescue_me()
|
|
491
415
|
alias text_equals string_equals?
|
492
416
|
alias text_equals? string_equals?
|
493
417
|
|
418
|
+
def string_does_not_equal?(strg, target, desc = '')
|
419
|
+
msg = "String '#{strg}' does not equal '#{target}'."
|
420
|
+
msg << " '#{desc}' " if desc.length > 0
|
421
|
+
if strg == target
|
422
|
+
failed_to_log("#{msg} (#{__LINE__})")
|
423
|
+
true
|
424
|
+
else
|
425
|
+
passed_to_log("#{msg} (#{__LINE__})")
|
426
|
+
end
|
427
|
+
end
|
428
|
+
|
429
|
+
alias validate_string_not_equal string_does_not_equal?
|
430
|
+
alias validate_string_does_not_equal string_does_not_equal?
|
431
|
+
|
494
432
|
def read_only?(browser, element, how, what, value = nil, desc = '')
|
495
433
|
msg = "#{element.to_s.titlecase} with #{how}=>'#{what}' "
|
496
434
|
msg << "and value=>'#{value}' " if value
|
@@ -592,9 +530,8 @@ related methods: rescue_me()
|
|
592
530
|
##### end backward compatible methods #####
|
593
531
|
|
594
532
|
|
595
|
-
# TODO Deprecated: all util1 methods should be catching
|
596
|
-
# this issue
|
597
533
|
def link_enabled?(browser, strg)
|
534
|
+
#TODO Use enabled?()
|
598
535
|
count = string_count_in_string(browser.text, strg)
|
599
536
|
if count > 0
|
600
537
|
if browser.link(:text, strg).enabled?
|
@@ -615,9 +552,8 @@ related methods: rescue_me()
|
|
615
552
|
|
616
553
|
alias validate_link_enabled link_enabled?
|
617
554
|
|
618
|
-
# TODO Deprecated: all util1 methods should be catching
|
619
|
-
# this issue
|
620
555
|
def link_disabled?(browser, strg)
|
556
|
+
#TODO use disabled?()
|
621
557
|
count = string_count_in_string(browser.text, strg)
|
622
558
|
if count > 0
|
623
559
|
if browser.link(:text, strg).enabled?
|
@@ -678,6 +614,7 @@ related methods: rescue_me()
|
|
678
614
|
|
679
615
|
#Validate select list contains text
|
680
616
|
def validate_list_by_id(browser, strg, text, message, select_if_present=true)
|
617
|
+
#TODO Use select_list_includes?() ?
|
681
618
|
if browser.select_list(:id, strg).exists?
|
682
619
|
select_list = browser.select_list(:id, strg)
|
683
620
|
if select_list.include?(text)
|
@@ -708,6 +645,7 @@ related methods: rescue_me()
|
|
708
645
|
|
709
646
|
#Validate select list contains text
|
710
647
|
def validate_list_by_name(browser, strg, text, message, select_if_present=true)
|
648
|
+
#TODO Use select_list_includes?() ?
|
711
649
|
if browser.select_list(:name, strg).exists?
|
712
650
|
select_list = browser.select_list(:name, strg)
|
713
651
|
if select_list.include?(text)
|
@@ -737,34 +675,10 @@ related methods: rescue_me()
|
|
737
675
|
end
|
738
676
|
|
739
677
|
#Validate select list does not contain text
|
740
|
-
def validate_no_list(browser, id, text,
|
741
|
-
|
742
|
-
if validate(browser, @myName, __LINE__)
|
743
|
-
failed_to_log(message + " (#{__LINE__})")
|
744
|
-
end
|
745
|
-
else
|
746
|
-
passed_to_log(message + " (#{__LINE__})")
|
747
|
-
true
|
748
|
-
end
|
749
|
-
rescue
|
750
|
-
failed_to_log("Unable to validate that '#{text}' did not in select list with name='#{listName}: '#{$!}'. (#{__LINE__})")
|
678
|
+
def validate_no_list(browser, id, text, desc = '')
|
679
|
+
select_list_does_not_include?(browser, :id, id, text, desc)
|
751
680
|
end
|
752
681
|
|
753
|
-
def validate_resize(d, err, tol, min, act)
|
754
|
-
ary = [false, "failed, actual #{act} err #{err}"]
|
755
|
-
if err == 0
|
756
|
-
ary = [true, 'succeeded ']
|
757
|
-
#TODO need to find way to calculate this adjustment
|
758
|
-
elsif d <= min + 4
|
759
|
-
ary = [true, "reached minimum (#{min}) "]
|
760
|
-
elsif err.abs <= tol
|
761
|
-
ary = [true, "within tolerance (+-#{tol}px) "]
|
762
|
-
end
|
763
|
-
ary
|
764
|
-
end
|
765
|
-
|
766
|
-
alias validate_move validate_resize
|
767
|
-
|
768
682
|
def validate_text(browser, ptrn, desc = '', skip_fail = false, skip_sleep = false)
|
769
683
|
cls = browser.class.to_s
|
770
684
|
cls.gsub!('Watir::', '')
|
@@ -806,7 +720,7 @@ related methods: rescue_me()
|
|
806
720
|
msg = "Expected exact text '#{expected}' in #{element} :#{how}=>#{what}."
|
807
721
|
msg << " #{desc}" if desc.length > 0
|
808
722
|
text = ''
|
809
|
-
who
|
723
|
+
who = browser.element(how, what)
|
810
724
|
if who
|
811
725
|
text = who.text
|
812
726
|
if text == expected
|
@@ -827,7 +741,7 @@ related methods: rescue_me()
|
|
827
741
|
end
|
828
742
|
|
829
743
|
def element_contains_text?(browser, element, how, what, expected, desc = '')
|
830
|
-
msg = "
|
744
|
+
msg = "Element #{element} :{how}=>#{what} contains text '#{expected}'."
|
831
745
|
msg << " #{desc}" if desc.length > 0
|
832
746
|
who = browser.element(how, what)
|
833
747
|
if who
|
@@ -929,7 +843,6 @@ related methods: rescue_me()
|
|
929
843
|
failed_to_log("Unable to validate select_list: '#{$!}'", __LINE__)
|
930
844
|
end
|
931
845
|
|
932
|
-
|
933
846
|
def validate_select_list_contents(browser, how, what, list)
|
934
847
|
mark_testlevel("#{__method__.to_s.titleize} (#{what})", 2)
|
935
848
|
select_list = browser.select_list(how, what)
|
@@ -981,8 +894,9 @@ related methods: rescue_me()
|
|
981
894
|
alias validate_selections validate_selected_options
|
982
895
|
alias validate_select_list_selections validate_selected_options
|
983
896
|
|
984
|
-
def
|
985
|
-
msg = "
|
897
|
+
def string_contains?(strg, target, desc = '')
|
898
|
+
msg = "String '#{strg}' contains '#{target}'."
|
899
|
+
msg << " '#{desc}' " if desc.length > 0
|
986
900
|
if strg.match(target)
|
987
901
|
passed_to_log("#{msg} (#{__LINE__})")
|
988
902
|
true
|
@@ -991,10 +905,12 @@ related methods: rescue_me()
|
|
991
905
|
end
|
992
906
|
end
|
993
907
|
|
994
|
-
alias validate_string
|
908
|
+
alias validate_string string_contains?
|
909
|
+
alias validate_string_contains string_contains?
|
995
910
|
|
996
|
-
def
|
997
|
-
msg = "
|
911
|
+
def string_does_not_contain?(strg, target, desc = '')
|
912
|
+
msg = "String '#{strg}' does not contain '#{target}'."
|
913
|
+
msg << " '#{desc}' " if desc.length > 0
|
998
914
|
if strg.match(target)
|
999
915
|
failed_to_log("#{msg} (#{__LINE__})")
|
1000
916
|
true
|
@@ -1003,20 +919,9 @@ related methods: rescue_me()
|
|
1003
919
|
end
|
1004
920
|
end
|
1005
921
|
|
1006
|
-
alias validate_string_not_contains
|
1007
|
-
alias validate_string_not_contain
|
1008
|
-
|
1009
|
-
def validate_string_does_not_equal(strg, target, message = '')
|
1010
|
-
msg = "Assert '#{strg}' does not equal '#{target}'? #{message} "
|
1011
|
-
if strg == target
|
1012
|
-
failed_to_log("#{msg} (#{__LINE__})")
|
1013
|
-
true
|
1014
|
-
else
|
1015
|
-
passed_to_log("#{msg} (#{__LINE__})")
|
1016
|
-
end
|
1017
|
-
end
|
1018
|
-
|
1019
|
-
alias validate_string_not_equal validate_string_does_not_equal
|
922
|
+
alias validate_string_not_contains string_does_not_contain?
|
923
|
+
alias validate_string_not_contain string_does_not_contain?
|
924
|
+
alias validate_string_does_not_contain string_does_not_contain?
|
1020
925
|
|
1021
926
|
def validate_no_text(browser, ptrn, desc = '')
|
1022
927
|
cls = browser.class.to_s
|
@@ -1042,10 +947,10 @@ related methods: rescue_me()
|
|
1042
947
|
failed_to_log("Unable to validate #{msg}: '#{$!}'")
|
1043
948
|
end
|
1044
949
|
|
1045
|
-
def
|
1046
|
-
msg = "Text field #{how}=>#{what} does not
|
950
|
+
def textfield_does_not_equal?(browser, how, what, expected, desc = '')
|
951
|
+
msg = "Text field #{how}=>#{what} does not equal '#{expected}'"
|
1047
952
|
msg << " #{desc}" if desc.length > 0
|
1048
|
-
if not browser.text_field(how, what).value ==
|
953
|
+
if not browser.text_field(how, what).value == expected
|
1049
954
|
if validate(browser, @myName, __LINE__)
|
1050
955
|
passed_to_log(msg)
|
1051
956
|
true
|
@@ -1057,21 +962,23 @@ related methods: rescue_me()
|
|
1057
962
|
failed_to_log("Unable to validate that #{msg}: '#{$!}'")
|
1058
963
|
end
|
1059
964
|
|
965
|
+
alias validate_textfield_not_value textfield_does_not_equal?
|
966
|
+
|
1060
967
|
###################################
|
1061
968
|
def validate_textfield_not_value_by_name(browser, name, value, desc = '')
|
1062
|
-
|
969
|
+
textfield_does_not_equal?(browser, :name, name, value, desc)
|
1063
970
|
end
|
1064
971
|
|
1065
972
|
alias validate_textfield_no_value_by_name validate_textfield_not_value_by_name
|
1066
973
|
|
1067
974
|
###################################
|
1068
975
|
def validate_textfield_not_value_by_id(browser, id, value, desc = '')
|
1069
|
-
|
976
|
+
textfield_does_not_equal?(browser, :id, id, value, desc)
|
1070
977
|
end
|
1071
978
|
|
1072
979
|
alias validate_textfield_no_value_by_id validate_textfield_not_value_by_id
|
1073
980
|
|
1074
|
-
def
|
981
|
+
def textfield_empty?(browser, how, what, desc = '')
|
1075
982
|
msg = "Text field #{how}=>#{what} is empty."
|
1076
983
|
msg << desc if desc.length > 0
|
1077
984
|
value = browser.text_field(how, what).value
|
@@ -1087,6 +994,9 @@ related methods: rescue_me()
|
|
1087
994
|
failed_to_log("Unable to validate #{msg} '#{$!}'")
|
1088
995
|
end
|
1089
996
|
|
997
|
+
alias validate_textfield_empty textfield_empty?
|
998
|
+
alias text_field_empty? textfield_empty?
|
999
|
+
|
1090
1000
|
def validate_textfield_empty_by_name(browser, name, message = '')
|
1091
1001
|
validate_textfield_empty(browser, :name, name, message)
|
1092
1002
|
end
|
@@ -1099,7 +1009,7 @@ related methods: rescue_me()
|
|
1099
1009
|
validate_textfield_empty(browser, :title, title, message)
|
1100
1010
|
end
|
1101
1011
|
|
1102
|
-
def
|
1012
|
+
def textfield_equals?(browser, how, what, expected, desc = '')
|
1103
1013
|
msg = "Expected '#{expected}' in textfield #{how}=>'#{what}'. #{desc}"
|
1104
1014
|
actual = browser.text_field(how, what).value
|
1105
1015
|
if actual.is_a?(Array)
|
@@ -1133,6 +1043,9 @@ related methods: rescue_me()
|
|
1133
1043
|
failed_to_log("Unable to validate #{msg}: '#{$!}")
|
1134
1044
|
end
|
1135
1045
|
|
1046
|
+
alias validate_textfield_value textfield_equals?
|
1047
|
+
alias text_field_equals? textfield_equals?
|
1048
|
+
|
1136
1049
|
def validate_textfield_dollar_value(browser, how, what, expected, with_cents = true, desc = '')
|
1137
1050
|
desc << " Dollar formatting"
|
1138
1051
|
if with_cents
|
@@ -1142,69 +1055,37 @@ related methods: rescue_me()
|
|
1142
1055
|
expected.gsub!(/\.00$/, '')
|
1143
1056
|
desc << ' with cents.'
|
1144
1057
|
end
|
1145
|
-
|
1058
|
+
textfield_equals?(browser, how, what, expected, desc)
|
1146
1059
|
end
|
1147
1060
|
|
1148
1061
|
def validate_textfield_value_by_name(browser, name, expected, desc = '')
|
1149
|
-
|
1062
|
+
textfield_equals?(browser, :name, name, expected, desc)
|
1150
1063
|
end
|
1151
1064
|
|
1152
1065
|
def validate_textfield_value_by_id(browser, id, expected, desc = '')
|
1153
|
-
|
1066
|
+
textfield_equals?(browser, :id, id, expected, desc)
|
1154
1067
|
end
|
1155
1068
|
|
1156
1069
|
def validate_textfield_visible_by_name(browser, strg, desc = '')
|
1157
|
-
|
1158
|
-
if browser.text_field(:name, strg).visible?
|
1159
|
-
passed_to_log("Textfield with :name='#{strg}' is visible as expected. #{desc}")
|
1160
|
-
true
|
1161
|
-
else
|
1162
|
-
failed_to_log("Textfield with :name='#{strg}' is not visible. #{desc}")
|
1163
|
-
end
|
1164
|
-
rescue
|
1165
|
-
failed_to_log("Unable to validate textfield with :name=>'#{strg}' is visible. #{desc}: '#{$!}'. (#{__LINE__})")
|
1070
|
+
visible?(browser, :text_field, :name, strg, desc)
|
1166
1071
|
end
|
1167
1072
|
|
1168
1073
|
alias visible_textfield_by_name validate_textfield_visible_by_name
|
1169
1074
|
|
1170
1075
|
def validate_textfield_disabled_by_name(browser, strg, desc = '')
|
1171
|
-
|
1172
|
-
if browser.text_field(:name, strg).disabled?
|
1173
|
-
passed_to_log("Textfield with :name='#{strg}' is disabled as expected. #{desc}")
|
1174
|
-
true
|
1175
|
-
else
|
1176
|
-
failed_to_log("Textfield with :name='#{strg}' is not disabled. #{desc}")
|
1177
|
-
end
|
1178
|
-
rescue
|
1179
|
-
failed_to_log("Unable to validate textfield with :name=>'#{strg}' is disabled. #{desc}: '#{$!}'. (#{__LINE__})")
|
1076
|
+
disabled?(browser, :text_field, :name, strg, desc)
|
1180
1077
|
end
|
1181
1078
|
|
1182
1079
|
alias disabled_textfield_by_name validate_textfield_disabled_by_name
|
1183
1080
|
|
1184
1081
|
def validate_textfield_enabled_by_name(browser, strg, desc = '')
|
1185
|
-
|
1186
|
-
if browser.text_field(:name, strg).enabled?
|
1187
|
-
passed_to_log("Textfield with :name='#{strg}' is enabled as expected. #{desc}")
|
1188
|
-
true
|
1189
|
-
else
|
1190
|
-
failed_to_log("Textfield with :name='#{strg}' is not enabled. #{desc}")
|
1191
|
-
end
|
1192
|
-
rescue
|
1193
|
-
failed_to_log("Unable to validate textfield with :name=>'#{strg}' is enabled. #{desc}: '#{$!}'. (#{__LINE__})")
|
1082
|
+
enabled?(browser, :text_field, :name, strg, desc)
|
1194
1083
|
end
|
1195
1084
|
|
1196
1085
|
alias enabled_textfield_by_name validate_textfield_enabled_by_name
|
1197
1086
|
|
1198
1087
|
def validate_textfield_not_visible_by_name(browser, strg, desc = '')
|
1199
|
-
|
1200
|
-
if browser.text_field(:name, strg).visible?
|
1201
|
-
failed_to_log("Textfield with :name='#{strg}' is visible. #{desc}")
|
1202
|
-
true
|
1203
|
-
else
|
1204
|
-
passed_to_log("Textfield with :name='#{strg}' is not visible as expected. #{desc}")
|
1205
|
-
end
|
1206
|
-
rescue
|
1207
|
-
failed_to_log("Unable to validate textfield with :name=>'#{strg}' is not visible. #{desc}: '#{$!}'. (#{__LINE__})")
|
1088
|
+
not_visible?(browser, :text_field, :name, strg, desc)
|
1208
1089
|
end
|
1209
1090
|
|
1210
1091
|
alias visible_no_textfield_by_name validate_textfield_not_visible_by_name
|
@@ -1260,56 +1141,24 @@ related methods: rescue_me()
|
|
1260
1141
|
alias validate_check checked_by_id?
|
1261
1142
|
alias checkbox_is_checked? checked_by_id?
|
1262
1143
|
|
1263
|
-
def checkbox_is_enabled?(browser, strg,
|
1264
|
-
|
1265
|
-
passed_to_log(message, __LINE__)
|
1266
|
-
true
|
1267
|
-
else
|
1268
|
-
failed_to_log("Not Enabled. (#{__LINE__})")
|
1269
|
-
end
|
1270
|
-
rescue
|
1271
|
-
failed_to_log("Unable to validate check box with id=#{strg}: '#{$!}'. (#{__LINE__})")
|
1144
|
+
def checkbox_is_enabled?(browser, strg, desc = '')
|
1145
|
+
enabled?(browser, :checkbox, :id, strg, desc)
|
1272
1146
|
end
|
1273
1147
|
|
1274
1148
|
alias validate_check_enabled checkbox_is_enabled?
|
1275
1149
|
|
1276
|
-
def checkbox_is_disabled?(browser, strg,
|
1277
|
-
|
1278
|
-
passed_to_log(message, __LINE__)
|
1279
|
-
true
|
1280
|
-
else
|
1281
|
-
failed_to_log("Not Disabled. (#{__LINE__})")
|
1282
|
-
end
|
1283
|
-
rescue
|
1284
|
-
failed_to_log("Unable to validate check box with id=#{strg}: '#{$!}'. (#{__LINE__})")
|
1150
|
+
def checkbox_is_disabled?(browser, strg, desc = '')
|
1151
|
+
disabled?(browser, :checkbox, :id, strg, desc)
|
1285
1152
|
end
|
1286
1153
|
|
1287
1154
|
alias validate_check_disabled checkbox_is_disabled?
|
1288
1155
|
|
1289
|
-
def validate_check_by_class(browser, strg,
|
1290
|
-
|
1291
|
-
if validate(browser, @myName, __LINE__)
|
1292
|
-
passed_to_log(message)
|
1293
|
-
true
|
1294
|
-
end
|
1295
|
-
else
|
1296
|
-
failed_to_log(message + " (#{__LINE__})")
|
1297
|
-
end
|
1298
|
-
rescue
|
1299
|
-
failed_to_log("Unable to validate check box with id=#{strg}: '#{$!}'. (#{__LINE__})")
|
1156
|
+
def validate_check_by_class(browser, strg, desc)
|
1157
|
+
checked?(browser, :class, strg, desc)
|
1300
1158
|
end
|
1301
1159
|
|
1302
|
-
def checkbox_not_checked?(browser, strg,
|
1303
|
-
|
1304
|
-
if validate(browser, @myName, __LINE__)
|
1305
|
-
failed_to_log(message + " (#{__LINE__})")
|
1306
|
-
end
|
1307
|
-
else
|
1308
|
-
passed_to_log(message)
|
1309
|
-
true
|
1310
|
-
end
|
1311
|
-
rescue
|
1312
|
-
failed_to_log("Unable to validate radio with id=#{strg}: '#{$!}'. (#{__LINE__})")
|
1160
|
+
def checkbox_not_checked?(browser, strg, desc)
|
1161
|
+
not_checked?(browser, :id, strg, desc)
|
1313
1162
|
end
|
1314
1163
|
|
1315
1164
|
alias validate_not_check checkbox_not_checked?
|
@@ -1327,182 +1176,4 @@ related methods: rescue_me()
|
|
1327
1176
|
failed_to_log("Unable to validate that '#{+source}' image appeared in page: '#{$!}'. (#{__LINE__})")
|
1328
1177
|
end
|
1329
1178
|
|
1330
|
-
#TODO unstub
|
1331
|
-
def verify_column_hidden(browser, panel, table_index, column_name)
|
1332
|
-
passed_to_log("TEST STUBBED: Column '#{column_name}' is hidden.")
|
1333
|
-
return true
|
1334
|
-
# id = @column_data_display_ids[column_name]
|
1335
|
-
# ok = false
|
1336
|
-
|
1337
|
-
# row = panel.tables[2][3]
|
1338
|
-
|
1339
|
-
# row.each do |cell|
|
1340
|
-
## strg = cell.to_s
|
1341
|
-
## insp = cell.inspect
|
1342
|
-
## ole = cell.ole_object
|
1343
|
-
## anId = cell.attribute_value(:id)
|
1344
|
-
# text = cell.text
|
1345
|
-
# if text =~ /#{id}/
|
1346
|
-
# if cell.to_s =~ /hidden/
|
1347
|
-
# passed_to_log( "Column '#{column_name}' is hidden.")
|
1348
|
-
# else
|
1349
|
-
# failed_to_log( "Column '#{column_name}' is not hidden.")
|
1350
|
-
# end
|
1351
|
-
# ok = true
|
1352
|
-
# end
|
1353
|
-
# end
|
1354
|
-
# if not ok
|
1355
|
-
# failed_to_log( "Column '#{column_name}' not found.")
|
1356
|
-
# end
|
1357
|
-
# rescue
|
1358
|
-
# failed_to_log("Unable to verify column '#{column_name}' is hidden: '#{$!}' (#{__LINE__})")
|
1359
|
-
end
|
1360
|
-
|
1361
|
-
#TODO unstub
|
1362
|
-
def verify_column_hidden_temp_ff(browser, data_index, row_index, column_name)
|
1363
|
-
passed_to_log("TEST STUBBED: Column '#{column_name}' is hidden.")
|
1364
|
-
return true
|
1365
|
-
|
1366
|
-
row = browser.tables[data_index][row_index]
|
1367
|
-
# debug_to_log( "#{row.to_a}")
|
1368
|
-
#TODO cells are all still there in the row. Need to check for clue to hidden/visible in other tag attributes
|
1369
|
-
act_ary = get_row_cells_text_as_array(row)
|
1370
|
-
|
1371
|
-
if not act_ary.include?(column_name)
|
1372
|
-
passed_to_log("Column '#{column_name}' is hidden.")
|
1373
|
-
else
|
1374
|
-
failed_to_log("Column '#{column_name}' is not hidden.")
|
1375
|
-
end
|
1376
|
-
end
|
1377
|
-
|
1378
|
-
#TODO unstub
|
1379
|
-
def verify_column_visible_temp_ff(browser, data_index, row_index, column_name)
|
1380
|
-
passed_to_log("TEST STUBBED: Column '#{column_name}' is visible.")
|
1381
|
-
return true
|
1382
|
-
|
1383
|
-
row = browser.tables[data_index][row_index]
|
1384
|
-
#TODO cells are all still there in the row. Need to check for clue to hidden/visible in other tag attributes
|
1385
|
-
act_ary = get_row_cells_text_as_array(row)
|
1386
|
-
|
1387
|
-
if act_ary.include?(column_name)
|
1388
|
-
passed_to_log("Column '#{column_name}' is visible.")
|
1389
|
-
else
|
1390
|
-
failed_to_log("Column '#{column_name}' is not visible.")
|
1391
|
-
end
|
1392
|
-
end
|
1393
|
-
|
1394
|
-
#TODO unstub
|
1395
|
-
def verify_column_visible(browser, panel, table_index, column_name)
|
1396
|
-
|
1397
|
-
passed_to_log("TEST STUBBED: Column '#{column_name}' is visible.")
|
1398
|
-
return true
|
1399
|
-
|
1400
|
-
# id = @column_data_display_ids[column_name]
|
1401
|
-
# ok = false
|
1402
|
-
# row = panel.tables[table_index][1]
|
1403
|
-
# row.each do |cell|
|
1404
|
-
# if cell.id == id
|
1405
|
-
# if not cell.to_s =~ /hidden/
|
1406
|
-
# passed_to_log("Column '#{column_name}' is visible.")
|
1407
|
-
# else
|
1408
|
-
# failed_to_log("Column '#{column_name}' is not visible.")
|
1409
|
-
# end
|
1410
|
-
# ok = true
|
1411
|
-
# end
|
1412
|
-
# end
|
1413
|
-
# if not ok
|
1414
|
-
# failed_to_log("Column '#{column_name}' not found.")
|
1415
|
-
# end
|
1416
|
-
rescue
|
1417
|
-
failed_to_log("Unable to verify column '#{column_name} is visible': '#{$!}' (#{__LINE__})")
|
1418
|
-
end
|
1419
|
-
|
1420
|
-
def verify_column_order(browser, table_index, row_index, exp_ary)
|
1421
|
-
mark_testlevel("Verify Column Order", 2)
|
1422
|
-
row = browser.tables[table_index][row_index]
|
1423
|
-
act_ary = get_row_cells_text_as_array(row)
|
1424
|
-
|
1425
|
-
if exp_ary == act_ary
|
1426
|
-
passed_to_log("Column order [#{act_ary.join(', ')}] appeared as expected.")
|
1427
|
-
else
|
1428
|
-
failed_to_log("Column order [#{act_ary.join(', ')}] not as expected [#{exp_ary.join(', ')}].")
|
1429
|
-
end
|
1430
|
-
sleep_for(1)
|
1431
|
-
end
|
1432
|
-
|
1433
|
-
def verify_column_sort(browser, nc_element, strg, table_index, column_index=nil)
|
1434
|
-
mark_testlevel("Verify Column Sort '#{strg}'", 3)
|
1435
|
-
if not column_index
|
1436
|
-
column_index = get_index_for_column_head(nc_element, table_index, strg)
|
1437
|
-
end
|
1438
|
-
|
1439
|
-
if column_index
|
1440
|
-
bfr_ary = fetch_array_for_table_column(nc_element, table_index, column_index)
|
1441
|
-
if strg =~ /date/i
|
1442
|
-
exp_ary = bfr_ary.sort { |x, y| Date.parse(x) <=> Date.parse(y) }
|
1443
|
-
else
|
1444
|
-
exp_ary = bfr_ary.sort { |x, y| x.gsub(',', '') <=> y.gsub(',', '') }
|
1445
|
-
end
|
1446
|
-
|
1447
|
-
if click_text(browser, strg)
|
1448
|
-
if column_index
|
1449
|
-
sleep_for(2.5)
|
1450
|
-
else
|
1451
|
-
sleep_for(1)
|
1452
|
-
end
|
1453
|
-
act_ary = fetch_array_for_table_column(nc_element, table_index, column_index)
|
1454
|
-
|
1455
|
-
if exp_ary == act_ary
|
1456
|
-
passed_to_log("Click on column '#{strg}' produces expected sorted list.")
|
1457
|
-
true
|
1458
|
-
else
|
1459
|
-
failed_to_log("Click on column '#{strg}' fails to produce expected sorted list.")
|
1460
|
-
debug_to_log("Original order ['#{bfr_ary.join("', '")}']")
|
1461
|
-
debug_to_log("Expected order ['#{exp_ary.join("', '")}']")
|
1462
|
-
debug_to_log(" Actual order ['#{act_ary.join("', '")}']")
|
1463
|
-
end
|
1464
|
-
end
|
1465
|
-
else
|
1466
|
-
failed_to_log("Unable to locate column index for '#{strg}' to verify sort.")
|
1467
|
-
end
|
1468
|
-
rescue
|
1469
|
-
failed_to_log("Unable to verify sort on column '#{strg}'. #{$!}")
|
1470
|
-
end
|
1471
|
-
|
1472
|
-
def verify_column_sort_temp_ff(browser, strg, table_index, column_index=nil)
|
1473
|
-
mark_testlevel("Verify Column Sort '#{strg}'", 3)
|
1474
|
-
|
1475
|
-
if not column_index
|
1476
|
-
column_index = get_index_for_column_head(browser, table_index, strg)
|
1477
|
-
end
|
1478
|
-
|
1479
|
-
if column_index
|
1480
|
-
bfr_ary = fetch_array_for_table_column(browser, table_index, column_index)
|
1481
|
-
if strg =~ /date/i
|
1482
|
-
exp_ary = bfr_ary.sort { |x, y| Date.parse(x) <=> Date.parse(y) }
|
1483
|
-
else
|
1484
|
-
exp_ary = bfr_ary.sort { |x, y| x.gsub(',', '') <=> y.gsub(',', '') }
|
1485
|
-
end
|
1486
|
-
|
1487
|
-
if click_text(browser, strg)
|
1488
|
-
sleep_for(3)
|
1489
|
-
act_ary = fetch_array_for_table_column(browser, table_index, column_index)
|
1490
|
-
|
1491
|
-
if exp_ary == act_ary
|
1492
|
-
passed_to_log("Click on column '#{strg}' produces expected sorted list.")
|
1493
|
-
true
|
1494
|
-
else
|
1495
|
-
failed_to_log("Click on column '#{strg}' fails to produce expected sorted list.")
|
1496
|
-
debug_to_log("Original order ['#{bfr_ary.join("', '")}']")
|
1497
|
-
debug_to_log("Expected order ['#{exp_ary.join("', '")}']")
|
1498
|
-
debug_to_log(" Actual order ['#{act_ary.join("', '")}']")
|
1499
|
-
end
|
1500
|
-
end
|
1501
|
-
else
|
1502
|
-
failed_to_log("Unable to locate column index for '#{strg}' to verify sort.")
|
1503
|
-
end
|
1504
|
-
rescue
|
1505
|
-
failed_to_log("Unable to verify sort on column '#{strg}'. #{$!}")
|
1506
|
-
end
|
1507
|
-
|
1508
1179
|
end
|