From: Andy Allan Date: Wed, 24 Mar 2021 11:40:17 +0000 (+0000) Subject: Move sessions-related tests out of UsersControllerTest X-Git-Tag: live~2265^2 X-Git-Url: https://git.openstreetmap.org./rails.git/commitdiff_plain/9fd96cfb8774805868ffb54e4c0a8b74b8607f10 Move sessions-related tests out of UsersControllerTest --- diff --git a/test/controllers/sessions_controller_test.rb b/test/controllers/sessions_controller_test.rb new file mode 100644 index 000000000..a94a9a158 --- /dev/null +++ b/test/controllers/sessions_controller_test.rb @@ -0,0 +1,90 @@ +require "test_helper" + +class SessionsControllerTest < ActionDispatch::IntegrationTest + ## + # test all routes which lead to this controller + def test_routes + assert_routing( + { :path => "/login", :method => :get }, + { :controller => "sessions", :action => "new" } + ) + assert_routing( + { :path => "/login", :method => :post }, + { :controller => "sessions", :action => "create" } + ) + assert_recognizes( + { :controller => "sessions", :action => "new", :format => "html" }, + { :path => "/login.html", :method => :get } + ) + + assert_routing( + { :path => "/logout", :method => :get }, + { :controller => "sessions", :action => "destroy" } + ) + assert_routing( + { :path => "/logout", :method => :post }, + { :controller => "sessions", :action => "destroy" } + ) + assert_recognizes( + { :controller => "sessions", :action => "destroy", :format => "html" }, + { :path => "/logout.html", :method => :get } + ) + end + + def test_login + user = create(:user) + + get login_path + assert_response :redirect + assert_redirected_to login_path(:cookie_test => true) + follow_redirect! + assert_response :success + assert_template "sessions/new" + + get login_path, :params => { :username => user.display_name, :password => "test" } + assert_response :success + assert_template "sessions/new" + + post login_path, :params => { :username => user.display_name, :password => "test" } + assert_response :redirect + assert_redirected_to root_path + end + + def test_logout_without_referer + post logout_path + assert_response :redirect + assert_redirected_to root_path + end + + def test_logout_with_referer + post logout_path, :params => { :referer => "/test" } + assert_response :redirect + assert_redirected_to "/test" + end + + def test_logout_fallback_without_referer + get logout_path + assert_response :success + assert_template "sessions/destroy" + assert_select "input[name=referer]:not([value])" + end + + def test_logout_fallback_with_referer + get logout_path, :params => { :referer => "/test" } + assert_response :success + assert_template "sessions/destroy" + assert_select "input[name=referer][value=?]", "/test" + end + + def test_logout_removes_session_token + user = build(:user, :pending) + post user_new_path, :params => { :user => user.attributes } + post user_save_path, :params => { :read_ct => 1, :read_tou => 1 } + + assert_difference "User.find_by(:email => user.email).tokens.count", -1 do + post logout_path + end + assert_response :redirect + assert_redirected_to root_path + end +end diff --git a/test/controllers/users_controller_test.rb b/test/controllers/users_controller_test.rb index 7d8f569f0..6cefcaa93 100644 --- a/test/controllers/users_controller_test.rb +++ b/test/controllers/users_controller_test.rb @@ -4,32 +4,6 @@ class UsersControllerTest < ActionDispatch::IntegrationTest ## # test all routes which lead to this controller def test_routes - assert_routing( - { :path => "/login", :method => :get }, - { :controller => "sessions", :action => "new" } - ) - assert_routing( - { :path => "/login", :method => :post }, - { :controller => "sessions", :action => "create" } - ) - assert_recognizes( - { :controller => "sessions", :action => "new", :format => "html" }, - { :path => "/login.html", :method => :get } - ) - - assert_routing( - { :path => "/logout", :method => :get }, - { :controller => "sessions", :action => "destroy" } - ) - assert_routing( - { :path => "/logout", :method => :post }, - { :controller => "sessions", :action => "destroy" } - ) - assert_recognizes( - { :controller => "sessions", :action => "destroy", :format => "html" }, - { :path => "/logout.html", :method => :get } - ) - assert_routing( { :path => "/user/new", :method => :get }, { :controller => "users", :action => "new" } @@ -406,63 +380,6 @@ class UsersControllerTest < ActionDispatch::IntegrationTest ActionMailer::Base.deliveries.clear end - def test_login - user = create(:user) - - get login_path - assert_response :redirect - assert_redirected_to login_path(:cookie_test => true) - follow_redirect! - assert_response :success - assert_template "sessions/new" - - get login_path, :params => { :username => user.display_name, :password => "test" } - assert_response :success - assert_template "sessions/new" - - post login_path, :params => { :username => user.display_name, :password => "test" } - assert_response :redirect - assert_redirected_to root_path - end - - def test_logout_without_referer - post logout_path - assert_response :redirect - assert_redirected_to root_path - end - - def test_logout_with_referer - post logout_path, :params => { :referer => "/test" } - assert_response :redirect - assert_redirected_to "/test" - end - - def test_logout_fallback_without_referer - get logout_path - assert_response :success - assert_template "sessions/destroy" - assert_select "input[name=referer]:not([value])" - end - - def test_logout_fallback_with_referer - get logout_path, :params => { :referer => "/test" } - assert_response :success - assert_template "sessions/destroy" - assert_select "input[name=referer][value=?]", "/test" - end - - def test_logout_removes_session_token - user = build(:user, :pending) - post user_new_path, :params => { :user => user.attributes } - post user_save_path, :params => { :read_ct => 1, :read_tou => 1 } - - assert_difference "User.find_by(:email => user.email).tokens.count", -1 do - post logout_path - end - assert_response :redirect - assert_redirected_to root_path - end - def test_confirm_get user = build(:user, :pending) post user_new_path, :params => { :user => user.attributes }