aboutsummaryrefslogtreecommitdiffstats
path: root/actionpack/test/controller/session_fixation_test.rb
blob: 9e5b45dc3de33c1a2d37c52fd1a13914f500d694 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
# require 'abstract_unit'
# 
# class SessionFixationTest < ActionController::IntegrationTest
#   class TestController < ActionController::Base
#     session :session_key => '_myapp_session_id',
#             :secret => CGI::Session.generate_unique_id,
#             :except => :default_session_key
# 
#     session :cookie_only => false,
#             :only => :allow_session_fixation
# 
#     def default_session_key
#       render :text => "default_session_key"
#     end
# 
#     def custom_session_key
#       render :text => "custom_session_key: #{params[:id]}"
#     end
# 
#     def allow_session_fixation
#       render :text => "allow_session_fixation"
#     end
# 
#     def rescue_action(e) raise end
#   end
# 
#   def setup
#     @controller = TestController.new
#   end
# 
#   def test_should_be_able_to_make_a_successful_request
#     with_test_route_set do
#       assert_nothing_raised do
#         get '/custom_session_key', :id => "1"
#       end
#       assert_equal 'custom_session_key: 1', @controller.response.body
#       assert_not_nil @controller.session
#     end
#   end
# 
#   def test_should_catch_session_fixation_attempt
#     with_test_route_set do
#       assert_raises(ActionController::RackRequest::SessionFixationAttempt) do
#         get '/custom_session_key', :_myapp_session_id => "42"
#       end
#       assert_nil @controller.session
#     end
#   end
# 
#   def test_should_not_catch_session_fixation_attempt_when_cookie_only_setting_is_disabled
#     with_test_route_set do
#       assert_nothing_raised do
#         get '/allow_session_fixation', :_myapp_session_id => "42"
#       end
#       assert !@controller.response.body.blank?
#       assert_not_nil @controller.session
#     end
#   end
# 
#   def test_should_catch_session_fixation_attempt_with_default_session_key
#     # using the default session_key is not possible with cookie store
#     ActionController::Base.session_store = :p_store
# 
#     with_test_route_set do
#       assert_raises ActionController::RackRequest::SessionFixationAttempt do
#         get '/default_session_key', :_session_id => "42"
#       end
#       assert_nil @controller.response
#       assert_nil @controller.session
#     end
#   end
# 
#   private
#     def with_test_route_set
#       with_routing do |set|
#         set.draw do |map|
#           map.with_options :controller => "session_fixation_test/test" do |c|
#             c.connect "/:action"
#           end
#         end
#         yield
#       end
#     end
# end