我试图遵循Rails教程,我有一个失败的rspec,但在浏览器应用程序的工作需要。这是当我登录(在浏览器中),去"http://localhost:3000/users/1/edit"这个页面打开。
我使用的是Rails 3.1.0。
规格失败(从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
testrongign_in from spec_helper.rb的代码:
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
code of factories.rb
Factory.define :user do |user|
user.name "Mikhail"
user.email "mikleb@yandex.ru"
user.password "123456789a"
user.password_confirmation "123456789a"
end
text from console:
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
你是否抛弃了response.body
来看看Rspec认为它看到了什么?您可能(我忘记了这是否仍然是必要的)需要启用本问题中描述的render_views
。
是否有可能用户没有真正登录,因此网站从编辑重定向到登录页面或类似的东西?
另一个警告,我很确定rspec只有在HTTP代码是2xx代码(200 ok, 201创建等)时才会为be_success
返回true。因此,如果您的控制器正在重定向(302、304等),那么rspec将不会认为请求"成功"。
尝试在断言之前放入puts response.body
,它可以帮助您缩小问题范围。