I’m new to RSpec, and trying to write a simple test that shows Devise is working. I’ve picked a random page and want to write a test that shows that a non logged-in user is re-redirected to /users/sign_in.
describe OrgsController do
describe "GET index when not logged in" do
it "redirects to new_user_session_path" do
user = FactoryGirl.create(:user)
user.confirm!
sign_in user
sign_out user
get :index
response.should redirect_to new_user_session_path
end
end
before(:each) do
user = FactoryGirl.create(:user)
user.confirm!
sign_in user
end
# remaining specs
end
I get "Expected response to be a redirect to <http://test.host/users/sign_in?locale=en> but was a redirect to <http://test.host/users/sign_in>."
I have implemented i18n, and have in my Application Controller:
before_filter :set_i18n_locale_from_params
What is the best way to get this working in terms of:
- Getting the routes to match?
- The hackishness of signing a user in and out again to get round the effects of the before(:each) block?
- The overall approach?
The problem of getting controller tests/specs to properly set the locale is a longstanding one, see: How to set locale default_url_options for functional tests (Rails)
From what you’ve written, it looks like
get :indexis not setting the locale by default, becausedefault_url_optionswill not work from controller tests/specs. Try one of the solutions mentioned in the link above to get the routes to match. See also this discussion on github: https://github.com/rspec/rspec-rails/issues/255For what it’s worth, this is the patch I currently use in specs/tests to get the locale to be automatically passed to routes from the current locale:
Regarding the hackishness of the
before(:each)block setup you have, I’d really suggest separating the cases using context blocks, with one context without the before filter logging the user in, and another with the before block logging the user in. The setup you have right now is really confusing for someone trying to see what’s going on.