Сбой rspec Rails Tutorial Глава 9.3

Я провалил 3 теста, и я нашел множество примеров здесь и в Интернете в целом, но я не могу найти, где я ошибаюсь. Спасибо за любую помощь.

1) User pages signup with valid information edit page 
 Failure/Error: before { visit edit_user_path(user) }
 ActionView::Template::Error:
   undefined method `model_name' for NilClass:Class
 # ./app/views/users/edit.html.erb:6:in  `_app_views_users_edit_html_erb___4113112884365867193_70232486166220'
 # ./spec/requests/user_pages_spec.rb:96:in `block (5 levels) in <top (required)>'

2) User pages signup with valid information edit page 
 Failure/Error: before { visit edit_user_path(user) }
 ActionView::Template::Error:
   undefined method `model_name' for NilClass:Class
 # ./app/views/users/edit.html.erb:6:in `_app_views_users_edit_html_erb___4113112884365867193_70232486166220'
 # ./spec/requests/user_pages_spec.rb:96:in `block (5 levels) in <top (required)>'

3) User pages signup with valid information edit page 
 Failure/Error: before { visit edit_user_path(user) }
 ActionView::Template::Error:
   undefined method `model_name' for NilClass:Class
 # ./app/views/users/edit.html.erb:6:in `_app_views_users_edit_html_erb___4113112884365867193_70232486166220'
 # ./spec/requests/user_pages_spec.rb:96:in `block (5 levels) in <top (required)>'

Finished in 0.26515 seconds
3 examples, 3 failures

Failed examples:

rspec ./spec/requests/user_pages_spec.rb:100 # User pages signup with valid information edit page 
rspec ./spec/requests/user_pages_spec.rb:99 # User pages signup with valid information edit page 
rspec ./spec/requests/user_pages_spec.rb:101 # User pages signup with valid information edit page 

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_not 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('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  

Вот user_controller:

    class UsersController < ApplicationController

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

 def new
    @user = User.new
 end

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

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

редактировать.html.erb:

  <% provide(:title, "Edit user") %> 
  <h1>Update your profile</h1>

<div class="row">
 <div class="span6 offset3">
  <%= form_for(@user) do |f| %>
  <%= render 'shared/error_messages' %>

  <%= f.label :name %>
  <%= f.text_field :name %>

  <%= f.label :email %>
  <%= f.text_field :email %>

  <%= f.label :password %>
  <%= f.password_field :password %>

  <%= f.label :password_confirmation, "Confirm Password" %>
  <%= f.password_field :password_confirmation %>

   <%= f.submit "Save changes", class: "btn btn-large btn-primary" %>
  <% end %>

    <%= gravatar_for @user %>
  <a href="http://gravatar.com/emails">change</a>
 </div>

here is the user_pages_spec:

    require 'spec_helper'

describe "User pages" do

subject { page }

describe "profile page" do
let(:user) { FactoryGirl.create(:user) }
before { visit user_path(user) }

it { should have_selector('h1', text: user.name) }
it { should have_selector('title', text: user.name) }
end

describe "signup page" do
 before { visit signup_path }

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

describe "signup" do

before { visit signup_path }

describe "with invalid information" do
it "should not create a user" do
  expect { click_button "Create my account" }.not_to change(User, :count)
end

describe "error messages" do
  before { click_button "Create my account" }

  it { should have_selector('title', text: 'Sign up') }
  it { should have_content('error') }
 end
end

 describe "with valid information" do
  before do
    fill_in "Name", with: "Example User"
    fill_in "Email", with: "[email protected]"
    fill_in "Password", with: "foobar"
    fill_in "Confirmation", with: "foobar"
 end

 it "should create a user" do
  expect do
    click_button "Create my account"
  end.to change(User, :count).by(1)
 end

 describe "after saving the user" do
  before { click_button "Create my account" }
  let(:user) { User.find_by_email('[email protected]') }

  it { should have_selector('title', text: user.name) }
  it { should have_selector('div.alert.alert-success', text: 'Welcome') }
  it { should have_link('Sign out') }
 end
 end
end

 describe "signup page" do
 before { visit signup_path }

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

  describe "signup" do

before { visit signup_path }

let(:submit) { "Create my account" }

describe "with invalid information" do
it "should not create a user" do
  expect { click_button submit }.not_to change(User, :count)
 end
end

describe "with valid information" do
before do
  fill_in "Name", with: "Example User"
  fill_in "Email", with: "[email protected]"
  fill_in "Password", with: "foobar"
  fill_in "Confirmation", with: "foobar"
end

it "should create a user" do
  expect { click_button submit }.to change(User, :count).by(1)
end
describe "edit" do
  let(:user) { FactoryGirl.create(:user) }
  before { visit edit_user_path(user) }

  describe "page" do
    it { should have_selector('h1', text: "Update your profile") }
    it { should have_selector('title', text: "Edit user") }
    it { should have_link('change', href: 'http://gravatar.com/emails') }
  end

  describe "with invalid information" do
    before { click_button "Save changes" }

    it { should have_content('error') }
    end
     end
     end
   end
 end

изменить: файл users_controllers.rb был неправильно отформатирован. Это должно выглядеть так:

class UsersController < ApplicationController

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

def new
 @user = User.new
end

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

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

person jfoutch    schedule 08.12.2012    source источник


Ответы (3)


Эта ошибка появится только в том случае, если переменная @user не была установлена ​​в вашем edit действии, что означает, что она не будет доступна для вызова form_for в вашем представлении... но она установлена, и поэтому она должна быть доступна.

Вы уверены, что сохранили эти файлы?

person Ryan Bigg    schedule 08.12.2012
comment
Да я их даже еще раз сохранил, чтобы убедиться. - person jfoutch; 09.12.2012

В вашем user_pages_spec.rb у вас есть:

let(:user) { FactoryGirl.create(:user) }
before { visit edit_user_path(user) }

Я считаю, что для того, чтобы редактирование работало, вам нужно войти в систему следующим образом:

let(:user) { FactoryGirl.create(:user) }
before do
    sign_in user
    visit edit_user_path(user)
end

Возможно, я дополнительно отредактировал свой, но это то, что я вижу, просматривая свои журналы коммитов. Надеюсь это поможет.

person TeckniX    schedule 11.12.2012
comment
Спасибо за ответ, но в итоге я сам разобрался, если вы видите правку внизу моего поста. Я не смог ответить на свой вопрос и принять ответ, поэтому просто внес изменения. - person jfoutch; 12.12.2012

Я заканчивал класс UsersController перед действием редактирования, поэтому он его не видел. Смотрите мое редактирование внизу OP.

person jfoutch    schedule 13.12.2012