mirror of
				https://github.com/redmine/redmine.git
				synced 2025-11-03 20:06:24 +01:00 
			
		
		
		
	git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@3220 e93f8b46-1217-0410-a6f0-8f06a7374b81
		
			
				
	
	
		
			111 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			111 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
require "#{File.dirname(__FILE__)}/../test_helper"
 | 
						|
 | 
						|
class DisabledRestApi < ActionController::IntegrationTest
 | 
						|
  fixtures :all
 | 
						|
 | 
						|
  def setup
 | 
						|
    Setting.rest_api_enabled = '0'
 | 
						|
    Setting.login_required = '1'
 | 
						|
  end
 | 
						|
 | 
						|
  def teardown
 | 
						|
    Setting.rest_api_enabled = '1'
 | 
						|
    Setting.login_required = '0'
 | 
						|
  end
 | 
						|
  
 | 
						|
  # Using the NewsController because it's a simple API.
 | 
						|
  context "get /news with the API disabled" do
 | 
						|
 | 
						|
    context "in :xml format" do
 | 
						|
      context "with a valid api token" do
 | 
						|
        setup do
 | 
						|
          @user = User.generate_with_protected!
 | 
						|
          @token = Token.generate!(:user => @user, :action => 'api')
 | 
						|
          get "/news.xml?key=#{@token.value}"
 | 
						|
        end
 | 
						|
        
 | 
						|
        should_respond_with :unauthorized
 | 
						|
        should_respond_with_content_type :xml
 | 
						|
        should "not login as the user" do
 | 
						|
          assert_equal User.anonymous, User.current
 | 
						|
        end
 | 
						|
      end
 | 
						|
 | 
						|
      context "with a valid HTTP authentication" do
 | 
						|
        setup do
 | 
						|
          @user = User.generate_with_protected!(:password => 'my_password', :password_confirmation => 'my_password')
 | 
						|
          @authorization = ActionController::HttpAuthentication::Basic.encode_credentials(@user.login, 'my_password')
 | 
						|
          get "/news.xml", nil, :authorization => @authorization
 | 
						|
        end
 | 
						|
        
 | 
						|
        should_respond_with :unauthorized
 | 
						|
        should_respond_with_content_type :xml
 | 
						|
        should "not login as the user" do
 | 
						|
          assert_equal User.anonymous, User.current
 | 
						|
        end
 | 
						|
      end
 | 
						|
 | 
						|
      context "with a valid HTTP authentication using the API token" do
 | 
						|
        setup do
 | 
						|
          @user = User.generate_with_protected!
 | 
						|
          @token = Token.generate!(:user => @user, :action => 'api')
 | 
						|
          @authorization = ActionController::HttpAuthentication::Basic.encode_credentials(@token.value, 'X')
 | 
						|
          get "/news.xml", nil, :authorization => @authorization
 | 
						|
        end
 | 
						|
        
 | 
						|
        should_respond_with :unauthorized
 | 
						|
        should_respond_with_content_type :xml
 | 
						|
        should "not login as the user" do
 | 
						|
          assert_equal User.anonymous, User.current
 | 
						|
        end
 | 
						|
      end
 | 
						|
    end
 | 
						|
 | 
						|
    context "in :json format" do
 | 
						|
      context "with a valid api token" do
 | 
						|
        setup do
 | 
						|
          @user = User.generate_with_protected!
 | 
						|
          @token = Token.generate!(:user => @user, :action => 'api')
 | 
						|
          get "/news.json?key=#{@token.value}"
 | 
						|
        end
 | 
						|
        
 | 
						|
        should_respond_with :unauthorized
 | 
						|
        should_respond_with_content_type :json
 | 
						|
        should "not login as the user" do
 | 
						|
          assert_equal User.anonymous, User.current
 | 
						|
        end
 | 
						|
      end
 | 
						|
 | 
						|
      context "with a valid HTTP authentication" do
 | 
						|
        setup do
 | 
						|
          @user = User.generate_with_protected!(:password => 'my_password', :password_confirmation => 'my_password')
 | 
						|
          @authorization = ActionController::HttpAuthentication::Basic.encode_credentials(@user.login, 'my_password')
 | 
						|
          get "/news.json", nil, :authorization => @authorization
 | 
						|
        end
 | 
						|
        
 | 
						|
        should_respond_with :unauthorized
 | 
						|
        should_respond_with_content_type :json
 | 
						|
        should "not login as the user" do
 | 
						|
          assert_equal User.anonymous, User.current
 | 
						|
        end
 | 
						|
      end
 | 
						|
 | 
						|
      context "with a valid HTTP authentication using the API token" do
 | 
						|
        setup do
 | 
						|
          @user = User.generate_with_protected!
 | 
						|
          @token = Token.generate!(:user => @user, :action => 'api')
 | 
						|
          @authorization = ActionController::HttpAuthentication::Basic.encode_credentials(@token.value, 'DoesNotMatter')
 | 
						|
          get "/news.json", nil, :authorization => @authorization
 | 
						|
        end
 | 
						|
 | 
						|
        should_respond_with :unauthorized
 | 
						|
        should_respond_with_content_type :json
 | 
						|
        should "not login as the user" do
 | 
						|
          assert_equal User.anonymous, User.current
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
    end    
 | 
						|
  end
 | 
						|
end
 |