Module: RWebSpec::WebDriver::Driver

Includes:
Popup, TestWisePlugin
Included in:
AbstractWebPage, RSpecHelper, TestScript, WebTestCase
Defined in:
lib/rwebspec-webdriver/driver.rb

Constant Summary collapse

@@default_polling_interval =

second

1
@@default_timeout =

seconds

30

Instance Method Summary collapse

Methods included from Popup

#check_for_popups, #check_for_security_alerts, #click_button_in_javascript_popup, #click_button_in_popup_after, #click_button_in_security_alert_popup, #click_button_in_security_information_popup, #click_popup_window, #ie_popup_clicker, #prepare_to_click_button_in_popup, #start_checking_js_dialog, #verify_alert

Methods included from TestWisePlugin

#connect_to_testwise, #debug, #dump_caller_stack, #notify_screenshot_location, #operation_delay

Instance Method Details

#absolutify_url(src, base_url, parent_url) ⇒ Object

change

<script type="text/javascript" src="/javascripts/prototype.js"></script>

to

<script type="text/javascript" src="http://itest2.com/javascripts/prototype.js"></script>


480
481
482
483
484
485
486
487
488
# File 'lib/rwebspec-webdriver/driver.rb', line 480

def absolutify_url(src, base_url, parent_url)
  if src.nil? || src.empty? || src == "//:" || src =~ /\s*http:\/\//i
    return src
  end

  return "#{base_url}#{src}" if src =~ /^\s*\//
  return "#{parent_url}#{src}" if parent_url
  return src
end

#absolutize_page(content, base_url, current_url_parent) ⇒ Object

<link rel=“stylesheet” type=“text/css” href=“/stylesheets/default.css” /> ‘<script type=“text/javascript” src=“www.jeroenwijering.com/embed/swfobject.js”></script>’ <script type=“text/javascript” src=“/javascripts/prototype.js”></script> <script type=“text/javascript” src=“/javascripts/scriptaculous.js?load=effects,builder”></script> <script type=“text/javascript” src=“/javascripts/extensions/gallery/lightbox.js”></script> <link href=“/stylesheets/extensions/gallery/lightbox.css” rel=“stylesheet” type=“text/css” /> <img src=“images/mission_48.png” />



439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
# File 'lib/rwebspec-webdriver/driver.rb', line 439

