そこで、 Selenium RCを使用して Web アプリをブラウザーで直接テストする Ruby 単体テストの作成を開始しました。ruby にはSelenum-Clientを使用しています。他のすべてのセレン テストの継承元となる基本クラスを作成しました。
これにより、多数の SeleniumDriver インスタンスが作成され、欠落しているすべてのメソッドが各インスタンスで呼び出されます。これにより、基本的にテストが並行して実行されます。
他の人はこれをどのように自動化しましたか?
これは私の実装です:
class SeleniumTest < Test::Unit::TestCase
def setup
@seleniums = %w(*firefox *iexplore).map do |browser|
puts 'creating browser ' + browser
Selenium::SeleniumDriver.new("localhost", 4444, browser, "http://localhost:3003", 10000)
end
start
open start_address
end
def teardown
stop
end
#sub-classes should override this if they want to change it
def start_address
"http://localhost:3003/"
end
# Overrides standard "open" method
def open(addr)
method_missing 'open', addr
end
# Overrides standard "type" method
def type(inputLocator, value)
method_missing 'type', inputLocator, value
end
# Overrides standard "select" method
def select(inputLocator, optionLocator)
method_missing 'select', inputLocator, optionLocator
end
def method_missing(method_name, *args)
@seleniums.each do |selenium_driver|
if args.empty?
selenium_driver.send method_name
else
selenium_driver.send method_name, *args
end
end
end
end
これは機能しますが、1 つのブラウザーが失敗すると、テスト全体が失敗し、どのブラウザーで失敗したかを知る方法がありません。