Вопрос

Я пытаюсь сделать скриншоты при сбое теста, используя selenium-client и rspec.Я запускаю эту команду:

$ spec my_spec.rb \
--require 'rubygems,selenium/rspec/reporting/selenium_test_report_formatter' \
--format=Selenium::RSpec::SeleniumTestReportFormatter:./report.html 

Он создает отчет корректно, когда все проходит, поскольку скриншоты не требуются.Однако, когда тест завершается неудачей, я получаю это сообщение, а в отчете есть пустые скриншоты:

WARNING: Could not capture HTML snapshot: execution expired
WARNING: Could not capture page screenshot: execution expired
WARNING: Could not capture system screenshot: execution expired
Problem while capturing system stateexecution expired

Что вызывает эту ошибку "срок выполнения истек"?Я упускаю что-то важное в своей спецификации?Вот код для my_spec.rb:

require 'rubygems'
gem "rspec", "=1.2.8"
gem "selenium-client"
require "selenium/client"
require "selenium/rspec/spec_helper"

describe "Databases" do
    attr_reader :selenium_driver
    alias :page :selenium_driver

  before(:all) do
      @selenium_driver = Selenium::Client::Driver.new \
          :host => "192.168.0.10",
          :port => 4444,
          :browser => "*firefox",
          :url => "http://192.168.0.11/",
          :timeout_in_seconds => 10
  end

  before(:each) do
    @selenium_driver.start_new_browser_session
  end

  # The system capture need to happen BEFORE closing the Selenium session
  append_after(:each) do
    @selenium_driver.close_current_browser_session
  end

  it "backed up" do
    page.open "/SQLDBDetails.aspx"
    page.click "btnBackup", :wait_for => :page
    page.text?("Pending Backup").should be_true
  end
end
Это было полезно?

Решение

Чтобы получить скриншоты при работе с ошибкой, мне пришлось немного подправить ситуацию.

Я перенес следующий код из spec_helper (который я нашел в C: uby\lib uby\gems\selenium-client-1.2.18\lib\selenium spec\spec_helper.rb):

    if actual_failure?
         Selenium::RSpec::SeleniumTestReportFormatter.capture_system_state(selenium_driver, self)
    end

и поместил его в раздел append_after(: each) do моего теста setup / teardown (перед строкой @selenium_driver.close_current_browser_session).

Надеюсь, это поможет!

Другие советы

Я столкнулся с этой проблемой и смог ее решить, настроив время ожидания для водителя. Это может привести к тому, что драйвер завершит сеанс браузера перед запуском: after_each Вы используете 10 секунд, я в порядке с: timeout_in_seconds = > 2000

Почему бы не сделать снимок экрана в функции after, но перед тем, как закрыть браузер?

похоже, что там отсутствует " .

it "backed up" do
    page.open "/SQLDBDetails.aspx
scroll top