2

我正在使用 Authlogic 和 Rails 3.2.3。Authlogic 在开发模式下正确验证用户,我可以在注册后使用活动用户登录,但在测试模式下,当我使用 Capybara 运行集成测试时password is not valid出现错误。

我已经确保密码是相同的、有效的,我什至尝试过设置


  acts_as_authentic do |c|
   c.validate_password_field = false
  end 

在我的测试中,我使用工厂,这是我的工厂定义。


FactoryGirl.define do
  factory :user do
    sequence :email do |i| 
      "test_user_#{i}@example.com"
    end
    sequence :name do 
      |i| "test user#{i}"
    end
    password "testtesttest"
    password_confirmation "testtesttest"
    password_salt "passwordsalt"
    perishable_token "windowintheskies"
    single_access_token "123123123"
  end  
end

我的数据库字段都允许 crypted_pa​​ssword 字段是 Varchar(255)


+---------------------+--------------+------+-----+---------+----------------+
| Field               | Type         | Null | Key | Default | Extra          |
+---------------------+--------------+------+-----+---------+----------------+
| id                  | int(11)      | NO   | PRI | NULL    | auto_increment |
| crypted_password    | varchar(255) | NO   |     | NULL    |                |
| password_salt       | varchar(255) | NO   |     | NULL    |                |
| email               | varchar(255) | NO   |     | NULL    |                |
| persistence_token   | varchar(255) | NO   |     | NULL    |                |
| single_access_token | varchar(255) | NO   |     | NULL    |                |
| perishable_token    | varchar(255) | NO   |     | NULL    |                |
| login_count         | int(11)      | NO   |     | 0       |                |
| failed_login_count  | int(11)      | NO   |     | 0       |                |
| last_request_at     | datetime     | YES  |     | NULL    |                |
| current_login_at    | datetime     | YES  |     | NULL    |                |
| last_login_at       | datetime     | YES  |     | NULL    |                |
| current_login_ip    | varchar(255) | YES  |     | NULL    |                |
| last_login_ip       | varchar(255) | YES  |     | NULL    |                |
| name                | varchar(255) | NO   |     |         |                |
| created_at          | datetime     | NO   |     | NULL    |                |
| updated_at          | datetime     | NO   |     | NULL    |                |
| active              | tinyint(1)   | YES  |     | 0       |                |
+---------------------+--------------+------+-----+---------+----------------+


我正在使用 capybara 运行我的集成测试,我发现错误只发生在测试模式而不是开发模式。

另外,我确定密码不为空

我的集成测试规范看起来像这样


require 'spec_helper'
describe "/lists" do    
  before(:each) do        
    @user = FactoryGirl.build(:user, :password => 'testtesttest', :password_confirmation => 'testtesttest') 
    @user.activate!    
  end

  it "loads the list creation pages on clicking the new list button" do    
    visit new_user_session_path
    fill_in "user_session_email", :with => @user.email
    fill_in "user_session_password", :with => 'testtesttest'
    click_button "Login"
    page.should have_content "My Lists"        
    visit lists_path
    click_link "Create A New List"
    page.should have_content('New List')
  end      

我的 user_sessions_controller 看起来像这样



  def create
    @user_session = UserSession.new(params[:user_session])
    puts "*" * 50
    puts " Password - #{params[:user_session][:password].to_s}"
    puts " User #{User.where(:email => params[:user_session][:email]).first.inspect}"
    puts "Valid #{User.where(:email => params[:user_session][:email]).first.valid_password?(params[:user_session][:password])}"
    puts " Active =  #{User.where(:email => params[:user_session][:email]).first.active?}"
    puts "*" * 50
    if @user_session.save!
      flash[:notice] = "Login successful!"
      redirect_back_or_default lists_url
    else                          
      puts "Error : #{@user_session.errors.inspect}"
      render :action => :new
    end
  end

4

0 回答 0