0

私はハートルのチュートリアルに取り組んでいます。現在チャプター9。テストを実行すると、次のエラーが表示されます。

c:\rails_project\sample_app>bundle exec rspec spec/

Failures:

1) Authentication authorization for non-signed-in users when attempting to visit a
protected page after signing in should render the desired protected page
Failure/Error: visit edit_user_path(user)NameError:undefined local variable or
method `requests' for #<UsersController:0x37cff38>
# ./app/helpers/sessions_helper.rb:36:in `store_location'
# ./app/controllers/users_controller.rb:44:in `signed_in_user'
# ./spec/requests/authentication_pages_spec.rb:57:in `block (5 levels)
in <top (required)>'

2) Authentication authorization in the Users controller visiting the edit page
Failure/Error: before { visit edit_user_path(user) }
NameError:undefined local variable or method `requests' for 
#<UsersController:0x439d430>
# ./app/helpers/sessions_helper.rb:36:in `store_location'
# ./app/controllers/users_controller.rb:44:in `signed_in_user'
# ./spec/requests/authentication_pages_spec.rb:75:in `block (5 levels)
in <top (required)>'

3) Authentication authorization in the Users controller Submitting to the update
action Failure/Error: before { put user_path(user) } NameError: undefined local
variable or method `requests' for #<UsersController: 0x44f78d0>
# ./app/helpers/sessions_helper.rb:36:in `store_location'
# ./app/controllers/users_controller.rb:44:in `signed_in_user'
# ./spec/requests/authentication_pages_spec.rb:80:in `block (5 levels)
in <top (required)>'

Finished in 9.33 seconds
70 examples, 3 failures, 3 pending

私の Authentication_pages_spec.rb ファイル:

require 'spec_helper'

describe "Authentication" 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 have_selector('div.alert.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('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 "when attempting to visit a protected page" do
      before do
        visit edit_user_path(user)
        fill_in "Email",    with: user.email
        fill_in "Password", with: user.password
        click_button "Sign in"
      end

      describe "after signing in" do

        it "should render the desired protected page" do
          page.should have_selector('title', text: 'Edit user')
        end
      end
    end
  end

  describe "in the Users controller" do

    describe "visiting the edit page" do
      before { visit edit_user_path(user) }
      it { should have_selector('title', text: "Sign in") }
    end

    describe "Submitting to the update action" do
      before { put user_path(user) }
      specify { response.should redirect_to(signin_path) }
    end
  end


  describe "as wrong user" do
    let(:user) { FactoryGirl.create(:user) }
    let(:wrong_user) { FactoryGirl.create(:user, email: "wrong@example.com") }
    before { sign_in user }

    describe "visiting User#edit page" do
      before { visit edit_user_path(wrong_user) }
      it { should_not have_selector('title', text: full_title('Edit user')) }
    end

    describe "submitting a PUT request to the User#update action" do
      before { put user_path(wrong_user) }
      specify { response.should redirect_to(root_path) } 
    end
  end    
 end
end

この問題は、 Michael Hartl の Ruby on Rails チュートリアルに示されているものと似ていることがわかりました。第9章でテストに失敗しまし たが、この解決策は私の場合には機能しません。誰でも思いついた?

4

2 に答える 2

2

たぶん、ボイドのショットだけかもしれませんが、SessionsHelper.store_locationにタイプミスがあります。'requests'を'request'に変更します。

于 2012-10-06T18:32:08.573 に答える
0

あなたのsessions_helper.rbファイルにはタイプミスがあります: requestsの代わりにrequest.

参照: http://guides.rubyonrails.org/action_controller_overview.html#the-request-and-response-objects

于 2012-10-06T19:53:01.960 に答える