2016-01-09 34 views
0

我正在使用React编写Rails应用程序的测试代码。 我使用RSpec,水豚,Poltergeist(PhantomJS 2.0)和设计进行身份验证。RSpec /水豚/ Poltergeist登录测试失败

因为这是一个javascript测试,我还使用建议的here的database_cleaner gem。 当测试运行时,我可以看到用户数据进入数据库(mysql),Devise方法user.valid_password?("password")返回true,但是测试失败。

spec_helper.rb

RSpec.configure do |config| 

    config.use_transactional_fixtures = false 

    Capybara.register_driver :poltergeist do |app| 
    options = { 
     inspector: true, 
     js_errors: false, 
     #debug: true, 
     phantomjs_options: %w[ 
     --web-security=no 
     --ignore-ssl-errors=yes 
     --ssl-protocol=any 
     ] 
    } 
    Capybara::Poltergeist::Driver.new(app, options) 
    end 

    Capybara.javascript_driver = :poltergeist 

    config.before(:suite) do 
    DatabaseCleaner.clean_with(:truncation) 
    end 
    config.before(:each) do 
    DatabaseCleaner.strategy = :transaction 
    end 
    config.before(:each, js: true) do 
    DatabaseCleaner.strategy = :truncation 
    end 
    config.before(:each) do 
    DatabaseCleaner.start 
    end 
    config.after(:each) do 
    DatabaseCleaner.clean 
    end 

end 

的规格如下所示。

require 'spec_helper' 

feature 'Registration', js: true do 
    let!(:email) { "[email protected]" } 

    scenario "user can sign up and log in" do 
    visit 'sign_up' 
    find('input').set(email) 
    find('.submit').click 
    expect(page).to have_content('welcome!') 

    visit '/sign_out' 
    visit '/sign_in' 

    expect(page).to have_content('Login') 
    find('input[name="email"]').set(email) 
    find('input[name="password"]').set('password') 
    find('.submit').click 
    wait_for_ajax 

    expect(page).to have_content('Test User') 
    end 

end 

API看起来像这样。

post do 
    email = params[:email] 
    password = params[:password] 

    if email.nil? or password.nil? 
    return error!(['this is error'], 401) 
    end 

    user = User.where(email: email.downcase).first 
    if user.nil? 
    return error!(['this is error'], 401) 
    end 
    if !user.valid_password?(password) 
    return error!(['this is error'], 401) 
    else 
    user.ensure_authentication_token 
    user.save 
    return { status: 'ok', results: { access_token: user.authentication_token } } 
    end 
end 

我用PhantomJS 2.0获得如下所示的日志。

API.ajax:POST /sessions 
API.ajax:POST /sessions 
API.ajax:POST /sessions :failed 
httpStatus:401 
error 
[object Object] 
API.ajax:POST /sessions :failed 
httpStatus:401 
error 
[object Object] 

所以在认证过程中出了点问题,但它只发生在我运行测试时。 (我可以注册并使用Chrome或Firefox登录。)

欣赏任何想法。

谢谢!

回答