Ошибка при входе в систему с помощью Machinist в тесте Shoulda

У меня возникли проблемы с правильным использованием Machinist и Shoulda в моем тестировании.

Вот мой тест:

 context "on POST method rating" do
p = Product.make
u = nil
setup do
  u = login_as
  post :vote, :rating => 3, :id => p
end

should "set rating for product to 3" do
  assert_equal p.get_user_vote(u), 3
end

А вот и мои чертежи:

 Sham.login { Faker::Internet.user_name }
Sham.name { Faker::Lorem.words}
Sham.email { Faker::Internet.email}
Sham.body { Faker::Lorem.paragraphs(2)}

User.blueprint do
 login
 password "testpass"
 password_confirmation { password }
 email
end

Product.blueprint do
 name {Sham.name}
 user {User.make}
end

И мой помощник по проверке подлинности:

def login_as(u = nil)
   u ||= User.make()
   @controller.stubs(:current_user).returns(u)
   u
 end

Ошибка, которую я получаю:

/home/jason/moderndarwin/vendor/rails/activerecord/lib/active_record/validations.rb:1090:in `save_without_dirty!': Validation failed: Login has already been taken, Email has already been taken (ActiveRecord::RecordInvalid)                                                         
       from /home/jason/moderndarwin/vendor/rails/activerecord/lib/active_record/dirty.rb:87:in `save_without_transactions!'                                                             
       from /home/jason/moderndarwin/vendor/rails/activerecord/lib/active_record/transactions.rb:200:in `save!'                                                                          
       from /home/jason/moderndarwin/vendor/rails/activerecord/lib/active_record/connection_adapters/abstract/database_statements.rb:136:in `transaction'                                
       from /home/jason/moderndarwin/vendor/rails/activerecord/lib/active_record/transactions.rb:182:in `transaction'                                                                    
       from /home/jason/moderndarwin/vendor/rails/activerecord/lib/active_record/transactions.rb:200:in `save!'                                                                          
       from /home/jason/moderndarwin/vendor/rails/activerecord/lib/active_record/transactions.rb:208:in `rollback_active_record_state!'
       from /home/jason/moderndarwin/vendor/rails/activerecord/lib/active_record/transactions.rb:200:in `save!'
       from /usr/lib/ruby/gems/1.8/gems/machinist-1.0.6/lib/machinist/active_record.rb:55:in `make'
       from /home/jason/moderndarwin/test/blueprints.rb:37
       from /usr/lib/ruby/gems/1.8/gems/machinist-1.0.6/lib/machinist.rb:77:in `generate_attribute_value'
       from /usr/lib/ruby/gems/1.8/gems/machinist-1.0.6/lib/machinist.rb:46:in `method_missing'
       from /home/jason/moderndarwin/test/blueprints.rb:37
       from /usr/lib/ruby/gems/1.8/gems/machinist-1.0.6/lib/machinist.rb:20:in `instance_eval'
       from /usr/lib/ruby/gems/1.8/gems/machinist-1.0.6/lib/machinist.rb:20:in `run'
       from /usr/lib/ruby/gems/1.8/gems/machinist-1.0.6/lib/machinist/active_record.rb:53:in `make'
       from ./test/functional/products_controller_test.rb:25:in `__bind_1269805681_945912'
       from /home/jason/moderndarwin/vendor/gems/thoughtbot-shoulda-2.10.2/lib/shoulda/context.rb:293:in `call'
       from /home/jason/moderndarwin/vendor/gems/thoughtbot-shoulda-2.10.2/lib/shoulda/context.rb:293:in `merge_block'
       from /home/jason/moderndarwin/vendor/gems/thoughtbot-shoulda-2.10.2/lib/shoulda/context.rb:288:in `initialize'
       from /home/jason/moderndarwin/vendor/gems/thoughtbot-shoulda-2.10.2/lib/shoulda/context.rb:169:in `new'
       from /home/jason/moderndarwin/vendor/gems/thoughtbot-shoulda-2.10.2/lib/shoulda/context.rb:169:in `context'
       from ./test/functional/products_controller_test.rb:24

Я не могу понять, что я делаю неправильно... Я проверил login_as с моей аутентификацией (Authlogic) в моем тестировании user_controller.

Любые указатели в правильном направлении будут высоко оценены!


person user303747    schedule 28.03.2010    source источник


Ответы (2)


У меня есть частичное решение... Я решил проблему, описанную выше, но функция should_redirect_to все еще меня устраивает...

Это мой новый тестовый код:

context "on POST method rating" do

   setup do
     @u = login_as
     @p1 = Product.make
     @p2 = Product.make # Make a second product that we'll show after rating the first
     post :vote, :rating => 3, :id => @p1
   end

   should "set rating for product to 3" do
     assert_equal @p1.get_user_vote(@u), 3
   end

   should_redirect_to("product page") {show_product_url(:id => @p2)}    
 end

И моя новая ошибка:

response to be a redirect to <http://test.host/products/555660218> but was a redirect to <http://test.host/products>.

Любые идеи, куда идти отсюда?

person user303747    schedule 28.03.2010

Ваш контроллер перенаправляется на products_url?

Примечание: вы не должны использовать случайные данные (Faker) для любой проверки, требующей уникальности. Вот для чего нужны эпизоды Factory Girl. Я предполагаю, что у Machinist есть что-то подобное.

person Dan Croak    schedule 29.03.2010
comment
Вот что делает мой контроллер: def voice Vote.do_vote # выполнить некоторую логику голосования redirect_to :action =› 'show', :id =› current_user.next_product(session[:tags]) end - person user303747; 08.04.2010
comment
Чего я не понимаю, так это того, что код работает правильно, когда я тестирую в браузере, но не при использовании набора тестов. Я также попытался переписать перенаправление контроллера, чтобы оно соответствовало моему тесту: def voice redirect_to show_product_url(current_user.next_product(session[:tags])) end - person user303747; 08.04.2010
comment
Кроме того, я попытался использовать mock, чтобы устранить некоторые неизвестные: контекст оценки метода POST do setup do @u = login_as @p1 = Product.make @p2 = Product.make # Создайте второй продукт, который мы покажем после оценки первого сообщения: голосование, :rating =› 3, :id =› @p1 @u.expects(:next_product).returns(@p2) end should_redirect_to(страница продукта) {show_product_url(:id =› @p2)} end Все та же ошибка . - person user303747; 08.04.2010