3

Rails チュートリアルに従おうとしていますが、失敗した rspec がありますが、ブラウザーではアプリが必要に応じて機能します。それは、(ブラウザーで) サインインして、「http://localhost:3000/users/1/edit」にアクセスすると、このページが開きます。チュートリアルの以前のすべての rspec が渡されます。

Rails '3.1.0.rc4' を使用しており、Windows で作業しています。

失敗する仕様 (users_controller_spec.rb から):

describe "GET 'edit" do
    before(:each) do
      @user = Factory(:user)
      test_sign_in(@user)
    end

    it "should be successful" do
      get :edit, :id => @user
      response.should be_success
    end
end

spec_helper.rb からの test_sign_in のコード:

RSpec.configure do |config|  
  config.mock_with :rspec

  config.fixture_path = "#{::Rails.root}/spec/fixtures"

  config.use_transactional_fixtures = true

  def test_sign_in(user)
    controller.sign_in(user)
  end
end

factory.rbのコード

Factory.define :user do |user|
  user.name "Mikhail"
  user.email "mikleb@yandex.ru"
  user.password "123456789a"
  user.password_confirmation "123456789a"
end

コンソールからのテキスト:

Failures:

  1) UsersController GET 'edit should be successful
     Failure/Error: response.should be_success
       expected success? to return true, got false
     # ./spec/controllers/users_controller_spec.rb:111:in `block (3 levels) in <
top (required)>'

UPD:「get :edit, :id => @user」の後、ユーザーはサインインしていません。しかし、ブラウザーで書いたように、すべてが必要に応じて機能します。そんなことがあるものか?

ApplicationControlelr に含まれている SessionHelper は次のとおりです。

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

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

  def signed_in?
    !current_user.nil?
  end

  def current_user=(user)
    @curent_user = user
  end

  def current_user
    @current_user ||= user_from_remember_token
  end

  def deny_access
    redirect_to signin_path, :notice => "Please sign in to access this page."
  end

  private
    def user_from_remember_token
      User.authenticate_with_salt(*remember_token)
    end

    def remember_token
      cookies.signed[:remember_token] || [nil, nil]
    end
end
4

1 に答える 1

2

response.bodyRspecが見ていると思うものを見るためにダンプしましたか?この質問でrender_views説明されているように、有効にする必要がある場合があります(これがまだ必要かどうかは忘れます)。

ユーザーが実際にログインしていないために、サイトが編集からサインインページなどにリダイレクトされている可能性はありますか?

もう1つの注意点として、rspecがtrueを返すのはbe_success、HTTPコードが2xxコード(200 ok、201が作成されたなど)の場合のみであると確信しています。したがって、コントローラーがリダイレクトしている場合(302、304など)、rspecは要求が「成功した」とは見なしません。

アサーションの前に立ち寄ってみてputs response.bodyください。問題を絞り込むのに役立つ場合があります。

于 2011-07-20T21:20:54.790 に答える