Por lo tanto, he comenzado a crear algunas pruebas de unidad de Ruby que usan Selenium RC para probar mi aplicación web directamente en el navegador. Estoy usando el Selenum-Client para ruby. Creé una clase base para todas mis otras pruebas de selenio para heredar.Selenium RC: ejecutar pruebas en navegadores múltiples automáticamente
Esto crea numerosas instancias de SeleniumDriver y se invoca a todos los métodos que faltan en cada instancia. Esto esencialmente ejecuta las pruebas en paralelo.
¿Cómo lo han automatizado otras personas?
Esta es mi aplicación:
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
Esto funciona, pero si falla un navegador, toda la prueba falla, y no hay manera de saber qué navegador fracasó sucesivamente.
Hola Daniel, Tengo una pregunta similar. Me preguntaba si puedes ayudar. [Selenium RC: Cómo lanzar pruebas interactivas con múltiples navegadores] (http://stackoverflow.com/questions/2836313/selenium-rchow-to-launch-interactive-testing-with-multiple-browsers) – onesith