Rspec系统测试在单独运行时通过,在整个套件中运行时失败

时间:2019-02-18 10:22:46

标签: ruby-on-rails ruby-on-rails-5 rspec-rails

当我单独运行它时,我通过了以下测试:

require 'rails_helper'

RSpec.describe 'deleting a non-recurring user event', js: true do

  let(:user)       { create(:proofreader_user) }
  let(:date)       { Date.current.strftime('%Y-%m-%d') }
  let(:date_time)  { date + ' 00:00'}

  it 'deletes the event' do
    visit root_path
    click_on "Login"
    fill_in  "Email",    with: user.email
    fill_in  "Password", with: user.password
    click_on "Sign In"
    visit calendar_path
    expect(current_path).to eq(calendar_path)
    expect(page).to have_css("#complete_registration:disabled")
    expect(page).to_not have_css("td.fc-event-container")
    find("td.fc-day[data-date='#{date}']").click
    expect(page).to have_css("div#user-event-modal")
    expect(page).to have_select('user_event[title]', :options => UserEvent.titles.keys)
    expect(find('input', id: 'user_event_starting').value).to eq date_time
    expect(find('input', id: 'user_event_ending').value).to eq date_time
    page.execute_script("$('input#user_event_starting').val('#{date} 09:00')")
    expect(find('input', id: 'user_event_starting').value).to eq date + ' 09:00'
    page.execute_script("$('input#user_event_ending').val('#{date} 12:00')")
    expect(find('input', id: 'user_event_ending').value).to eq date + ' 12:00'
    click_on 'Save'
    expect(page).to have_css("td.fc-event-container a.fc-day-grid-event")
    expect(page).to have_css("span.fc-time", text: '9a - 12p')
    expect(page).to have_css("span.fc-title", text: 'work')
    find("span.fc-time", text: '9a - 12p').click
    expect(page).to have_css("div#user-event-modal")
    find("#del_one_event").click
    within('.swal2-actions') { click_button('Yes') }
    wait_for { page }.to_not have_css("div#user-event-modal")
    expect(page).to_not have_css("td.fc-event-container")
    expect(page).to_not have_css("span.fc-time", text: '10a - 14p')
  end
end

但是,当我运行所有测试时,出现以下错误:

Failure/Error: within('.swal2-actions') { click_button('Yes') }

     Capybara::ElementNotFound:
       Unable to find visible css ".swal2-actions"

为什么当我与其他测试一起运行时该测试失败,并且我如何解决它才能在运行所有测试时通过?

2 个答案:

答案 0 :(得分:3)

如果没有更多信息,无法确定。最好创建并发布minimum complete verifiable example

根据给出的信息,我猜想与其他测试一起运行时失败的测试没有正确隔离。其他示例正在更改应用程序的状态,从而导致该测试失败。因此,请查看您的beforeafter钩子,并确保在rails_helper.rb

中设置了config.use_transactional_fixtures = true

如果在单击#del_one_event到出现.swal2-actions的时间之间可能存在延迟,则进行更改

within('.swal2-actions') { click_button('Yes') }

find('.swal2-actions').click_button('Yes')

如果这些方法都不能解决问题,则browser caching可能有问题,但这甚至更难调试。

答案 1 :(得分:1)

如果不查看其他测试,很难回答。 但是我注意到一些值得检查的地方:

  • 您正在通过导航应用程序来创建数据,也许其他测试也会创建数据,从而阻止该测试中的数据被创建
  • 命令find("#del_one_event").click(前一行)仅执行单击,而不会等到发生任何事情。由于所有测试和数据库中都有更多数据,执行.swal2-actions时可能要花更长的时间,直到within('.swal2-actions') { click_button('Yes') }出现并且尚不存在

接近错误的另一种方法是制作屏幕快照并进行比较。查看宝石capybara-screenshot