aboutsummaryrefslogblamecommitdiffstats
path: root/actionpack/test/controller/session_fixation_test.rb
blob: e8dc8bd295d7c2903a2842b74b99147c2e04c794 (plain) (tree)
1
2
3
4
5
6
7
8
9
10
                       
 
                                                             
                                               





                                                       




















                                                          





                                                                     
       


                                                




                                                                             
       


                                                                                         





                                                                 
       


                                                                         








                                                                            
       

     










                                                                             
   
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