Capybara+rspec: ошибка маршрутизации Reset_Password

Поэтому я пытаюсь проверить простую функцию забытого пароля. Я новичок, так что извините, если это глупый вопрос. Здесь я должен ввести адрес электронной почты пользователя в форме забытого пароля, который отправляет мне ссылку в электронном письме для сброса пароля. Я захожу внутрь письма, но когда он нажимает на ссылку, страница попадает на страницу с ошибкой

 it "sends reset password email on submit",:js=> true, :focus=>true do


    visit "/login"
    click_link "Forgot Password?"
    sleep 1
    fill_in "email", :with => @user.email
    click_button "Submit"
    email = open_email(@user.email)
    email.should deliver_to(@user.email)
    #email.should have_subject("FlinkMusic - Forgot you password")
    click_first_link_in_email

    page.should have_content ("Reset your password")
        fill_in "Password ", :with => "password1" 
        fill_in "Repeat Password", :with => "password1"
        click_button "Reset Password"
        page.should have_content "Your password has been reset.Please log in."

end

вот мой spec_helper

   require 'rubygems'
   require 'spork'
   Spork.prefork do

   ENV["RAILS_ENV"] ||= 'test'
   require File.expand_path("../../config/environment", __FILE__)
   require 'rspec/rails'
  require 'rspec/autorun'
  require 'capybara/rspec'
  require "capybara-screenshot"
  require 'factory_girl_rails'
  Dir[Rails.root.join("spec/support/**/*.rb")].each {|f| require f}

 #Capybara.defualt_wait_time = 10

  if ENV['BROWSER_TEST']
Capybara.register_driver :selenium do |app|
Capybara::Selenium::Driver.new(app, :browser => :chrome)
 end
else
Capybara.javascript_driver = :selenium
 end
RSpec.configure do |config|

      config.include Capybara::DSL

     config.include(EmailSpec::Helpers)
     config.include(EmailSpec::Matchers)


     config.treat_symbols_as_metadata_keys_with_true_values = true
     config.filter_run :focus => true
     config.run_all_when_everything_filtered = true

Мне чего-то не хватает? Спасибо!

1 ответ

Решение

Проблема была click_first_link_in_email, Это не было нажатием на реальную ссылку. Я должен был использовать visit_in_email('Reset Password') чтобы открыть страницу "Сброс пароля".

Другие вопросы по тегам