こんばんは。検索してもマッチする結果がなかなか見つからないため、質問させてください。
Minitestにて、以下の条件でテストを行ったところ、タイトルに記載した通りのエラーが出ます。
(エラーログは以下です。)
Ruby
1Minitest::Result 2 remembering 3 4 Expected nil (NilClass) to respond to #empty?.
users_login_test.rb
Ruby
1require 'test_helper' 2 3class UsersLoginTest < ActionDispatch::IntegrationTest 4 def setup 5 @user = users(:michael) 6 end 7. 8. 9. 10 11 test "login with remembering" do 12 log_in_as(@user, remember_me: '1') 13 assert_not_empty cookies['remember_token'] 14 end 15 16 test "login without remembering" do 17 log_in_as(@user,remember_me:'0') 18 assert_empty cookies['remember_token'] 19 end 20end
test_helper.rb
Ruby
1require File.expand_path('../../config/environment', __FILE__) 2require 'rails/test_help' 3 4class ActiveSupport::TestCase 5 # Setup all fixtures in test/fixtures/*.yml for all tests in alphabetical order. 6 fixtures :all 7 8 # テストユーザーがログイン中の場合にtrueを返す 9 def is_logged_in? 10 !session[:user_id].nil? 11 end 12 13 # テストユーザーとしてログインする 14 def log_in_as(user) 15 session[:user_id] = user.id 16 end 17end 18 19class ActionDispatch::IntegrationTest 20 # テストユーザーとしてログインする 21 def log_in_as(user, password: 'password', remember_me: '1') 22 post login_path, params: { session: { email: user.email, 23 password: password, 24 remember_me: remember_me } } 25 end 26end
sessions_controller.rb
Ruby
1class SessionsController < ApplicationController 2 def new 3 end 4 5 def create 6 user = User.find_by(email: params[:session][:email].downcase) 7 if user && user.authenticate(params[:session][:password]) 8 log_in user 9 params[:session][:remember_me] == '1' ? remember(user) : forget(user) 10 redirect_to user 11 else 12 render 'new' 13 end 14 end 15 16 def destroy 17 log_out if logged_in? 18 redirect_to root_url 19 end 20end
user.rb
Ruby
1class User < ApplicationRecord 2 attr_accessor :remember_token 3 4 before_save { self.email = email.downcase } 5 validates :name, presence: true, length: { maximum: 25 } 6 VALID_EMAIL_REGEX = /\A[\w+\-.]+@[a-z\d\-.]+.[a-z]+\z/i 7 validates :email, presence: true, length: { maximum: 255 }, format: { with: VALID_EMAIL_REGEX }, uniqueness: { case_sensitive: false} 8 9 has_secure_password 10 validates :password, presence: true,length: { minimum: 6 } 11 12 13 14 def User.digest(string) 15 cost = ActiveModel::SecurePassword.min_cost ? BCrypt::Engine::MIN_COST : 16 BCrypt::Engine.cost 17 BCrypt::Password.create(string,cost: cost) 18 end 19 20 def User.new_token 21 SecureRandom.urlsafe_base64 22 end 23 24 def remember 25 self.remember_token = User.new_token 26 update_attribute(:remember_digest, User.digest(remember_token)) 27 end 28 29 def authenticated?(remember_token) 30 return false if remember_digest.nil? 31 BCrypt::Password.new(remember_digest).is_password?(remember_token) 32 end 33 34 def forget 35 update_attribute(:remember_digest,nil) 36 end 37end 38 39
以上のファイルのみで恐らく足りると思います。
なお、実際に動作確認を自分の手でしてみても、特に挙動としておかしいところもなく、いまいちどこが悪いのかよくわかりません。
大変初歩的な誤りを犯しているのだとは思うのですが…。
お忙しい中申し訳ないですが、よろしくお願いいたします。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。