2012-06-19 35 views
2

我会非常感谢任何帮助确定我无法注销示例应用程序的原因。 *我所有的rspec测试通过。 *当我去注销我的本地服务器时,请单击注销,我没有注销,并且链接不会更改为登录(虽然此通道的rspec测试)。Hartl Rails教程第8章 - 无法注销Sample_App。所有rspec测试通过

下面是authentication_pages_spec.rb

require 'spec_helper' 

describe "AuthenticationPages" do 

    subject { page } 

    describe "signin page" do 
    before { visit signin_path } 

    it { should have_selector('h1', text: 'Sign in') } 
    it { should have_selector('title', text: 'Sign in') } 
    end 

    describe "signin" do 
    before { visit signin_path } 

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

     it { should have_selector('title', text: 'Sign in') } 
     it { should have_selector('div.alert.alert-error', text: 'Invalid') } 

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

    describe "with valid information" do 
     let(:user) { FactoryGirl.create(:user) } 
     before do 
     fill_in "Email", with: user.email 
     fill_in "Password", with: user.password 
     click_button "Sign in" 
     end 

     it { should have_selector('title', text: user.name) } 
     it { should have_link('Profile',  href: 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 
end 

这里的相关试验是sessions_controller.rb

class SessionsController < ApplicationController 

    def new 
    end 

    def create 
    user = User.find_by_email(params[:session][:email]) 
    if user && user.authenticate(params[:session][:password]) 
     sign_in user 
     redirect_to user 
    else 
     flash.now[:error] = "Invalid email/password combination" 
     render 'new' 
    end 
    end 

    def destroy 
    sign_out 
    redirect_to root_path 
    end 
end 

这里是sessions_helper.rb

module SessionsHelper 
    def sign_in(user) 
    cookies.permanent[:remember_token] = user.remember_token 
    self.current_user = user 
    end 

    def signed_in? 
    !self.current_user.nil? 
    end 

    def current_user=(user) 
    @current_user = user 
    end 

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

    def sign_out 
    self.current_user = nil 
    cookies.delete(:remember_token) 
    end 
end 

这里是_header.html。 erb

<header class="navbar navbar-fixed-top"> 
    <div class="navbar-inner"> 
     <div class="container"> 
      <%= link_to "sample app", root_path, id: "logo" %> 
      <nav> 
       <ul class="nav pull-right"> 
        <li><%= link_to "Home", root_path %></li> 
        <li><%= link_to "Help", help_path %></li> 
        <% if signed_in? %> 
         <li><%= link_to "Users", '#' %></li> 
         <li id="fat-menu" class="dropdown"> 
          <a href='#' class="dropdown-toggle" data-toggle="dropdown"> 
           Account <b class="caret"></b> 
          </a> 
          <ul class="dropdown-menu"> 
           <li><%= link_to "Profile", user_path(current_user) %></li> 
           <li><%= link_to "Settings", '#' %></li> 
           <li class="divider"></li> 
           <li> 
            <%= link_to "Sign out", signout_path, method: "delete" %>  
           </li> 
          </ul> 
         </li>   
        <% else %> 
         <li><%= link_to "Sign in", signin_path %></li> 
        <% end %> 
       </ul> 
      </nav> 
     </div> 
    </div> 
</header> 

最后,这里是模型user.rb

class User < ActiveRecord::Base 
    attr_accessible :name, :email, :password, :password_confirmation 
    has_secure_password 

    before_save { |user| user.email = user.email.downcase } 
    before_save :create_remember_token 

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

    private 

    def create_remember_token 
     self.remember_token = SecureRandom.urlsafe_base64 
    end 
end 

这里是我的WEBrick服务器说:

Started DELETE "/signout" for 127.0.0.1 at 2012-06-19 10:58:53 -0400 
Processing by SessionsController#destroy as HTML 
    Parameters: {"authenticity_token"=>"qP1xAF4YXTaFmjeHxS5SgvUx+6+c6us5AL4jqgEBeqQ="} 
Redirected to http://localhost:3000/ 
Completed 302 Found in 1ms (ActiveRecord: 0.0ms) 


Started GET "/" for 127.0.0.1 at 2012-06-19 10:58:53 -0400 
Processing by StaticPagesController#home as HTML 
    Rendered static_pages/home.html.erb within layouts/application (0.6ms) 
    Rendered layouts/_shim.html.erb (0.1ms) 
    User Load (0.3ms) SELECT "users".* FROM "users" WHERE "users"."remember_token" IS NULL LIMIT 1 
    Rendered layouts/_header.html.erb (3.1ms) 
    Rendered layouts/_footer.html.erb (0.5ms) 
Completed 200 OK in 22ms (Views: 21.2ms | ActiveRecord: 0.3ms) 
[2012-06-19 10:58:53] WARN Could not determine content-length of response body. Set content-length of the response or set Response#chunked = true 


Started GET "/assets/application.css?body=1" for 127.0.0.1 at 2012-06-19 10:58:53 -0400 
Served asset /application.css - 304 Not Modified (11ms) 
[2012-06-19 10:58:53] WARN Could not determine content-length of response body. Set content-length of the response or set Response#chunked = true 

在情况下,一些问题在这里饼干是什么正在检查浏览器中的cookies时发生:

检查cookie: 1.我清除所有cookie 2.转到loca lhost:3000。我仍以用户2的身份登录。我检查cookie,并且没有本地主机的remember_token。我确实有一个名为“_sample_app_session”的cookie。 3.点击退出。没有任何反应,仍然登录。 4.输入/登录。以用户身份登录3 5.我现在在cookies中有一个remember_token。 6.点击退出。仍然显示我在顶级导航栏中签名。 7.我点击个人资料,看看,我登录的用户2(通过调试) 8.我检查饼干和记令牌消失了,我仍然有_sample_app_session

你有什么办法,我可以考什么可能会造成这种情况?我真的想解决这个问题,所以我可以继续教程。

+0

请单击sign_out发布您的路由sign_out和params散列。 – Anil

+0

这里是退出的路线:match'/ signout',to:'sessions#destroy',via::delete – coopcode

+0

我不确定当你点击登出时参数会被哈希值为何? – coopcode

回答

5

哦,我也有同样的问题。就连我也一样拉我的头发。然后,我的一个朋友注意到了代码并帮助我。 问题是,您错过了从RAILS CONSOLE添加记忆令牌。只要检查可选的黄瓜上面的部分。你会注意到从轨道控制台添加令牌的部分。

导轨控制台

User.first.remember_token

=>零

User.all.each {|用户|用户。保存(验证:假)}

User.first.remember_token

+1

男人,我花了超过两个小时来处理这个问题!非常感谢您的帮助 !! – CanCeylan

1

确保力推的Heroku之后到数据库迁移。我有一个类似的问题,它跑了后,我走了:

$ heroku run rake db:migrate 
相关问题