Методы контроллера before_save не вызываются при тестировании

Следующий rails-api только приложение.

В users_controller.rb

  def sign_up
    @user = User.new(user_params)
    if @user.save
      user = {}
      user[:name] = @user.name
      user[:email] = @user.email
      user[:access_token] = @user.auth_token
      user[:message] = "Successfully Signed up"
      render json: user, status: 200
    else
      render json: @user.errors, status: :unprocessable_entity
    end
  end

  private 
  def user_params
    params.permit(:name, :email, :password, :password_confirmation)
  end

В модели /user.rb

attr_accessor :password
before_save :encrypt_password, :generate_token
VALID_EMAIL_REGEX = /\A[\w+\-.]+@[a-z\d\-.]+\.[a-z]+\z/i
validates :email, presence: true, format: { with: VALID_EMAIL_REGEX } , uniqueness: { case_sensitive:false }
validates :password, :confirmation => true, presence: true, :length => {:within => 6..20}
validates_presence_of :password_salt, :password_hash
validates_presence_of :auth_token

В тесте /controllers/users_controller_test.rb

test "should create user" do
  assert_difference('User.count') do
    post :sign_up, {email: '[email protected]', name: 'user_3', password: 12345678, password_confirmation: 12345678}
  end
end

Атрибуты пользовательской модели:

name email password_hash password_salt auth_token

Вышеприведенный тест не проходит b'cos @user.errors показывает

<ActiveModel::Errors:0x007fd826117140 @base=#<User id: nil, name: "user_3", email: "[email protected]", password_hash: nil, password_salt: nil, auth_token: nil, created_at: nil, updated_at: nil>, @messages={:password_salt=>["can't be blank"], :password_hash=>["can't be blank"], :auth_token=>["can't be blank"]}>

На @user.savebefore_save :encrypt_password, :generate_token не называются.

С помощью gem 'bcrypt' хранить пароль как хеш

Как мне это исправить?

1 ответ

Решение

Вместо before_save :encrypt_password, :generate_token использование before_validation :encrypt_password, :generate_token, Код в encrypt_password а также generate_token не запускается, потому что вы сначала проверяете данные модели, а поскольку данные недействительны, запускать не нужно before_save потому что запись не будет сохранена в любом случае

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