def absolutize_page(content, base_url, current_url_parent)
  modified_content = ""
  content.each_line do |line|
    if line =~ /<script\s+.*src=["'']?(.*)["'].*/i then
      script_src = $1
      substitute_relative_path_in_src_line(line, script_src, base_url, current_url_parent)
    elsif line =~ /<link\s+.*href=["'']?(.*)["'].*/i then
      link_href = $1
      substitute_relative_path_in_src_line(line, link_href, base_url, current_url_parent)
    elsif line =~ /<img\s+.*src=["'']?(.*)["'].*/i then
      img_src = $1
      substitute_relative_path_in_src_line(line, img_src, base_url, current_url_parent)
    end

    modified_content += line
  end
  return modified_content
end

#absolutize_page_hpricot(content, base_url, parent_url) ⇒ Object

absolutize_page referencs using hpricot



460
461
462
463
464
465
466
467
468
469
470
471
472
473
# File 'lib/rwebspec-webdriver/driver.rb', line 460

def absolutize_page_hpricot(content, base_url, parent_url)
  return absolutize_page(content, base_url, parent_url) if RUBY_PLATFORM == 'java'
  begin
    require 'nokogiri'
    doc = Nokogiri::HTML(content)
    base_url.slice!(-1) if ends_with?(base_url, "/")
    (doc/'link').each { |e| e['href'] = absolutify_url(e['href'], base_url, parent_url) || "" }
    (doc/'img').each { |e| e['src'] = absolutify_url(e['src'], base_url, parent_url) || "" }
    (doc/'script').each { |e| e['src'] = absolutify_url(e['src'], base_url, parent_url) || "" }
    return doc.to_html
  rescue => e
    absolutize_page(content, base_url, parent_url)
  end
end

#ajax_wait_for_element(element_id, seconds, status = 'show', check_interval = @@default_polling_interval) ⇒ Object

Wait for specific seconds for an Ajax update finish. Trick: In your Rails application,

  :loading 	=> "Element.show('search_indicator');
  :complete	=> "Element.hide('search_indicator');

<%= image_tag("indicator.gif", :id => 'search_indicator', :style => 'display:none') %>

Typical usage:

ajax_wait_for_element("search_indicator", 30)
ajax_wait_for_element("search_indicator", 30, "show")
ajax_wait_for_element("search_indicator", 30, "hide")
ajax_wait_for_element("search_indicator", 30, "show", 5) # check every 5 seconds

Warning: this method has not been fully tested, if you are not using Rails, change your parameter accordingly.



687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
# File 'lib/rwebspec-webdriver/driver.rb', line 687

def ajax_wait_for_element(element_id, seconds, status='show', check_interval = @@default_polling_interval)
  count = 0
  check_interval = 1 if check_interval < 1 or check_interval > seconds
  while count < (seconds / check_interval) do
    search_indicator = @web_browser.element_by_id(element_id)
    search_indicator_outer_html = search_indicator.outerHtml if search_indicator
    if status == 'hide'
      return true if search_indicator_outer_html and !search_indicator_outer_html.include?('style="DISPLAY: none"')
    else
      return true if search_indicator_outer_html and search_indicator_outer_html.include?('style="DISPLAY: none"')
    end
    sleep check_interval if check_interval > 0 and check_interval < 5 * 60 # wait max 5 minutes
    count += 1
  end
  return false
end

#allow(&block) ⇒ Object Also known as: shall_allow, allowing

Does not provide real function, other than make enhancing test syntax

Example:

allow { click_button('Register') }


625
626
627
# File 'lib/rwebspec-webdriver/driver.rb', line 625

def allow(& block)
  yield
end

#attach_browser(how, what, options = {}) ⇒ Object

Attach to existinb browser window

attach_browser(:title,    )


207
208
209
210
211
212
213
214
215
216
# File 'lib/rwebspec-webdriver/driver.rb', line 207

def attach_browser(how, what, options = {})
  #TODO
  options.merge!(:browser => is_firefox? ? "Firefox" : "IE") unless options[:browser]
  begin
    options.merge!(:base_url => browser.context.base_url)
  rescue => e
    puts "failed to set base_url, ignore : #{e}"
  end
  WebBrowser.attach_browser(how, what, options)
end

#basic_authentication(username, password, options = {}) ⇒ Object



958
959
960
961
962
963
964
965
966
# File 'lib/rwebspec-webdriver/driver.rb', line 958

def basic_authentication(username, password, options = {})
  if is_celerity?
    basic_authentication_celerity(username, password)
  elsif is_firefox?
    basic_authentication_firefox(username, password)
  else
    basic_authentication_ie(options[:title], username, password, options)
  end
end

#basic_authentication_celerity(username, password) ⇒ Object



954
955
956
# File 'lib/rwebspec-webdriver/driver.rb', line 954

def basic_authentication_celerity(username, password)
  @web_browser.celerity.credentials = "#{username}:#{password}"
end

#basic_authentication_firefox(username, password, wait = 3) ⇒ Object

Use JSSH to pass authentication

Window title "Authentication required"


929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
# File 'lib/rwebspec-webdriver/driver.rb', line 929

def basic_authentication_firefox(username, password, wait = 3)
  jssh_command = "
  var length = getWindows().length;
  var win;
  var found = false;
  for (var i = 0; i < length; i++) {
    win = getWindows()[i];
    if(win.document.title == \"Authentication Required\") {
      found = true;
      break;
    }
  }
  if (found) {
    var jsdocument = win.document;
    var dialog = jsdocument.getElementsByTagName(\"dialog\")[0];
    jsdocument.getElementsByTagName(\"textbox\")[0].value = \"#{username}\";
    jsdocument.getElementsByTagName(\"textbox\")[1].value = \"#{password}\";
    dialog.getButton(\"accept\").click();
  }
  \n"
  sleep(wait)
  $jssh_socket.send(jssh_command, 0)
  # read_socket()
end

#basic_authentication_ie(title, username, password, options = {}) ⇒ Object

Use AutoIT3 to send password title starts with “Connect to …”



906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
# File 'lib/rwebspec-webdriver/driver.rb', line 906

def basic_authentication_ie(title, username, password, options = {})
  default_options = {:textctrl_username => "Edit2",
    :textctrl_password => "Edit3",
    :button_ok => 'Button1'
  }

  options = default_options.merge(options)

  title ||= ""
  if title =~ /^Connect\sto/
    full_title = title
  else
    full_title = "Connect to #{title}"
  end
  require 'rformspec'
   = RFormSpec::Window.new(full_title)
  .send_control_text(options[:textctrl_username], username)
  .send_control_text(options[:textctrl_password], password)
  .click_button("OK")
end

#begin_at(url) ⇒ Object

Starting browser with a URL

Example:

begin_at("http://www.itest2.com")


153
154
155
156
157
# File 'lib/rwebspec-webdriver/driver.rb', line 153

def begin_at(url)
  # puts "[DEBUG] [SeleniumBrowser] begin_at #{url}"
  dump_caller_stack
  @web_browser.begin_at(url)
end

#browserObject

return the underlying RWebSpec::WebDriver::Browser object



94
95
96
# File 'lib/rwebspec-webdriver/driver.rb', line 94

def browser
  @web_browser
end

#cell_with_id(cell_id, options = {}) ⇒ Object Also known as: table_data_with_id

return the text of specific (identified by attribute “id”) ta tag For page containing

<td id="preferred_recorder">iTest2/Watir Recorder</span>

td_with_id(“preferred_recorder”) # => iTest2/Watir Recorder



554
555
556
557
558
559
560
561
# File 'lib/rwebspec-webdriver/driver.rb', line 554

def cell_with_id(cell_id, options = {})
  if options && options[:index] then
    elements = find_elements(:id, cell_id.to_s)
    elements[options[:index].to_i - 1].text
  else
    find_element(:id, cell_id.to_s).text
  end
end

#check_ie_versionObject



884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
# File 'lib/rwebspec-webdriver/driver.rb', line 884

def check_ie_version
  if is_windows? && @ie_version.nil?
    begin
      cmd = 'reg query "HKLM\SOFTWARE\Microsoft\Internet Explorer" /v Version';
      result = `#{cmd}`
      version_line = nil
      result.each do |line|
        if (line =~ /Version\s+REG_SZ\s+([\d\.]+)/)
          version_line = $1
        end
      end

      if version_line =~ /^\s*(\d+)\./
        @ie_version = $1.to_i
      end
    rescue => e
    end
  end
end

#choose_file_dialog(file_path) ⇒ Object



878
879
880
881
882
# File 'lib/rwebspec-webdriver/driver.rb', line 878

def choose_file_dialog(file_path)
  Watir.autoit.WinWaitActive("Choose File to Upload", '', 10)
  Watir.autoit.ControlSetText("Choose File to Upload", "", 1148, file_path)
  Watir.autoit.ControlClick("Choose File to Upload", "", "&Open")
end

#clear_popup(popup_win_title, seconds = 10, yes = true) ⇒ Object

Clear popup windows such as ‘Security Alert’ or ‘Security Information’ popup window,

Screenshot see kb2.adobe.com/cps/165/tn_16588.html

You can also by pass security alerts by change IE setting, kb.iu.edu/data/amuj.html

Example

clear_popup("Security Information", 5, true) # check for Security Information for 5 seconds, click Yes


838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
# File 'lib/rwebspec-webdriver/driver.rb', line 838

def clear_popup(popup_win_title, seconds = 10, yes = true)
  # commonly "Security Alert", "Security Information"
  if is_windows?
    sleep 1
    autoit = WIN32OLE.new('AutoItX3.Control')
    # Look for window with given title. Give up after 1 second.
    ret = autoit.WinWait(popup_win_title, '', seconds)
    #
    # If window found, send appropriate keystroke (e.g. {enter}, {Y}, {N}).
    if ret == 1 then
      puts "about to send click Yes" if debugging?
      button_id = yes ? "Button1" : "Button2" # Yes or No
      autoit.ControlClick(popup_win_title, '', button_id)
    end
    sleep(0.5)
  else
    raise "Currently supported only on Windows"
  end
end

#click_button_with_image_src_contains(image_filename) ⇒ Object Also known as: click_button_with_image

Click image buttion with image source name

For an image submit button <input name=“submit” type=“image” src=“/images/search_button.gif”>

click_button_with_image("search_button.gif")


356
357
358
359
360
# File 'lib/rwebspec-webdriver/driver.rb', line 356

def click_button_with_image_src_contains(image_filename)
  perform_operation {
    @web_browser.click_button_with_image_src_contains(image_filename)
  }
end

#close_all_browsersObject

Close all opening browser windows



128
129
130
# File 'lib/rwebspec-webdriver/driver.rb', line 128

def close_all_browsers
  #TODO
end

#close_browserObject Also known as: close_ie

Close the current browser window (started by the script). If no browser started, then close all browser windows.



114
115
116
117
118
119
120
121
122
# File 'lib/rwebspec-webdriver/driver.rb', line 114

def close_browser
  if @web_browser
    # Old TestWise version
    # @web_browser.close_browser unless $TESTWISE_LEAVE_BROWSER_OPEN_AFTER_RUN
    @web_browser.close_browser
  else
    WebBrowser.close_all_browsers
  end
end

#contains(str) ⇒ Object Also known as: contain

In pages, can’t use include, text.should include(“abc”) won’t work Instead,

text.should contains("abc"


346
347
348
# File 'lib/rwebspec-webdriver/driver.rb', line 346

def contains(str)
  ContainsText.new(str)
end

#contains_text(text) ⇒ Object



339
340
341
# File 'lib/rwebspec-webdriver/driver.rb', line 339

def contains_text(text)
  @web_browser.contains_text(text)
end

#contextObject



145
146
147
# File 'lib/rwebspec-webdriver/driver.rb', line 145

def context
  @web_browser.context
end

#default_dump_dirObject



387
388
389
390
391
392
393
394
395
396
397
398
399
# File 'lib/rwebspec-webdriver/driver.rb', line 387

def default_dump_dir
  if $TESTWISE_RUNNING_SPEC_ID && $TESTWISE_WORKING_DIR

    $TESTWISE_DUMP_DIR = File.join($TESTWISE_WORKING_DIR, "dump")
    FileUtils.mkdir($TESTWISE_DUMP_DIR) unless File.exists?($TESTWISE_DUMP_DIR)

    spec_run_id = $TESTWISE_RUNNING_SPEC_ID
    spec_run_dir_name = spec_run_id.to_s.rjust(4, "0") unless spec_run_id == "unknown"
    to_dir = File.join($TESTWISE_DUMP_DIR, spec_run_dir_name)
  else
    to_dir = ENV['TEMP_DIR'] || (is_windows? ? "C:\\temp" : "/tmp")
  end
end

#dump_response(stream = nil) ⇒ Object


For debugging




383
384
385
# File 'lib/rwebspec-webdriver/driver.rb', line 383

def dump_response(stream = nil)
  @web_browser.dump_response(stream)
end

#element_by_id(elem_id) ⇒ Object

Identify DOM element by ID Warning: it is only supported on IE



376
377
378
# File 'lib/rwebspec-webdriver/driver.rb', line 376

def element_by_id(elem_id)
  @web_browser.element_by_id(elem_id)
end

#element_text(elem_id) ⇒ Object

Warning: this does not work well with Firefox yet.



370
371
372
# File 'lib/rwebspec-webdriver/driver.rb', line 370

def element_text(elem_id)
  @web_browser.element_value(elem_id)
end

#ends_with?(str, suffix) ⇒ Boolean

Returns:

  • (Boolean)


502
503
504
505
# File 'lib/rwebspec-webdriver/driver.rb', line 502

def ends_with?(str, suffix)
  suffix = suffix.to_s
  str[-suffix.length, suffix.length] == suffix
end

#enter_text_with_id(textfield_id, value) ⇒ Object

for text field can be easier to be identified by attribute “id” instead of “name”, not recommended though



314
315
316
317
318
319
320
321
322
323
324
# File 'lib/rwebspec-webdriver/driver.rb', line 314

def enter_text_with_id(textfield_id, value)
  perform_operation {
    elements = find_elements(:id, textfield_id)
    if elements.size == 1 then
      elements[0].send_keys(value)
    else
      smaller_set = elements.select {|x| x.tag_name == "textarea" || (x.tag_name == "input" &&  x.attribute("text")) }
      smaller_set[0].send_keys(value)
    end
  }
end

#expect_page(page_clazz, argument = nil) ⇒ Object

Verify the next page following an operation.

Typical usage:

.
expect_page HomePage


137
138
139
140
141
142
143
# File 'lib/rwebspec-webdriver/driver.rb', line 137

def expect_page(page_clazz, argument = nil)
  if argument
    @web_browser.expect_page(page_clazz, argument)
  else
    @web_browser.expect_page(page_clazz)
  end
end

#failsafe(&block) ⇒ Object Also known as: fail_safe

try operation, ignore if errors occur

Example:

failsafe { click_link("Logout") }  # try logout, but it still OK if not being able to (already logout))


636
637
638
639
640
641
# File 'lib/rwebspec-webdriver/driver.rb', line 636

def failsafe(& block)
  begin
    yield
  rescue =>e
  end
end

#find_element(how, what) ⇒ Object



103
104
105
# File 'lib/rwebspec-webdriver/driver.rb', line 103

def find_element(how, what)
  @web_browser.find_element(how, what)
end

#find_elements(how, what) ⇒ Object



107
108
109
# File 'lib/rwebspec-webdriver/driver.rb', line 107

def find_elements(how, what)
  @web_browser.find_elements(how, what)
end

#firefoxObject

Return the FireWatir::Firefox instance



167
168
169
# File 'lib/rwebspec-webdriver/driver.rb', line 167

def firefox
  @web_browser.firefox
end

#goto_page(page) ⇒ Object Also known as: visit

Go to another page on the testing site.

open_browser("http://www.itest2.com")
goto_page("/demo")  # visit page http://www.itest2.com/demo


188
189
190
191
192
# File 'lib/rwebspec-webdriver/driver.rb', line 188

def goto_page(page)
  perform_operation {
    @web_browser.goto_page(page) if @web_browser
  }
end

#goto_url(url) ⇒ Object

Go to another web site, normally different site being tested on

open_browser("http://www.itest2.com")
goto_url("http://myorganized.info")


199
200
201
202
# File 'lib/rwebspec-webdriver/driver.rb', line 199

def goto_url(url)
  puts "Calling web_browser goto: #{@web_browser.inspect}"
  @web_browser.goto_url url
end

#ieObject

Return the Watir::IE instance



161
162
163
# File 'lib/rwebspec-webdriver/driver.rb', line 161

def ie
  @web_browser.ie
end

#is_firefox?Boolean

Returns:

  • (Boolean)


171
172
173
# File 'lib/rwebspec-webdriver/driver.rb', line 171

def is_firefox?
  @web_browser.is_firefox? if @web_browser
end

#is_htmlunit?Boolean

Returns:

  • (Boolean)


179
180
181
# File 'lib/rwebspec-webdriver/driver.rb', line 179

def is_htmlunit?
  RUBY_PLATFORM =~ /java/ && @web_browser
end

#is_ie?Boolean

Returns:

  • (Boolean)


175
176
177
# File 'lib/rwebspec-webdriver/driver.rb', line 175

def is_ie?
  @web_browser.is_ie? if @web_browser
end

#is_linux?Boolean

Returns:

  • (Boolean)


573
574
575
# File 'lib/rwebspec-webdriver/driver.rb', line 573

def is_linux?
  RUBY_PLATFORM.downcase.include?("linux")
end

#is_mac?Boolean

Returns:

  • (Boolean)


565
566
567
# File 'lib/rwebspec-webdriver/driver.rb', line 565

def is_mac?
  RUBY_PLATFORM.downcase.include?("darwin")
end

#is_windows?Boolean

Returns:

  • (Boolean)


569
570
571
# File 'lib/rwebspec-webdriver/driver.rb', line 569

def is_windows?
  RUBY_PLATFORM.downcase.include?("mswin") or RUBY_PLATFORM.downcase.include?("mingw")
end

#label_with_id(label_id, options = {}) ⇒ Object

return the text of specific (identified by attribute “id”) label tag For page containing

<label id="preferred_ide">TestWise</label>

label_with_id(“preferred_ids”) # => TestWise label_with_id(“preferred_ids”, :index => 2) # => TestWise



527
528
529
530
531
532
533
534
535
# File 'lib/rwebspec-webdriver/driver.rb', line 527

def label_with_id(label_id, options = {})
  if options && options[:index] then
    elements = find_elements(:id, label_id.to_s)
    elements[options[:index].to_i - 1].text
    # label(:id => label_id.to_s, :index => options[:index]).text
  else
    find_element(:id, label_id.to_s).text
  end
end

#new_popup_window(options) ⇒ Object



364
365
366
# File 'lib/rwebspec-webdriver/driver.rb', line 364

def new_popup_window(options)
  @web_browser.new_popup_window(options)
end

#on(page) {|page| ... } ⇒ Object

Example:

on @page do |i|
  i.enter_text('btn1')
  i.click_button('btn1')
end

Yields:

  • (page)


601
602
603
# File 'lib/rwebspec-webdriver/driver.rb', line 601

def on(page, & block)
  yield page
end

#open_browser(base_url = nil, options = {}) ⇒ Object Also known as: open_browser_with

open a browser, and set base_url via hash, but does not acually

example:

open_browser :base_url => http://localhost:8080

There are 3 ways to set base url

1. pass as first argument
2. If running using TestWise, used as confiured
3. Use default value set

New Options:

:browser => :ie | :firefox | :chrome


38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
# File 'lib/rwebspec-webdriver/driver.rb', line 38

def open_browser(base_url = nil, options = {})
  # puts "[DEBUG] [SeleniumDriver] Callling open_browser #{base_url}"
  begin
    support_unicode
  rescue => e
    puts "Unicode may not work in IE, #{e}"
  end

  base_url ||= $TESTWISE_PROJECT_BASE_URL
  base_url ||= $BASE_URL
  raise "base_url must be set" if base_url.nil?

  default_options = {:speed => "fast",
    :visible => true,
    :highlight_colour => 'yellow',
    :close_others => true,
    :start_new => true, # start a new browser always
  :go => true}

  options = default_options.merge options

  if $TESTWISE_BROWSER
    options[:browser] = $TESTWISE_BROWSER.downcase
  end

  if options[:firefox] && options[:browser].nil? then
    options[:browser] = "firefox" # legacy
  end

  if base_url =~ /^file:/
    uri_base = base_url
  else
    uri = URI.parse(base_url)
    uri_base = "#{uri.scheme}://#{uri.host}:#{uri.port}"
  end

  if options[:start_new] || $celerity_loaded
    # puts "[DEBUG] [SeleniumBrowser] creating a new browser"
    @web_browser = WebBrowser.new(uri_base, nil, options)
    # puts "[DEBUG] [SeleniumBrowser] browser: #{@web_browser.inspect}"
  else
    @web_browser = WebBrowser.reuse(uri_base, options) # Reuse existing browser
  end

  if base_url =~ /^file:/
    goto_url(base_url) # for files, no base url
  else
    (uri.path.length == 0) ? begin_at(base_url) : begin_at(uri.path) if options[:go]
  end

  return @web_browser
end

#page_sourceObject

current page source (in HTML)



513
514
515
# File 'lib/rwebspec-webdriver/driver.rb', line 513

def page_source
  @web_browser.page_source
end

#page_textObject

return plain text view of page



518
519
520
# File 'lib/rwebspec-webdriver/driver.rb', line 518

def page_text
  @web_browser.text
end

#page_titleObject

current web page title



508
509
510
# File 'lib/rwebspec-webdriver/driver.rb', line 508

def page_title
  @web_browser.page_title
end

#perform_operation(&block) ⇒ Object



326
327
328
329
330
331
332
333
334
335
336
337
# File 'lib/rwebspec-webdriver/driver.rb', line 326

def perform_operation(& block)
  begin
    dump_caller_stack
    operation_delay
    yield
  rescue RuntimeError => re
    puts "[DEBUG] operation error: #{re}"
    raise re
    #      ensure
    #        puts "[DEBUG] ensure #{perform_ok}" unless perform_ok
  end
end

#quitObject



99
100
101
# File 'lib/rwebspec-webdriver/driver.rb', line 99

def quit
  @web_browser.quit
end

#repeat_try(num_tries = @@default_timeout || 30, interval = @@default_polling_interval || 1, &block) ⇒ Object

Try the operation up to specified times, and sleep given interval (in seconds) Error will be ignored until timeout Example

repeat_try(3, 2) { click_button('Search' } # 3 times, 6 seconds in total
repeat_try { click_button('Search' } # using default 5 tries, 2 second interval


757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
# File 'lib/rwebspec-webdriver/driver.rb', line 757

def repeat_try(num_tries = @@default_timeout || 30, interval = @@default_polling_interval || 1, & block)
  num_tries ||= 1
  (num_tries - 1).times do |num|
    begin
      yield
      return
    rescue => e
      # puts "debug: #{num} failed: #{e}"
      sleep interval
    end
  end

  # last try, throw error if still fails
  begin
    yield
  rescue => e
    raise e.to_s + " after trying #{num_tries} times every #{interval} seconds"
  end
  yield
end

#save_current_page(options = {}) ⇒ Object

For current page souce to a file in specified folder for inspection

save_current_page(:dir => "C:\\mysite", filename => "abc", :replacement => true)


404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
# File 'lib/rwebspec-webdriver/driver.rb', line 404

def save_current_page(options = {})
  default_options = {:replacement => true}
  options = default_options.merge(options)
  to_dir = options[:dir] || default_dump_dir

  if options[:filename]
    file_name = options[:filename]
  else
    file_name = Time.now.strftime("%m%d%H%M%S") + ".html"
  end

  Dir.mkdir(to_dir) unless File.exists?(to_dir)
  file = File.join(to_dir, file_name)

  content = page_source
  base_url = @web_browser.context.base_url
  current_url = @web_browser.url
  current_url =~ /(.*\/).*$/
  current_url_parent = $1
  if options[:replacement] && base_url =~ /^http:/
    File.new(file, "w").puts absolutize_page_hpricot(content, base_url, current_url_parent)
  else
    File.new(file, "w").puts content
  end

end

#select_file_for_upload(file_field_name, file_path) ⇒ Object



858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
# File 'lib/rwebspec-webdriver/driver.rb', line 858

def select_file_for_upload(file_field_name, file_path)
=begin        
  if is_windows?
    normalized_file_path = file_path.gsub("/", "\\")
    if $support_ie8 && check_ie_version && @ie_version >= 8
      # puts "IE8"
      file_field(:name, file_field).set(normalized_file_path)
      # choose_file_dialog(normalized_file_path)
    else
      file_field(:name, file_field).set(normalized_file_path)
    end
  else
    # for firefox, just call file_field, it may fail
    file_field(:name, file_field).set(normalized_file_path)
  end
=end
  elem = find_element(:name, file_field_name)
  elem.send_keys(file_path)
end

#shall_not_allow(&block) ⇒ Object Also known as: do_not_allow

fail the test if user can perform the operation

Example:

shall_not_allow { 1/0 }


609
610
611
612
613
614
615
616
617
# File 'lib/rwebspec-webdriver/driver.rb', line 609

def shall_not_allow(& block)
  operation_performed_ok = false
  begin
    yield
    operation_performed_ok = true
  rescue
  end
  raise "Operation shall not be allowed" if operation_performed_ok
end

#span_with_id(span_id, options = {}) ⇒ Object

return the text of specific (identified by attribute “id”) span tag For page containing

<span id="preferred_recorder">iTest2/Watir Recorder</span>

span_with_id(“preferred_recorder”) # => iTest2/Watir Recorder



541
542
543
544
545
546
547
548
# File 'lib/rwebspec-webdriver/driver.rb', line 541

def span_with_id(span_id, options = {})
  if options && options[:index] then
    elements = find_elements(:id, span_id.to_s)
    elements[options[:index].to_i - 1].text
  else
    find_element(:id, span_id.to_s).text
  end
end

#substitute_relative_path_in_src_line(line, script_src, host_url, page_parent_url) ⇒ Object

substut



491
492
493
494
495
496
497
498
499
500
# File 'lib/rwebspec-webdriver/driver.rb', line 491

def substitute_relative_path_in_src_line(line, script_src, host_url, page_parent_url)
  unless script_src =~ /^["']?http:/
    host_url.slice!(-1) if ends_with?(host_url, "/")
    if script_src =~ /^\s*\// # absolute_path
      line.gsub!(script_src, "#{host_url}#{script_src}")
    else #relative_path
      line.gsub!(script_src, "#{page_parent_url}#{script_src}")
    end
  end
end

#support_utf8Object Also known as: support_unicode

Support browser (IE) operations using unicode

Example:
 click_button("Google 搜索")

Reference: jira.openqa.org/browse/WTR-219



581
582
583
584
585
586
# File 'lib/rwebspec-webdriver/driver.rb', line 581

def support_utf8
  if is_windows?
    require 'win32ole'
    WIN32OLE.codepage = WIN32OLE::CP_UTF8
  end
end

#symbol_to_sequence(symb) ⇒ Object

Convert :first to 1, :second to 2, and so on…



815
816
817
818
819
820
821
822
823
824
825
826
827
828
# File 'lib/rwebspec-webdriver/driver.rb', line 815

def symbol_to_sequence(symb)
  value = {:zero => 0,
    :first => 1,
    :second => 2,
    :third => 3,
    :fourth => 4,
    :fifth => 5,
    :sixth => 6,
    :seventh => 7,
    :eighth => 8,
    :ninth => 9,
  :tenth => 10}[symb]
  return value || symb.to_i
end

#take_screenshotObject

use win32screenshot library to save curernt active window, which shall be IE



971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
# File 'lib/rwebspec-webdriver/driver.rb', line 971

def take_screenshot
  if $testwise_screenshot_supported && is_windows?
    begin
      screenshot_image_filename =  "screenshot_" + Time.now.strftime("%m%d%H%M%S") + ".jpg"
      the_dump_dir = default_dump_dir
      FileUtils.mkdir_p(the_dump_dir) unless File.exists?(the_dump_dir)
      screenshot_image_filepath = File.join(the_dump_dir, screenshot_image_filename)
      screenshot_image_filepath.gsub!("/", "\\") if is_windows?

      FileUtils.rm_f(screenshot_image_filepath) if File.exist?(screenshot_image_filepath)

      case @web_browser.underlying_browser.browser
        when :internet_explorer
          Win32::Screenshot::Take.of(:window, :title => /internet\sexplorer/i).write(screenshot_image_filepath)
        else
          Win32::Screenshot::Take.of(:foreground).write(screenshot_image_filepath)
      end
      notify_screenshot_location(screenshot_image_filepath)
    rescue => e
      puts "error on taking screenshot: #{e}"
    end
  end
end

#try(timeout = @@default_timeout, polling_interval = @@default_polling_interval || 1, &block) ⇒ Object



806
807
808
809
810
811
# File 'lib/rwebspec-webdriver/driver.rb', line 806

def try(timeout = @@default_timeout, polling_interval = @@default_polling_interval || 1, &block)
  puts "Warning: method 'try' is deprecated (won't support in RWebSpec 3), use try_until instead."
  try_until(timeout, polling_interval) {
    yield
  }
end

#try_until(timeout = @@default_timeout, polling_interval = @@default_polling_interval || 1, &block) ⇒ Object Also known as: try_upto

Try the operation up to specified timeout (in seconds), and sleep given interval (in seconds). Error will be ignored until timeout Example

try { click_link('waiting')}
try(10, 2) { click_button('Search' } # try to click the 'Search' button upto 10 seconds, try every 2 seconds
try { click_button('Search' }


786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
# File 'lib/rwebspec-webdriver/driver.rb', line 786

def try_until(timeout = @@default_timeout, polling_interval = @@default_polling_interval || 1, & block)
  start_time = Time.now

  last_error = nil
  until (duration = Time.now - start_time) > timeout
    begin
      return if yield
      last_error = nil
    rescue => e
      last_error = e
    end
    sleep polling_interval
  end

  raise "Timeout after #{duration.to_i} seconds with error: #{last_error}." if last_error
  raise "Timeout after #{duration.to_i} seconds."
end

#use_current_browser(how = :title, what = /.*/) ⇒ Object

Reuse current an opened browser window instead of opening a new one example:

use_current_browser(:title, /.*/) # use what ever browser window
use_current_browser(:title, "TestWise") # use browser window with title "TestWise"


222
223
224
# File 'lib/rwebspec-webdriver/driver.rb', line 222

def use_current_browser(how = :title, what = /.*/)
  @web_browser = WebBrowser.attach_browser(how, what)
end

#wait_for_element(element_id, timeout = @@default_timeout, interval = @@default_polling_interval) ⇒ Object

Wait the element with given id to be present in web page

Warning: this not working in Firefox, try use wait_util or try instead



707
708
709
710
711
712
713
714
715
716
# File 'lib/rwebspec-webdriver/driver.rb', line 707

def wait_for_element(element_id, timeout = @@default_timeout, interval = @@default_polling_interval)
  start_time = Time.now
  #TODO might not work with Firefox
  until @web_browser.element_by_id(element_id) do
    sleep(interval)
    if (Time.now - start_time) > timeout
      raise RuntimeError, "failed to find element: #{element_id} for max #{timeout}"
    end
  end
end

#wait_until(timeout = @@default_timeout || 30, polling_interval = @@default_polling_interval || 1, &block) ⇒ Object

Execute the provided block until either (1) it returns true, or (2) the timeout (in seconds) has been reached. If the timeout is reached, a TimeOutException will be raised. The block will always execute at least once.

This does not handle error, if the given block raise error, the statement finish with error Examples:

wait_until {puts 'hello'}
wait_until { div(:id, :receipt_date).exists? }

Raises:

  • (TimeoutError)


656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
# File 'lib/rwebspec-webdriver/driver.rb', line 656

def wait_until(timeout = @@default_timeout || 30, polling_interval = @@default_polling_interval || 1, & block)
  end_time = ::Time.now + timeout

  until ::Time.now > end_time
    result = nil 
    begin 
      result = yield(self)
      return result if result	        
    rescue => e
    end
    sleep polling_interval
  end

  raise TimeoutError, "timed out after #{timeout} seconds"
end