awetestlib 0.1.3-x86-mingw32 → 0.1.5-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.
Files changed (50) hide show
  1. data/awetestlib.windows.gemspec +1 -1
  2. data/bin/awetestlib +11 -4
  3. data/bin/awetestlib-helpers.rb +28 -1
  4. data/bin/awetestlib-netbeans-setup.rb +39 -0
  5. data/bin/awetestlib-rubymine-setup.rb +33 -0
  6. data/images/logo.png +0 -0
  7. data/lib/awetestlib/html_report.rb +171 -0
  8. data/lib/{regression → awetestlib}/logging.rb +10 -43
  9. data/lib/awetestlib/regression/browser.rb +1233 -0
  10. data/lib/awetestlib/regression/drag_and_drop.rb +379 -0
  11. data/lib/awetestlib/regression/find.rb +431 -0
  12. data/lib/awetestlib/regression/legacy.rb +45 -0
  13. data/lib/awetestlib/regression/page_data.rb +190 -0
  14. data/lib/awetestlib/regression/runner.rb +306 -0
  15. data/lib/awetestlib/regression/tables.rb +491 -0
  16. data/lib/awetestlib/regression/user_input.rb +1256 -0
  17. data/lib/awetestlib/regression/utilities.rb +895 -0
  18. data/lib/awetestlib/regression/validations.rb +1184 -0
  19. data/lib/awetestlib/regression/waits.rb +391 -0
  20. data/lib/awetestlib/runner.rb +16 -0
  21. data/lib/awetestlib.rb +4 -4
  22. data/lib/version.rb +2 -2
  23. data/setup_samples/sample_netbeans/demo.rb +86 -0
  24. data/setup_samples/sample_netbeans/nbproject/configs/Demo.properties +2 -0
  25. data/setup_samples/sample_netbeans/nbproject/private/config.properties +1 -0
  26. data/setup_samples/sample_netbeans/nbproject/private/configs/Demo.properties +1 -0
  27. data/setup_samples/sample_netbeans/nbproject/private/private.properties +2 -0
  28. data/setup_samples/sample_netbeans/nbproject/project.properties +5 -0
  29. data/setup_samples/sample_netbeans/nbproject/project.xml +13 -0
  30. data/setup_samples/sample_rubymine/.idea/.name +1 -0
  31. data/setup_samples/sample_rubymine/.idea/encodings.xml +5 -0
  32. data/setup_samples/sample_rubymine/.idea/misc.xml +5 -0
  33. data/setup_samples/sample_rubymine/.idea/modules.xml +9 -0
  34. data/setup_samples/sample_rubymine/.idea/sample_rubymine.iml +9 -0
  35. data/setup_samples/sample_rubymine/.idea/scopes/scope_settings.xml +5 -0
  36. data/setup_samples/sample_rubymine/.idea/vcs.xml +7 -0
  37. data/setup_samples/sample_rubymine/.idea/workspace.xml +213 -0
  38. data/setup_samples/sample_rubymine/demo.rb +86 -0
  39. metadata +44 -19
  40. data/lib/regression/browser.rb +0 -1259
  41. data/lib/regression/drag_and_drop.rb +0 -374
  42. data/lib/regression/find.rb +0 -426
  43. data/lib/regression/legacy.rb +0 -40
  44. data/lib/regression/page_data.rb +0 -185
  45. data/lib/regression/runner.rb +0 -278
  46. data/lib/regression/tables.rb +0 -486
  47. data/lib/regression/user_input.rb +0 -1255
  48. data/lib/regression/utilities.rb +0 -891
  49. data/lib/regression/validations.rb +0 -1179
  50. data/lib/regression/waits.rb +0 -387
