よろしくお願いいたします。
Ruby初心者です。RailsTutorial9章でテストが正常に動作しないので。知恵をお借りしたいです。
↓エラーメッセージ
ruby
1PS C:\中略\environment\sample_app> rails test 2 3(中略) 4Error: 5UsersLoginTest#test_login_with_valid_information: 6NoMethodError: undefined method `forget' for #<SessionsController:0x000000000ab1c240> 7Did you mean? format 8 app/controllers/sessions_controller.rb:10:in `create' 9 test/integration/users_login_test.rb:21:in `block in <class:UsersLoginTest>' 10 11 12bin/rails test test/integration/users_login_test.rb:19
↓テストで引っかかっていると思しき「sessions_controller.rb」
ruby
1class SessionsController < ApplicationController 2 3 def new 4 end 5 6 def create 7 user = User.find_by(email: params[:session][:email].downcase) 8 if user && user.authenticate(params[:session][:password]) 9 log_in user 10 #エラー該当行 11 #「remember」は見つかるのに「forget」が見つからない? 12 params[:session][:remember_me] == '1' ? remember(user) : forget(user) 13 redirect_to user 14 else 15 flash.now[:danger] = 'Invalid email/password combination' 16 render 'new' 17 end 18 end 19 20 def destroy 21 log_out if logged_in? 22 redirect_to root_url 23 end 24end
↓「forget」の呼び出し元と思しき「user.rb」
ruby
1class User < ApplicationRecord 2 attr_accessor :remember_token 3 before_save { self.email = email.downcase } 4 validates :name, presence: true, length: { maximum: 50 } 5 VALID_EMAIL_REGEX = /\A[\w+\-.]+@[a-z\d\-.]+.[a-z]+\z/i 6 validates :email, presence: true, length: { maximum: 255 }, 7 format: { with: VALID_EMAIL_REGEX }, 8 uniqueness: { case_sensitive: false } 9 has_secure_password 10 validates :password, presence: true, length: { minimum: 6 } 11 12 # 渡された文字列のハッシュ値を返す 13 def User.digest(string) 14 cost = ActiveModel::SecurePassword.min_cost ? BCrypt::Engine::MIN_COST : 15 BCrypt::Engine.cost 16 BCrypt::Password.create(string, cost: cost) 17 end 18 19 # ランダムなトークンを返す 20 def User.new_token 21 SecureRandom.urlsafe_base64 22 end 23 24 # 永続セッションのためにユーザーをデータベースに記憶する 25 def remember 26 self.remember_token = User.new_token 27 update_attribute(:remember_digest, User.digest(remember_token)) 28 end 29 30 # 渡されたトークンがダイジェストと一致したらtrueを返す 31 def authenticated?(remember_token) 32 return false if remember_digest.nil? 33 BCrypt::Password.new(remember_digest).is_password?(remember_token) 34 end 35 36 # ユーザーのログイン情報を破棄する 37 def forget 38 update_attribute(:remember_digest, nil) 39 end 40 41 # 永続的セッションを破棄する 42 #見つかってないforgetってこれ? 43 def forget(user) 44 user.forget 45 cookies.delete(:user_id) 46 cookies.delete(:remember_token) 47 end 48 49 # 現在のユーザーをログアウトする 50 def log_out 51 forget(current_user) 52 session.delete(:user_id) 53 @current_user = nil 54 end 55end
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。