🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 6

Ruby on Rails 6は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

RSpec

RSpecはRuby用のBDD(behaviour-driven development)フレームワークです。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

2回答

692閲覧

[Ruby on Rails]remember_meのテストが成功しない

gussan-me

総合スコア7

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 6

Ruby on Rails 6は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

RSpec

RSpecはRuby用のBDD(behaviour-driven development)フレームワークです。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2021/02/25 01:05

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

以上でございます。
恐れ入りますが、ご確認のほどよろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

def remember(user) user.remember cookies.permanent.signed[:user_id] = user.id cookies.permanent[:remember_token] = user.remember_token end #永続的セッションを破棄する def forget(user) user.forget cookies.delete(:user_id) cookies.delete(:remember_token) end

とすることで解決しました。

投稿2021/02/25 12:10

gussan-me

総合スコア7

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

自己解決

def remember(user) user.remember cookies.permanent.signed[:user_id] = user.id cookies.permanent[:remember_token] = user.remember_token end #永続的セッションを破棄する def forget(user) user.forget cookies.delete(:user_id) cookies.delete(:remember_token) end

とすることで解決しました。

投稿2021/02/25 12:05

gussan-me

総合スコア7

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問