Railsにて、remember me機能のテストを作成中なのですが、
下記のエラーが発生して解決ができない状況です。
ヒントなど頂けますと幸いです。
#エラー内容
Failure: UsersLoginTest#test_login_with_remembering [/home/ec2-user/environment/Metal/test/integration/users_login_test.rb:45]: --- expected +++ actual @@ -1 +1,3 @@ -"eyJfcmFpbHMiOnsibWVzc2FnZSI6IklrSTFaMVZCWTA5Q09ISlNTMmsyVFRWa1QyaEdTMUVpIiwiZXhwIjpudWxsLCJwdXIiOiJjb29raWUucmVtZW1iZXJfdG9rZW4ifX0=--c779d655e1ca944e0014d74517e936ecd13461d5" +# encoding: US-ASCII +# valid: true +"B5gUAcOB8rRKi6M5dOhFKQ"
こちらのエラーが発生してしまいます。
期待されたremember_tokenと、実際のremember_tokenが異なっているという意味かと認識しているのですが、
なぜ異なっているのか、検討がつかないといった状況です。
#関係があると考えたコード
#[test/integration/users_login_test.rb] #remember me機能をテストするコード test "login with remembering" do log_in_as(@user, remember_me: '1') #assert_not_empty cookies[:remember_token] assert_equal cookies['remember_token'], assigns(:user).remember_token end
↑
[試したこと]
assert_not_empty cookies[:remember_token]
をコメントインして、
assert_equal cookies['remember_token'], assigns(:user).remember_token
をコメントアウトするとテストが成功します。
#[controllers/sessions_controller.rb] #ログイン機能を実装しているコード def create @user = User.find_by(email: params[:session][:email].downcase) if @user && @user.authenticate(params[:session][:password]) #ユーザーログイン後にユーザー情報のページにリダイレクトする。 log_in @user params[:session][:remember_me] == '1' ? remember(@user) : forget(@user) redirect_to user_url(@user) else flash.now[:danger] = "ログイン情報に誤りがあります。" render 'new' end end
#[helpers/sessions_helper.rb] #controllers/session_controller.rbで使用しているヘルパーを定義しているコード #ユーザーのセッションを永続的にする def remember(user) user.remember cookies.permanent.signed[:user_id] = user.id cookies.permanent.signed[:remember_token] = user.remember_token end #永続的セッションを破棄する def forget(user) user.forget cookies.delete(:user_id) cookies.delete(:remember_token) end
#[model/user.rb] #controllers/session_controller.rbで使用している、remember_tokenについて定義をしているコード class User < ApplicationRecord attr_accessor :remember_token before_save {self.email = email.downcase } validates :name, presence: true, length: { maximum: 50 } VALID_EMAIL_REGEX = /\A[\w+\-.]+@[a-z\d\-]+(.[a-z\d\-]+)*.[a-z]+\z/i validates :email, presence: true, length: { maximum: 255 }, format: { with: VALID_EMAIL_REGEX }, uniqueness: true has_secure_password validates :password, presence: true, length: { minimum: 6 } #渡された文字列のハッシュ値を返す def User.digest(string) cost = ActiveModel::SecurePassword.min_cost ? BCrypt::Engine::MIN_COST : BCrypt::Engine.cost BCrypt::Password.create(string, cost: cost) end #ランダムなトークンを返す def User.new_token SecureRandom.urlsafe_base64 end def remember self.remember_token = User.new_token update_attribute(:remember_digest, User.digest(remember_token)) end #渡されたトークンがダイジェストと一致したらtrueを返す #ここでのremember_tokenは、attr_accessor :remember_tokenで定義したアクセサとは異なる。 def authenticated?(remember_token) return false if remember_digest.nil? BCrypt::Password.new(remember_digest).is_password?(remember_token) end #ユーザーのログイン情報を破棄する def forget update_attribute(:remember_digest, nil) end end
以上でございます。
恐れ入りますが、ご確認のほどよろしくお願いいたします。
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。