1 # frozen_string_literal: true
5 class SessionsControllerTest < ActionDispatch::IntegrationTest
7 # test all routes which lead to this controller
10 { :path => "/login", :method => :get },
11 { :controller => "sessions", :action => "new" }
14 { :path => "/login", :method => :post },
15 { :controller => "sessions", :action => "create" }
18 { :controller => "sessions", :action => "new", :format => "html" },
19 { :path => "/login.html", :method => :get }
23 { :path => "/logout", :method => :get },
24 { :controller => "sessions", :action => "destroy" }
27 { :path => "/logout", :method => :post },
28 { :controller => "sessions", :action => "destroy" }
31 { :controller => "sessions", :action => "destroy", :format => "html" },
32 { :path => "/logout.html", :method => :get }
40 assert_redirected_to login_path(:cookie_test => true)
42 assert_response :success
43 assert_template "sessions/new"
45 get login_path, :params => { :username => user.display_name, :password => "s3cr3t" }
46 assert_response :success
47 assert_template "sessions/new"
49 post login_path, :params => { :username => user.display_name, :password => "s3cr3t" }
50 assert_redirected_to root_path
52 post login_path, :params => { :username => " #{user.display_name}", :password => "s3cr3t" }
53 assert_redirected_to root_path
55 post login_path, :params => { :username => "#{user.display_name} ", :password => "s3cr3t" }
56 assert_redirected_to root_path
59 def test_login_remembered
62 post login_path, :params => { :username => user.display_name, :password => "s3cr3t", :remember_me => "yes" }
63 assert_redirected_to root_path
65 assert_equal 28 * 86400, session[:_remember_for]
68 def test_login_not_remembered
71 post login_path, :params => { :username => user.display_name, :password => "s3cr3t", :remember_me => "0" }
72 assert_redirected_to root_path
74 assert_nil session[:_remember_for]
77 def test_login_pending_user
78 user = create(:user, :pending)
80 post login_path, :params => { :username => user.display_name, :password => "s3cr3t", :remember_me => "0" }
81 assert_redirected_to :controller => "confirmations", :action => "confirm", :display_name => user.display_name
84 def test_login_suspended_user
85 user = create(:user, :suspended)
87 post login_path, :params => { :username => user.display_name, :password => "s3cr3t", :remember_me => "0" }
88 assert_redirected_to login_path(:username => user.display_name, :remember_me => false)
89 assert_equal({ :partial => "sessions/suspended_flash" }, flash[:error])
92 def test_login_invalid_password
95 post login_path, :params => { :username => user.display_name, :password => "s2cr2t", :remember_me => "0" }
96 assert_redirected_to login_path(:username => user.display_name, :remember_me => false)
97 assert_equal(I18n.t("sessions.new.auth failure"), flash[:error])
100 def test_login_expired_password
101 user = create(:user, :pass_crypt => "expired password")
103 post login_path, :params => { :username => user.display_name, :password => "s3cr3t", :remember_me => "0" }
104 assert_redirected_to user_forgot_password_path
105 assert_equal(I18n.t("sessions.new.reset_to_login"), flash[:warning])
108 def test_logout_without_referer
110 assert_redirected_to root_path
113 def test_logout_with_referer
114 post logout_path, :params => { :referer => "/test" }
115 assert_redirected_to "/test"
118 def test_logout_fallback_without_referer
120 assert_response :success
121 assert_template "sessions/destroy"
122 assert_select "input[name=referer]:not([value])"
125 def test_logout_fallback_with_referer
126 get logout_path, :params => { :referer => "/test" }
127 assert_response :success
128 assert_template "sessions/destroy"
129 assert_select "input[name=referer][value=?]", "/test"