我想測試這個測試登入/ signout方法:無法毀壞CURRENT_USER在SIGN_OUT方法功能測試
測試/控制器/ sessions_controller_test.rb
class SessionsControllerTest < ActionController::TestCase
fixtures :users
include SessionsHelper
test "should signin and signout" do
get :new
assert_response :success
post :create, email: users(:alex).email, password: 'qwerty'
assert_redirected_to profile_url
assert cookies[:remember_token]
assert current_user == users(:alex), 'Ooops! Wrong current_user!'
delete :destroy
assert_redirected_to signin_url
debugger
assert !cookies[:remember_token]
=> assert !current_user, 'Ooops! Current_user not nil!'
end
end
在=>點cookies[:remember_token]
不見了,但current_user
仍users(:alex)
,我不明白爲什麼。我有沒有錯過delete :destroy
一行?
集成測試正在通過,並且在帶有註銷行爲的瀏覽器中進行現場演出也有訣竅。
從會話控制器和輔助方法:
sessions_controller.rb
def destroy
sign_out
redirect_to signin_url
end
sessions_helper.rb
def current_user=(user)
@current_user = user
end
def current_user
remember_token = User.encrypt(cookies[:remember_token])
@current_user ||= User.find_by(remember_token: remember_token)
end
def sign_out
cookies.delete(:remember_token)
self.current_user = nil
end
'User.find_by(remember_token:User.encrypt(nil))'返回什麼? –
'User.find_by(remember_token:User.encrypt(nil))=>無' –