私はRubyの新機能であり、受け入れテストのためにWatirでスクリプトを開発しています。ブラウザを更新した後のRubyのグローバル変数
基本的にドロップダウンリストを表示し、すべてのドロップダウンアイテムをグローバル変数に格納してから、それを反復して他の機能を実行する小さなスクリプトがあります。
問題は、各ドロップダウンアイテムのすべての機能を実行した後にブラウザをリフレッシュしようとすると発生し、次のドロップダウンアイテムに反復し、すべてのドロップダウンアイテムが完了するまで同じ機能を実行しようとします。
$browser = Watir::Browser.new :chrome
$wait = Watir::Wait
def wait_while_loading(what)
lightbox = $browser.div(:class , 'lightbox')
begin
# Capture load start
start = Time.now
$wait.until { lightbox.present? }
$wait.until { !lightbox.present? }
# Capture load end
finish = Time.now
load_time = (finish - start).to_s
rescue => e
print e.backtrace.join("\n")
#log_error('Failed while loading ' + what + '.')
end
end
def cycle_all_views
$views = []
$current_view
$view_dropdown = $browser.div(:id, 'views-dropdown')
$views = $browser.div(:class, 'dropdown-views').div(:class, 'dropdown-menu--footer').ul(:class, 'dropdown-menu').divs(:class, 'dropdown-menu-item')
start_on_view = 10
begin
$views.drop(start_on_view).each_with_index do |view, i|
$view_dropdown.click
$current_view = view.text
index = i.to_s
safe_name = sanitize($current_view)
view.click
wait_while_loading($current_view)
$browser.refresh
wait_while_loading('Refreshing Page...')
end
rescue => e
#log_error('Failed to load view ' + $current_view)
end
end
は、次のview
に反復した後$views_dropdown
をクリックし、$browser.refresh
をトリガした後、私は$current_view = view.text
をやろうとしたときに想定しno implicit conversion of nil into String
を示すエラーで迎えています。ページの更新後に変数へのすべての割り当てを失うのですか?もしそうなら、それらを保つ方法はありますか?
誰かがWatirスクリプトのデバッグのより良い方法を教えてくれたら、私は自分の人生を楽にする方法を知りたいと思っています。
スタックトレースは、これを返します。
C:/Ruby23/lib/ruby/gems/2.3.0/gems/watir-webdriver-0.9.3/lib/watir-webdriver/ele
ments/element.rb:536:in `assert_element_found'
C:/Ruby23/lib/ruby/gems/2.3.0/gems/watir-webdriver-0.9.3/lib/watir-webdriver/ele
ments/element.rb:524:in `ensure_not_stale'
C:/Ruby23/lib/ruby/gems/2.3.0/gems/watir-webdriver-0.9.3/lib/watir-webdriver/ele
ments/element.rb:503:in `assert_exists'
C:/Ruby23/lib/ruby/gems/2.3.0/gems/watir-webdriver-0.9.3/lib/watir-webdriver/ele
ments/element.rb:81:in `text'
main.rb:55:in `block in cycle_all_views'
main.rb:52:in `each'
main.rb:52:in `each_with_index'
main.rb:52:in `cycle_all_views'
main.rb:122:in `block in <main>'
main.rb:112:in `each'
main.rb:112:in `<main>'Failed to load view First View
エラーのスタックトレースを投稿してください。 – DiegoSalazar
スタックトレースは元の投稿に掲載されています。 – ascendantofrain
と私はUIテストの作業のためにRubymineのデバッガが大好きです。 – titusfortner