2014-04-18 79 views
0

在Rails教程中,本節結束,所有測試都失敗了。任何幫助將非常感激。Rails教程第9章,9.2.2 - 43錯誤

我的用戶控制器:

class UsersController < ApplicationController 
     before_action :signed_in_user, only: [:edit, :update] 
     before_action :correct_user, only: [:edit, :update] 

     def show 
     @user = User.find(params[:id]) 
     end 

     def new 
     @user = User.new 
     end 

     def edit 
     end 

     def update 
     if @user.update_attributes(user_params) 
      flash[:success] = "Profile updated" 
      redirect_to @user 
     else 
      render 'edit' 
     end 
     end 

     def create 
     @user = User.new(user_params) 
     if @user.save 
      sign_in @user 
      flash[:success] = "Welcome to the Sample App!" 
      redirect_to @user 
     else 
      render 'new' 
     end 
     end 

     private 

     def user_params 
      params.require(:user).permit(:name, :email, :password, 
             :password_confirmation) 
     end 

     # Before filters 

     def signed_in_user 
      redirect_to signin_url, notice: "Please sign in." unless signed_in? 
     end 

     def correct_user 
      @user = User.find(params[:id]) 
      redirect_to(root_url) unless current_user?(@user) 
     end 
    end 

我的認證規範:

require 'spec_helper' 

describe "Authentication" do 

    subject { page } 

    describe "signin page" do 
    before { visit signin_path } 

    it { should have_content('Sign in') } 
    it { should have_title('Sign in') } 
    end 

    describe "signin" do 
    before { visit signin_path } 

    describe "with invalid information" do 
     before { click_button "Sign in" } 

     it { should have_title('Sign in') } 
     it { should have_selector('div.alert.alert-error') } 

     describe "after visiting another page" do 
     before { click_link "Home" } 
     it { should_not have_selector('div.alert.alert-error') } 
     end 
    end 

    describe "with valid information" do 
     let(:user) { FactoryGirl.create(:user) } 
     before {sign_in user} 

     it { should have_title(user.name) } 
     it { should have_link('Profile',  href: user_path(user)) } 
     it { should have_link('Settings', href: edit_user_path(user)) } 
     it { should have_link('Sign out', href: signout_path) } 
     it { should_not have_link('Sign in', href: signin_path) } 

     describe "followed by signout" do 
     before { click_link "Sign out" } 
     it { should have_link('Sign in') } 
     end 
    end 
    end 

    describe "authorization" do 

    describe "for non-signed-in users" do 
     let(:user) { FactoryGirl.create(:user) } 

     describe "in the Users controller" do 

     describe "visiting the edit page" do 
      before { visit edit_user_path(user) } 
      it { should have_title('Sign in') } 
     end 

     describe "submitting to the update action" do 
      before { patch user_path(user) } 
      specify { expect(response).to redirect_to(signin_path) } 
     end 
     end 
    end 

    describe "as wrong user" do 
     let(:user) { FactoryGirl.create(:user) } 
     let(:wrong_user) { FactoryGirl.create(:user, email: "[email protected]") } 
     before { sign_in user, no_capybara: true } 

     describe "submitting a GET request to the Users#edit action" do 
     before { get edit_user_path(wrong_user) } 
     specify { expect(response.body).not_to match(full_title('Edit user')) } 
     specify { expect(response).to redirect_to(root_url) } 
     end 

     describe "submitting a PATCH request to the Users#update action" do 
     before { patch user_path(wrong_user) } 
     specify { expect(response).to redirect_to(root_url) } 
     end 
    end 
    end 
end 

我會幫手:

module SessionsHelper 

    def sign_in(user) 
    remember_token = User.new_remember_token 
    cookies.permanent[:remember_token] = remember_token 
    user.update_attribute(:remember_token, User.hash(remember_token)) 
    self.current_user = user 
    end 

    def signed_in? 
    !current_user.nil? 
    end 

    def current_user=(user) 
    @current_user = user 
    end 

    def current_user 
    remember_token = User.digest(cookies[:remember_token]) 
    @current_user ||= User.find_by(remember_token: remember_token) 
    end 

    def current_user?(user) 
    user == current_user 
    end 

    def sign_out 
    current_user.update_attribute(:remember_token, 
            User.hash(User.new_remember_token)) 
    cookies.delete(:remember_token) 
    self.current_user = nil 
    end 
end 

只是被問起User.rb模型文件,所以在這裏它是......

class User < ActiveRecord::Base 
    before_save { self.email = email.downcase } 
    before_create :create_remember_token 

    has_secure_password 
    before_save { email.downcase! } 
    validates :name, presence: true, length: { maximum: 50 } 
    VALID_EMAIL_REGEX = /\A[\w+\-.][email protected][a-z\d\-]+(?:\.[a-z\d\-]+)*\.[a-z]+\z/i 
    validates :email, presence: true, format: { with: VALID_EMAIL_REGEX }, 
        uniqueness: { case_sensitive: false } 
    has_secure_password 
    validates :password, length: { minimum: 6 } 

    def User.new_remember_token 
    SecureRandom.urlsafe_base64 
    end 

    def User.hash(token) 
    Digest::SHA1.hexdigest(token.to_s) 
    end 

    private 

    def create_remember_token 
     self.remember_token = User.hash(User.new_remember_token) 
    end 
end 
+0

你的錯誤在說什麼? –

+0

您可以舉幾個測試失敗的例子,以便我們可以看到錯誤。 –

+0

30)用戶頁面保存後用有效信息註冊 ←[31m失敗/錯誤:←[0m←[31mbefore {訪問註冊路徑}←[0m ←[31mActionView :: Template :: Error←[0m: ←[對於#<類:0x558c438>←[0m – robgreen48

回答

0

您正在呼籲User模式digest類的方法,但還沒有確定它尚未這就是爲什麼你的錯誤作爲undefined method 'digest'

在你User模型中,添加以下方法:

def User.digest(token) 
    Digest::SHA1.hexdigest(token.to_s) 
    end 

細節請參考8.2 Signin success部分。

+0

謝謝Kirti。我在User模型中有User.hash(token)方法,而不是User.digest(令牌)。改變它雖然不能解決它 – robgreen48

+0

你現在肯定會得到更少的錯誤。您可以使用錯誤消息和相關規範更新您的問題。那麼我可以看看它。 –

+0

嗨Kirti - 我修好了。 User.hash()方法已經更新到User.digest(),我不得不將所有引用替換爲舊方法。我現在通過了所有測試。謝謝你的幫助。 – robgreen48

相關問題