@@ -1,891 +0,0 @@
1
- module Utilities
2
-
3
- # Place holder to prevent method not found error in scripts
4
- def set_script_variables
5
- # TODO: replace with method_missing?
6
- end
7
-
8
- def setup
9
- # if @os_sysname =~ /Windows.+Server\s+2003/
10
- ## 'Microsoft(R) Windows(R) Server 2003, Enterprise Edition'
11
- # @vertical_hack_ie = 110
12
- # @vertical_hack_ff = 138
13
- # @horizontal_hack_ie = 5
14
- # @horizontal_hack_ff = 4
15
- # elsif @os_sysname =~ /Windows XP Professional/
16
- # 'Microsoft Windows XP Professional'
17
- @vertical_hack_ie = 118
18
- @vertical_hack_ff = 144
19
- @horizontal_hack_ie = 5
20
- @horizontal_hack_ff = 4
21
- #end
22
-
23
- @settings_display_ids = Hash[
24
- "Currency" => "row-currencyName",
25
- "Description" => "row-description",
26
- "Tx Date" => "row-fmtDate",
27
- "Total" => "row-amount",
28
- "[currencyCode]" => "row-currencyCode",
29
- "Date in Millis" => "row-dateInMilliseconds",
30
- ]
31
- @column_data_display_ids = Hash[
32
- "Currency" => "yui-dt0-th-currencyName",
33
- "Description" => "yui-dt0-th-description",
34
- "Tx Date" => "yui-dt0-th-fmtDate",
35
- "Total" => "yui-dt0-th-fmtDate",
36
- "[currencyCode]" => "yui-dt0-th-currencyCode",
37
- "Date in Millis" => "yui-dt0-th-dateInMilliseconds",
38
- ]
39
- @settings_panel_index = 0
40
- @x_tolerance = 4
41
- @y_tolerance = 4
42
- end
43
-
44
- def get_trace(lnbr)
45
- callertrace = "\nCaller trace: (#{lnbr})\n"
46
- Kernel.caller.each_index do |x|
47
- callertrace << ' >> ' + Kernel.caller[x].to_s + "\n"
48
- end
49
- callertrace
50
- end
51
-
52
- alias dump_caller get_trace
53
-
54
- def get_mdyy(t = Time.now)
55
- "#{t.month}/#{t.day}/#{t.year}"
56
- end
57
-
58
- def get_prefix(strg, offset)
59
- a_slice = strg.slice(0, offset)
60
- a_slice.downcase
61
- end
62
-
63
- def get_timestamp(format = 'long', offset = nil, offset_unit = :years)
64
- t = DateTime.now
65
- if offset
66
- t = t.advance(offset_unit => offset)
67
- end
68
- case format
69
- when 'dateonly'
70
- t.strftime("%m/%d/%Y")
71
- when 'condensed'
72
- t.strftime("%Y%m%d%H%M")
73
- when 'condensed_seconds'
74
- t.strftime("%Y%m%d%H%M%S")
75
- when 'long'
76
- t.strftime("%m/%d/%Y %I:%M %p")
77
- when 'mdyy'
78
- get_mdyy(t)
79
- when 'm/d/y'
80
- get_mdyy(t)
81
- else
82
- Time.now.strftime("%m/%d/%Y %H:%M:%S")
83
- end
84
- end
85
-
86
- def calc_index(index, every = 1)
87
- (index / every) + (every - 1)
88
- end
89
-
90
- def get_variables(file, login = :role, dbg = true)
91
- debug_to_log("#{__method__}: file = #{file}")
92
- debug_to_log("#{__method__}: role = #{login}")
93
-
94
- @var = Hash.new
95
- workbook = Excel.new(file)
96
- data_index = find_sheet_with_name(workbook, 'Data')
97
- workbook.default_sheet = workbook.sheets[data_index]
98
- var_col = 0
99
-
100
- 2.upto(workbook.last_column) do |col|
101
- scriptName = workbook.cell(1, col)
102
- if scriptName == @myName
103
- var_col = col
104
- break
105
- end
106
- end
107
-
108
- 2.upto(workbook.last_row) do |line|
109
- name = workbook.cell(line, 'A')
110
- value = workbook.cell(line, var_col).to_s.strip
111
- @var[name] = value
112
- end
113
-
114
- @var.keys.sort.each do |name|
115
- message_tolog("@var #{name}: '#{@var[name]}'")
116
- end if dbg
117
-
118
- @login = Hash.new
119
- login_col = 0
120
- role_col = 0
121
- userid_col = 0
122
- password_col = 0
123
- url_col = 0
124
- name_col = 0
125
- role_index = find_sheet_with_name(workbook, 'Login')
126
- if role_index >= 0
127
- workbook.default_sheet = workbook.sheets[role_index]
128
-
129
- 1.upto(workbook.last_column) do |col|
130
- a_cell = workbook.cell(1, col)
131
- case a_cell
132
- when @myName
133
- login_col = col
134
- break
135
- when 'role'
136
- role_col = col
137
- when 'userid'
138
- userid_col = col
139
- when 'password'
140
- password_col = col
141
- when 'url'
142
- url_col = col
143
- when 'name'
144
- name_col = col
145
- end
146
- end
147
-
148
- 2.upto(workbook.last_row) do |line|
149
- role = workbook.cell(line, role_col)
150
- userid = workbook.cell(line, userid_col)
151
- password = workbook.cell(line, password_col)
152
- url = workbook.cell(line, url_col)
153
- username = workbook.cell(line, name_col)
154
- enabled = workbook.cell(line, login_col).to_s
155
-
156
- case login
157
- when :id
158
- key = userid
159
- when :role
160
- key = role
161
- else
162
- key = role
163
- end
164
-
165
- @login[key] = Hash.new
166
- @login[key]['role'] = role
167
- @login[key]['userid'] = userid
168
- @login[key]['password'] = password
169
- @login[key]['url'] = url
170
- @login[key]['name'] = username
171
- @login[key]['enabled'] = enabled
172
-
173
- end
174
-
175
- @login.keys.sort.each do |key|
176
- message_tolog("@login (by #{login}): #{key}=>'#{@login[key].to_yaml}'")
177
- end if dbg
178
- end
179
-
180
- rescue
181
- fatal_to_log("#{__method__}: '#{$!}'")
182
- end
183
-
184
- def translate_var_list(key)
185
- if @var[key] and @var[key].length > 0
186
- list = @var[key].dup
187
- unless list =~ /^\[.+\]$/
188
- list = "[#{list}]"
189
- end
190
- eval(list)
191
- end
192
- rescue
193
- failed_to_log("#{__method__}: '#{$!}'")
194
- end
195
-
196
- def grab_window_list(strg)
197
- @ai.AutoItSetOption("WinTitleMatchMode", 2)
198
- list = @ai.WinList(strg)
199
- stuff = ''
200
- names = list[0]
201
- handles = list[1]
202
- max = names.length - 1
203
- rng = Range.new(0, max)
204
- rng.each do |idx|
205
- window_handle = "[HANDLE:#{handles[idx]}]"
206
- full_text = @ai.WinGetText(window_handle)
207
- stuff << "[#{handles[idx]}]=>#{names[idx]}=>'#{full_text}'\n"
208
- end
209
- debug_to_log("\n#{stuff}")
210
- @ai.AutoItSetOption("WinTitleMatchMode", 1)
211
- stuff
212
- end
213
-
214
- def debug_call_list(msg)
215
- call_array = get_call_array
216
- debug_to_log("#{msg}\n#{dump_array(call_array)}")
217
- end
218
-
219
- def sec2hms(s)
220
- Time.at(s.to_i).gmtime.strftime('%H:%M:%S')
221
- end
222
-
223
- def close_log(scriptName, lnbr = '')
224
- cmplTS = Time.now.to_f.to_s
225
- puts ("#{scriptName} finished. Closing log. #{lnbr.to_s}")
226
- passed_to_log("#{scriptName} run complete [#{cmplTS}]")
227
- @myLog.close()
228
- sleep(2)
229
- end
230
-
231
- protected :close_log
232
-
233
- def find_sheet_with_name(workbook, sheet_name)
234
- sheets = workbook.sheets
235
- idx = 0
236
- found = false
237
- sheets.each do |s|
238
- if s == sheet_name
239
- found = true
240
- break
241
- end
242
- idx += 1
243
- end
244
- if found
245
- idx
246
- else
247
- -1
248
- end
249
- end
250
-
251
- def nice_array(arr, space_to_underscore = false)
252
- new_arr = Array.new
253
- if space_to_underscore
254
- arr.each do |nty|
255
- new_arr << nty.gsub(/\s/, '_')
256
- end
257
- else
258
- new_arr = arr
259
- end
260
- "['#{new_arr.join("','")}']"
261
- end
262
-
263
- def string_count_in_string(strg, substrg)
264
- count = strg.scan(substrg).length
265
- count
266
- end
267
-
268
- def rescue_me(e, me = nil, what = nil, where = nil, who = nil)
269
- #TODO: these are rescues from exceptions raised in Watir/Firewatir
270
- debug_to_log("#{__method__}: Begin rescue")
271
- ok = false
272
- begin
273
- gaak = who.inspect
274
- located = gaak =~ /located=true/i
275
- rescue
276
- debug_to_log("#{__method__}: gaak: '#{gaak}'")
277
- end
278
- msg = e.message
279
- debug_to_log("#{__method__}: msg = #{msg}")
280
- if msg =~ /undefined method\s+.join.\s+for/i # firewatir to_s implementation error
281
- ok = true
282
- elsif msg =~ /undefined method\s+.match.\s+for.+WIN32OLERuntimeError/i # watir and firewatir
283
- ok = true
284
- elsif msg =~ /undefined method\s+.match.\s+for.+UnknownObjectException/i # watir
285
- ok = true
286
- elsif msg =~ /window\.getBrowser is not a function/i # firewatir
287
- ok = true
288
- elsif msg =~ /WIN32OLERuntimeError/i # watir
289
- ok = true
290
- elsif msg =~ /undefined method\s+.match.\s+for/i # watir
291
- ok = true
292
- elsif msg =~ /wrong number of arguments \(1 for 0\)/i
293
- ok = true
294
- elsif (msg =~ /unable to locate element/i)
295
- if located
296
- ok = true
297
- elsif where == 'Watir::Div'
298
- ok = true
299
- end
300
- elsif (msg =~ /HRESULT error code:0x80070005/)
301
- ok = true
302
- #elsif msg =~ /missing\s+\;\s+before statement/
303
- # ok = true
304
- end
305
- if ok
306
- debug_to_log("#{__method__}: RESCUED: \n#{who.to_yaml}=> #{what} in #{me}()\n=> '#{$!}'")
307
- debug_to_log("#{__method__}: #{who.inspect}") if who
308
- debug_to_log("#{__method__}: #{where.inspect}")
309
- debug_to_log("#{__method__}: #{get_callers(6, true)}")
310
- else
311
- debug_to_log("#{__method__}: NO RESCUE: #{e.message}")
312
- debug_to_log("#{__method__}: NO RESCUE: \n#{get_callers(6, true)}")
313
- end
314
- debug_to_log("#{__method__}: Exit")
315
- ok
316
- end
317
-
318
- def get_caller_line
319
- last_caller = get_callers[0]
320
- line = last_caller.split(':', 3)[1]
321
- line
322
- end
323
-
324
- def get_call_list(depth = 9, dbg = false)
325
- myList = []
326
- call_list = Kernel.caller
327
- puts call_list if dbg
328
- call_list.each_index do |x|
329
- myCaller = call_list[x].to_s
330
- break if x > depth or myCaller =~ /:in .run.$/
331
- myCaller =~ /([\(\)\w_\_\-\.]+\:\d+\:?.*?)$/
332
- myList << "[#{$1.gsub(/eval/, @myName)}] "
333
- end
334
- myList
335
- end
336
-
337
- alias get_callers get_call_list
338
-
339
- def get_call_list_new(depth = 9, dbg = false)
340
- myList = []
341
- call_list = Kernel.caller
342
- puts call_list if dbg
343
- call_list.each_index do |x|
344
- myCaller = call_list[x].to_s
345
- break if x > depth or myCaller =~ /:in .run.$/
346
- if myCaller.include? @myName
347
- myCaller =~ /([\(\)\w_\_\-\.]+\:\d+\:?.*?)$/
348
- myList << "[#{$1.gsub(/eval/, @myName)}] "
349
- break
350
- end
351
- end
352
- if @projName
353
- call_list.each_index do |x|
354
- myCaller = call_list[x].to_s
355
- break if x > depth or myCaller =~ /:in .run.$/
356
- if myCaller.include? @projName
357
- myCaller =~ /([\(\)\w_\_\-\.]+\:\d+\:?.*?)$/
358
- myList << "[#{$1.gsub(/eval/, @projName)}] "
359
- break
360
- end
361
- end
362
- end
363
- myList
364
- end
365
-
366
- def get_call_array(depth = 9)
367
- arr = []
368
- call_list = Kernel.caller
369
- call_list.each_index do |x|
370
- myCaller = call_list[x].to_s
371
- break if x > depth or myCaller =~ /:in .run.$/
372
- myCaller =~ /([\(\)\w_\_\-\.]+\:\d+\:?.*?)$/
373
- arr << $1.gsub(/eval/, @myName)
374
- end
375
- arr
376
- end
377
-
378
- def get_debug_list(dbg = false)
379
- calls = get_call_array(10)
380
- puts "#{calls.to_yaml}" if dbg
381
- arr = []
382
- calls.each_index do |ix|
383
- if ix > 1 # skip this method and the logging method
384
- arr << calls[ix]
385
- end
386
- end
387
- puts "#{arr.to_yaml}" if dbg
388
- if arr.length > 0
389
- list = 'TRACE:'
390
- arr.reverse.each { |l| list << "=>#{l}" }
391
- " [[#{list}]]"
392
- else
393
- nil
394
- end
395
- end
396
-
397
- def dump_array(arr, space_to_underscore = false)
398
- dump = " #{arr.inspect}\n"
399
- arr.each_index do |x|
400
- value = arr[x].to_s
401
- value.gsub!(/\s/, '_') if space_to_underscore
402
- dump << " #{x.to_s.rjust(5)}>> '#{arr[x].to_s}'\n"
403
- end
404
- dump
405
- end
406
-
407
- def dump_ole_methods(ole)
408
- rtrn = ''
409
- ole.ole_methods.each do |m|
410
- prms = ''
411
- m.params.each do |p|
412
- prms << "#{p}, "
413
- end
414
- rtrn << "#{m.name}(#{prms.chop.chop})\n"
415
- end
416
- rtrn
417
- end
418
-
419
- def dump_ole_get_methods(ole)
420
- rtrn = ''
421
- ole.ole_get_methods.each do |m|
422
- prms = ''
423
- m.params.each do |p|
424
- prms << "#{p}, "
425
- end
426
- rtrn << "#{m.name}(#{prms.chop.chop})\n"
427
- end
428
- rtrn
429
- end
430
-
431
- def dump_ole_help(ole)
432
- rtrn = ''
433
- ole.ole_obj_help.each do |m|
434
- prms = ''
435
- m.params.each do |p|
436
- prms << "#{p}, "
437
- end
438
- rtrn << "#{m.name}(#{prms.chop.chop})\n"
439
- end
440
- rtrn
441
- end
442
-
443
- def dump_select_list_options(element)
444
- msg = "#{element.inspect}"
445
- options = element.options
446
- cnt = 1
447
- options.each do |o|
448
- msg << "\n\t#{cnt}:\t'#{o}"
449
- cnt += 1
450
- end
451
- debug_to_log(msg)
452
- end
453
-
454
- def dump_all_tables(browser, to_report = false)
455
- tables = browser.tables
456
- msg = ''
457
- tbl_cnt = 0
458
- tables.each do |tbl|
459
- tbl_cnt += 1
460
- row_cnt = 0
461
- msg <<"\n=================\ntable: #{tbl_cnt}\n=================\n#{tbl}\ntext:\n#{tbl.text}"
462
- tbl.rows.each do |row|
463
- row_cnt += 1
464
- cell_cnt = 0
465
- msg <<"\n=================\ntable: #{tbl_cnt} row: #{row_cnt}\n#{row.inspect}\n#{row}\ntext:'#{row.text}'"
466
- row.each do |cell|
467
- cell_cnt += 1
468
- msg <<"\ncell: #{cell_cnt}\n#{cell.inspect}\n#{row}\ntext: '#{cell.text}'"
469
- end
470
- end
471
- end
472
- if to_report
473
- debug_to_report(msg)
474
- else
475
- debug_to_log(msg)
476
- end
477
- end
478
-
479
- def dump_table_and_rows(table, to_report = false)
480
- msg = "\n=================\ntable\n=================\nn#{table}\n#{table.to_yaml}\nrows:"
481
- cnt = 0
482
- table.rows.each do |r|
483
- cnt += 1
484
- msg << "\n#{cnt}: #{r.text}"
485
- end
486
- msg << "\n=================\n================="
487
- if to_report
488
- debug_to_report(msg)
489
- else
490
- debug_to_log(msg)
491
- end
492
- end
493
-
494
- def dump_table_rows_and_cells(tbl)
495
- msg = ''
496
- row_cnt = 0
497
- msg <<"\n=================\ntable: #{tbl.inspect}\n=================\n#{tbl}\ntext:\n#{tbl.text}"
498
- tbl.rows.each do |row|
499
- row_cnt += 1
500
- cell_cnt = 0
501
- msg <<"\n=================\nrow: #{row_cnt}\n#{row.inspect}\n#{row}\ntext:'#{row.text}'"
502
- row.each do |cell|
503
- cell_cnt += 1
504
- msg <<"\ncell: #{cell_cnt}\n#{cell.inspect}\n#{row}\ntext: '#{cell.text}'"
505
- end
506
- end
507
- debug_to_log(msg)
508
- end
509
-
510
- alias dump_table_rows dump_table_rows_and_cells
511
-
512
- def dump_row_cells(row)
513
- msg = ''
514
- cell_cnt = 0
515
- msg <<"\n=================\nrow: #{row.inspect}\n#{row}\ntext:'#{row.text}'"
516
- row.each do |cell|
517
- cell_cnt += 1
518
- msg <<"\ncell: #{cell_cnt}\n#{cell.inspect}\n#{row}\ntext: '#{cell.text}'"
519
- end
520
- debug_to_log(msg)
521
- end
522
-
523
- def parse_cookies(browser)
524
- cookies = Hash.new
525
- strg = browser.document.cookie
526
- ary = strg.split(';')
527
- ary.each do |c|
528
- key, value = c.split('=')
529
- cookies[key.lstrip] = value
530
- end
531
- cookies
532
- end
533
-
534
- def capture_screen(browser, ts)
535
- browser.maximize
536
- browser.bring_to_front
537
- caller = get_caller
538
- caller.match(/:(\d+):/)
539
- lnbr = $1
540
- path = "#{@myRoot}/screenshot/"
541
- screenfile = "#{@myName}_#{@myRun.id}_#{lnbr.to_s}_#{ts.to_f.to_s}.scrsht.jpg"
542
- info_to_log("path:#{path} screenfile:#{screenfile}")
543
- screenSpec = '"' + path + screenfile + '"'
544
- screenSpec.gsub!('/', '\\')
545
- screen_capture(screenSpec)
546
- screenfile
547
- end
548
-
549
- def pdf_to_text(file, noblank = true)
550
- spec = file.sub(/\.pdf$/, '')
551
- `pdftotext #{spec}.pdf`
552
- file = File.new("#{spec}.txt")
553
- text = []
554
- file.readlines.each do |l|
555
- l.chomp! if noblank
556
- if l.length > 0
557
- text << l
558
- end
559
- end
560
- file.close
561
- text
562
- end
563
-
564
- def flash_id(browser, strg, count)
565
- msg = "Flash link id='#{strg}' #{count} times."
566
- msg << " #{desc}" if desc.length > 0
567
- browser.link(:id, strg).flash(count)
568
- if validate(browser, @myName, __LINE__)
569
- passed_to_log(msg)
570
- true
571
- end
572
- rescue
573
- failed_to_log("Unable to #{msg} '#{$!}'")
574
- end
575
-
576
- def flash(element, count = 4)
577
- element.flash(count)
578
- debug_to_log("'#{element.inspect}' flashed #{count} times.")
579
- true
580
- rescue
581
- debug_to_log("Flash '#{element.inspect}' failed: '#{$!}' (#{__LINE__})")
582
- end
583
-
584
- def get_save_file_path(root, filename)
585
- filespec = "#{root}/file/#{filename}"
586
- filespec.gsub!('/', '\\')
587
- end
588
-
589
- def save_file_orig(filepath, desc = '', wait = WAIT)
590
- # title = translate_popup_title(title)
591
- @ai.WinWait("File Download", "", wait)
592
- @ai.ControlFocus("File Download", "", "&Save")
593
- sleep 1
594
- @ai.ControlClick("File Download", "", "&Save", "left")
595
- @ai.WinWait("Save As", "", wait)
596
- sleep 1
597
- @ai.ControlSend("Save As", "", "Edit1", filepath)
598
- @ai.ControlClick("Save As", "", "&Save", "left")
599
- sleep 1
600
- @ai.WinWait("Download complete", "", wait)
601
- @ai.ControlClick("Download complete", "", "Close")
602
- end
603
-
604
- #TODO This and save_file2 have to be combined somehow.
605
- def save_file1(filepath, title = "File Download", desc = '', wait = WAIT)
606
- title = translate_popup_title(title)
607
- @ai.WinWait(title, '', wait)
608
- @ai.WinActivate(title, '')
609
- sleep 1
610
- @ai.ControlFocus(title, "", "&Save")
611
- sleep 3
612
- @ai.ControlClick(title, "", "&Save", "primary")
613
- sleep 2
614
- @ai.ControlClick(title, "", "Save", "primary")
615
-
616
- @ai.WinWait("Save As", "", wait)
617
- sleep 1
618
- @ai.ControlSend("Save As", "", "Edit1", filepath)
619
- @ai.ControlFocus("Save As", "", "&Save")
620
- @ai.ControlClick("Save As", "", "&Save", "primary")
621
- @ai.ControlClick("Save As", "", "Save", "primary")
622
-
623
- @ai.WinWait("Download complete", "", wait)
624
- passed_to_log("Save file '#{filepath}' succeeded. #{desc}")
625
- @ai.ControlClick("Download complete", "", "Close")
626
- rescue
627
- failed_to_log("Save file failed: #{desc} '#{$!}'. (#{__LINE__})")
628
- end
629
-
630
- def save_file2(filepath, title = "File Download - Security Warning", desc = '', wait = WAIT)
631
- title = translate_popup_title(title)
632
- sleep(1)
633
- @ai.WinWait(title, '', wait)
634
- dl_hndl = @ai.WinGetHandle(title, '')
635
- dl_sv_hndl = @ai.ControlGetHandle(title, '', "&Save")
636
- @ai.WinActivate(title, '')
637
- sleep 1
638
- @ai.ControlFocus(title, "", "&Save")
639
- sleep 1
640
- @ai.ControlFocus(title, "", "Save")
641
- sleep 1
642
- @ai.ControlClick(title, "", "&Save", "primary")
643
- sleep 1
644
- @ai.ControlClick(title, "", "Save", "primary")
645
- sleep 1
646
- w = WinClicker.new
647
- w.clickButtonWithHandle(dl_sv_hndl)
648
- sleep 1
649
- w.clickWindowsButton_hwnd(dl_hndl, "Save")
650
- sleep 1
651
- w.clickWindowsButton_hwnd(dl_hndl, "&Save")
652
-
653
- @ai.WinWait("Save As", "", wait)
654
- sleep 1
655
- @ai.ControlSend("Save As", "", "Edit1", filepath)
656
- @ai.ControlFocus("Save As", "", "&Save")
657
- @ai.ControlClick("Save As", "", "&Save", "primary")
658
-
659
- @ai.WinWait("Download complete", "", wait)
660
- passed_to_log("Save file '#{filepath}' succeeded. #{desc}")
661
- @ai.ControlClick("Download complete", "", "Close")
662
- rescue
663
- failed_to_log("Save file failed: #{desc} '#{$!}'. (#{__LINE__})")
664
- end
665
-
666
- #method for handling save dialog
667
- #use click_no_wait on the action that triggers the save dialog
668
- def save_file(filepath, download_title = "File Download - Security Warning")
669
- # TODO need version for Firefox
670
- # TODO need to handle first character underline, e.g. 'Cancel' and '&Cancel'
671
- download_title = translate_popup_title(download_title)
672
- download_text = ''
673
- download_control = "&Save"
674
- saveas_title = 'Save As'
675
- saveas_text = ''
676
- saveas_control = "Edit1"
677
- dnld_cmplt_title = "Download Complete"
678
- dnld_cmplt_title = translate_popup_title(dnld_cmplt_title)
679
- dnld_cmplt_text = ""
680
- # save_title = ""
681
- side = 'primary'
682
- msgdl = "Window '#{download_title}':"
683
- msgsa = "Window '#{saveas_title}':"
684
- msgdc = "Window '#{dnld_cmplt_title}':"
685
- begin
686
- if @ai.WinWait(download_title, download_text, WAIT)
687
- @ai.WinActivate(download_title, download_text)
688
- if @ai.WinActive(download_title, download_text)
689
- dl_title = @ai.WinGetTitle(download_title, download_text)
690
- # dl_hndl = @ai.WinGetHandle(download_title, download_text)
691
- # dl_text = @ai.WinGetText(download_title, download_text)
692
- # dl_sv_hndl = @ai.ControlGetHandle(dl_title, '', download_control)
693
- # dl_op_hndl = @ai.ControlGetHandle(dl_title, '', '&Open')
694
- # dl_cn_hndl = @ai.ControlGetHandle(dl_title, '', 'Cancel')
695
- debug_to_log("#{msgdl} activated. (#{__LINE__})")
696
-
697
- if @ai.ControlFocus(dl_title, download_text, download_control)
698
- debug_to_log("#{msgdl} focus gained. (#{__LINE__})")
699
-
700
- @ai.Send("S")
701
- # @ai.ControlSend(dl_Stitle, download_text, download_control, "{ENTER}")
702
- sleep_for 1
703
-
704
- if @ai.ControlClick(dl_title, download_text, download_control, side)
705
- debug_to_log("#{msgdl} click succeeded on '#{download_control}'. (#{__LINE__})")
706
-
707
- if @ai.WinWait(saveas_title, saveas_text, WAIT)
708
- debug_to_log("#{msgsa} appeared. (#{__LINE__})")
709
- sleep_for 1
710
- if @ai.ControlSend(saveas_title, saveas_text, saveas_control, filepath)
711
- debug_to_log("#{msgsa} controlsend of '#{saveas_control}' succeeded. (#{__LINE__})")
712
-
713
- @ai.Send("S")
714
- @ai.ControlSend(saveas_title, saveas_text, saveas_control, "{ENTER}")
715
- sleep_for 1
716
-
717
- if @ai.ControlClick(saveas_title, saveas_text, saveas_control, side)
718
- passed_to_log("#{msgsa} click succeeded on '#{saveas_control}'. (#{__LINE__})")
719
- if @ai.WinWait(dnld_cmplt_title, dnld_cmplt_text, WAIT)
720
- debug_to_log("#{msgdc} appeared. (#{__LINE__})")
721
- sleep_for 1
722
- if @ai.ControlClick(dnld_cmplt_title, dnld_cmplt_text, "Close", side)
723
- passed_to_log("Save file for #{filepath} succeeded.")
724
- else
725
- failed_to_log("#{msgdc} click failed on 'Close'. (#{__LINE__})")
726
- end
727
- else
728
- failed_to_log("#{msgdc} did not appear after #{WAIT} seconds. (#{__LINE__})")
729
- end
730
- else
731
- failed_to_log("#{msgsa} click failed on '#{saveas_control}'. (#{__LINE__})")
732
- end
733
- else
734
- failed_to_log("#{msgsa} controlsend of '#{saveas_control}' failed. (#{__LINE__})")
735
- end
736
- else
737
- failed_to_log("#{msgsa} did not appear after #{WAIT} seconds. (#{__LINE__})")
738
- end
739
- else
740
- failed_to_log("#{msgdl} click failed on '#{download_control}'. (#{__LINE__})")
741
- end
742
- else
743
- failed_to_log("#{msgdl} Unable to gain focus on control '#{dl_title}'. (#{__LINE__})")
744
- end
745
- else
746
- failed_to_log("#{msgdl} Unable to activate. (#{__LINE__})")
747
- end
748
- else
749
- failed_to_log("#{msgdl} did not appear after #{WAIT} seconds. (#{__LINE__})")
750
- end
751
- rescue
752
- failed_to_log("Save file failed: '#{$!}'. (#{__LINE__})")
753
- end
754
- end
755
-
756
- #method for cancelling Print window
757
- # TODO need to handle 'Cancel' and '&Cancel' (first character underlined)
758
- def close_print(title = 'Print', text = '', button = '&Cancel', side = 'left')
759
- msg = "Popup: title=#{title} button='#{button}' text='#{text}' side='#{side}':"
760
- if @ai.WinWait(title, text, WAIT)
761
- passed_to_log("#{msg} found.")
762
- @ai.WinActivate(title)
763
- if @ai.WinActive(title, text)
764
- passed_to_log("#{msg} activated.")
765
- if @ai.ControlFocus(title, text, button)
766
- passed_to_log("#{msg} focus attained.")
767
- if @ai.ControlClick(title, text, button, side)
768
- passed_to_log("#{msg} closed successfully.")
769
- else
770
- failed_to_log("#{msg} click failed on button (#{__LINE__})")
771
- end
772
- else
773
- failed_to_log("#{msg} Unable to gain focus on button (#{__LINE__})")
774
- end
775
- else
776
- failed_to_log("#{msg} Unable to activate (#{__LINE__})")
777
- end
778
- else
779
- failed_to_log("#{msg} did not appear after #{WAIT} seconds. (#{__LINE__})")
780
- end
781
- rescue
782
- failed_to_log("Close #{msg}: '#{$!}'. (#{__LINE__})")
783
- end
784
-
785
- #method for handling file download dialog
786
- #use click_no_wait on the action that triggers the save dialog
787
- # TODO need version for Firefox
788
- # TODO need to handle 'Cancel' and '&Cancel' (first character underlined)
789
- # TODO replace call to close_modal_ie with actual file download
790
- def file_download(browser = nil)
791
- title = 'File Download'
792
- title = translate_popup_title(title)
793
- text = ''
794
- button = 'Cancel'
795
- if @browserAbbrev == 'IE'
796
- close_popup(title, button, text)
797
- else
798
-
799
- end
800
- end
801
-
802
- #method for handling file upload dialog
803
- #use click_no_wait on the action that triggers the save dialog
804
- # TODO need version for Firefox
805
- def file_upload(filepath)
806
- title = 'Choose File'
807
- title = translate_popup_title(title)
808
- text = ''
809
- button = "&Open"
810
- control = "Edit1"
811
- side = 'primary'
812
- msg = "Window title=#{title} button='#{button}' text='#{text}' side='#{side}':"
813
- begin
814
- if @ai.WinWait(title, text, WAIT)
815
- passed_to_log("#{msg} found.")
816
- @ai.WinActivate(title, text)
817
- if @ai.WinActive(title, text)
818
- passed_to_log("#{msg} activated.")
819
- if @ai.ControlSend(title, text, control, filepath)
820
- passed_to_log("#{msg} #{control} command sent.")
821
- sleep_for 1
822
- if @ai.ControlClick(title, text, button, "primary")
823
- passed_to_log("#{msg} Upload of #{filepath} succeeded.")
824
- else
825
- failed_to_log("#{msg} Upload of #{filepath} failed. (#{__LINE__})")
826
- end
827
- else
828
- failed_to_log("#{msg} Unable to select #{filepath}. (#{__LINE__})")
829
- end
830
- else
831
- failed_to_log("#{msg} Unable to activate. (#{__LINE__})")
832
- end
833
- else
834
- failed_to_log("#{msg} did not appear after #{WAIT} seconds. (#{__LINE__})")
835
- end
836
- rescue
837
- failed_to_log("#{msg} Unable to upload: '#{$!}'. (#{__LINE__})")
838
- end
839
-
840
- end
841
-
842
- def upload_file(data_path)
843
- limit = 180 # .seconds
844
- Timeout::timeout(limit) {
845
- wait = 20
846
- @ai.WinWait("Choose File to Upload", "", wait)
847
- sleep 1
848
- @ai.ControlSend("Choose File to Upload", "", "Edit1", data_path)
849
- @ai.ControlClick("Choose File to Upload", "", "[CLASS:Button; INSTANCE:2]", "left")
850
- sleep 4
851
- #sleep 1
852
- }
853
- failed_to_log("Choose File to Upload not found after #{limit} '#{$!}'")
854
- rescue Timeout::Error
855
- failed_to_log("File Upload timeout after #{limit} '#{$!}'")
856
- end
857
-
858
- def focus_on_textfield_by_id(browser, strg, desc = '')
859
- msg = "Set focus on textfield name='#{strg}' "
860
- msg << " #{desc}" if desc.length > 0
861
- tf = browser.text_field(:id, strg)
862
- if validate(browser, @myName, __LINE__)
863
- tf.focus
864
- if validate(browser, @myName, __LINE__)
865
- passed_to_log(msg)
866
- true
867
- end
868
- end
869
- rescue
870
- failed_to_log("Unable to #{msg} '#{$!}'")
871
- end
872
-
873
- def flash_text(browser, strg, count, desc = '')
874
- msg = "Flash link text='#{strg}' #{count} times."
875
- msg << " #{desc}" if desc.length > 0
876
- strgCnt = string_count_in_string(browser.text, strg)
877
- if strgCnt > 0
878
- browser.link(:text, strg).flash(count)
879
- if validate(browser, @myName, __LINE__)
880
- passed_to_log(msg)
881
- true
882
- end
883
- else
884
- failed_to_log("#{msg} Link not found.")
885
- end
886
- rescue
887
- failed_to_log("Unable to #{msg} '#{$!}'")
888
- end
889
-
890
-
891
- end