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_logout_without_referer
 
  79     assert_redirected_to root_path
 
  82   def test_logout_with_referer
 
  83     post logout_path, :params => { :referer => "/test" }
 
  84     assert_redirected_to "/test"
 
  87   def test_logout_fallback_without_referer
 
  89     assert_response :success
 
  90     assert_template "sessions/destroy"
 
  91     assert_select "input[name=referer]:not([value])"
 
  94   def test_logout_fallback_with_referer
 
  95     get logout_path, :params => { :referer => "/test" }
 
  96     assert_response :success
 
  97     assert_template "sessions/destroy"
 
  98     assert_select "input[name=referer][value=?]", "/test"