disabled_rest_api_test.rb
78 lines
| 2.5 KiB
| text/x-ruby
|
RubyLexer
|
r11024 | # Redmine - project management software | ||
# Copyright (C) 2006-2013 Jean-Philippe Lang | ||||
# | ||||
# This program is free software; you can redistribute it and/or | ||||
# modify it under the terms of the GNU General Public License | ||||
# as published by the Free Software Foundation; either version 2 | ||||
# of the License, or (at your option) any later version. | ||||
# | ||||
# This program is distributed in the hope that it will be useful, | ||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||||
# GNU General Public License for more details. | ||||
# | ||||
# You should have received a copy of the GNU General Public License | ||||
# along with this program; if not, write to the Free Software | ||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | ||||
|
r4395 | require File.expand_path('../../../test_helper', __FILE__) | ||
|
r3106 | |||
|
r11023 | class Redmine::ApiTest::DisabledRestApiTest < Redmine::ApiTest::Base | ||
|
r7395 | fixtures :projects, :trackers, :issue_statuses, :issues, | ||
:enumerations, :users, :issue_categories, | ||||
:projects_trackers, | ||||
:roles, | ||||
:member_roles, | ||||
:members, | ||||
|
r11122 | :enabled_modules | ||
|
r3106 | |||
def setup | ||||
Setting.rest_api_enabled = '0' | ||||
Setting.login_required = '1' | ||||
end | ||||
def teardown | ||||
Setting.rest_api_enabled = '1' | ||||
Setting.login_required = '0' | ||||
end | ||||
|
r6549 | |||
|
r8358 | def test_with_a_valid_api_token | ||
|
r9337 | @user = User.generate! | ||
|
r8959 | @token = Token.create!(:user => @user, :action => 'api') | ||
|
r3106 | |||
|
r8358 | get "/news.xml?key=#{@token.value}" | ||
assert_response :unauthorized | ||||
assert_equal User.anonymous, User.current | ||||
|
r6549 | |||
|
r8358 | get "/news.json?key=#{@token.value}" | ||
assert_response :unauthorized | ||||
assert_equal User.anonymous, User.current | ||||
end | ||||
|
r6549 | |||
|
r8358 | def test_with_valid_username_password_http_authentication | ||
|
r9337 | @user = User.generate! do |user| | ||
user.password = 'my_password' | ||||
end | ||||
|
r3106 | |||
|
r8358 | get "/news.xml", nil, credentials(@user.login, 'my_password') | ||
assert_response :unauthorized | ||||
assert_equal User.anonymous, User.current | ||||
|
r6549 | |||
|
r8358 | get "/news.json", nil, credentials(@user.login, 'my_password') | ||
assert_response :unauthorized | ||||
assert_equal User.anonymous, User.current | ||||
end | ||||
|
r3106 | |||
|
r8358 | def test_with_valid_token_http_authentication | ||
|
r9337 | @user = User.generate! | ||
|
r8959 | @token = Token.create!(:user => @user, :action => 'api') | ||
|
r3106 | |||
|
r8358 | get "/news.xml", nil, credentials(@token.value, 'X') | ||
assert_response :unauthorized | ||||
assert_equal User.anonymous, User.current | ||||
|
r6549 | |||
|
r8358 | get "/news.json", nil, credentials(@token.value, 'X') | ||
assert_response :unauthorized | ||||
assert_equal User.anonymous, User.current | ||||
|
r3106 | end | ||
end | ||||