2012-06-12 23:33:09 +04:00
|
|
|
# Redmine - project management software
|
2014-02-08 11:58:49 +04:00
|
|
|
# Copyright (C) 2006-2014 Jean-Philippe Lang
|
2012-06-12 23:33:09 +04:00
|
|
|
#
|
|
|
|
# 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.
|
|
|
|
|
|
|
|
require File.expand_path('../test_case', __FILE__)
|
|
|
|
require 'tmpdir'
|
|
|
|
|
|
|
|
class RedminePmTest::RepositorySubversionTest < RedminePmTest::TestCase
|
2012-06-14 12:04:44 +04:00
|
|
|
fixtures :projects, :users, :members, :roles, :member_roles, :auth_sources
|
2012-06-12 23:33:09 +04:00
|
|
|
|
|
|
|
SVN_BIN = Redmine::Configuration['scm_subversion_command'] || "svn"
|
|
|
|
|
|
|
|
def test_anonymous_read_on_public_repo_with_permission_should_succeed
|
|
|
|
assert_success "ls", svn_url
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_anonymous_read_on_public_repo_without_permission_should_fail
|
|
|
|
Role.anonymous.remove_permission! :browse_repository
|
|
|
|
assert_failure "ls", svn_url
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_anonymous_read_on_private_repo_should_fail
|
|
|
|
Project.find(1).update_attribute :is_public, false
|
|
|
|
assert_failure "ls", svn_url
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_anonymous_commit_on_public_repo_should_fail
|
|
|
|
Role.anonymous.add_permission! :commit_access
|
|
|
|
assert_failure "mkdir --message Creating_a_directory", svn_url(random_filename)
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_anonymous_commit_on_private_repo_should_fail
|
|
|
|
Role.anonymous.add_permission! :commit_access
|
|
|
|
Project.find(1).update_attribute :is_public, false
|
|
|
|
assert_failure "mkdir --message Creating_a_directory", svn_url(random_filename)
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_non_member_read_on_public_repo_with_permission_should_succeed
|
|
|
|
Role.anonymous.remove_permission! :browse_repository
|
|
|
|
with_credentials "miscuser8", "foo" do
|
|
|
|
assert_success "ls", svn_url
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_non_member_read_on_public_repo_without_permission_should_fail
|
|
|
|
Role.anonymous.remove_permission! :browse_repository
|
|
|
|
Role.non_member.remove_permission! :browse_repository
|
|
|
|
with_credentials "miscuser8", "foo" do
|
|
|
|
assert_failure "ls", svn_url
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_non_member_read_on_private_repo_should_fail
|
|
|
|
Project.find(1).update_attribute :is_public, false
|
|
|
|
with_credentials "miscuser8", "foo" do
|
|
|
|
assert_failure "ls", svn_url
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_non_member_commit_on_public_repo_should_fail
|
|
|
|
Role.non_member.add_permission! :commit_access
|
|
|
|
assert_failure "mkdir --message Creating_a_directory", svn_url(random_filename)
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_non_member_commit_on_private_repo_should_fail
|
|
|
|
Role.non_member.add_permission! :commit_access
|
|
|
|
Project.find(1).update_attribute :is_public, false
|
|
|
|
assert_failure "mkdir --message Creating_a_directory", svn_url(random_filename)
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_member_read_on_public_repo_with_permission_should_succeed
|
|
|
|
Role.anonymous.remove_permission! :browse_repository
|
|
|
|
Role.non_member.remove_permission! :browse_repository
|
|
|
|
with_credentials "dlopper", "foo" do
|
|
|
|
assert_success "ls", svn_url
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_member_read_on_public_repo_without_permission_should_fail
|
|
|
|
Role.anonymous.remove_permission! :browse_repository
|
|
|
|
Role.non_member.remove_permission! :browse_repository
|
|
|
|
Role.find(2).remove_permission! :browse_repository
|
|
|
|
with_credentials "dlopper", "foo" do
|
|
|
|
assert_failure "ls", svn_url
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_member_read_on_private_repo_with_permission_should_succeed
|
|
|
|
Project.find(1).update_attribute :is_public, false
|
|
|
|
with_credentials "dlopper", "foo" do
|
|
|
|
assert_success "ls", svn_url
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_member_read_on_private_repo_without_permission_should_fail
|
|
|
|
Role.find(2).remove_permission! :browse_repository
|
|
|
|
Project.find(1).update_attribute :is_public, false
|
|
|
|
with_credentials "dlopper", "foo" do
|
|
|
|
assert_failure "ls", svn_url
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_member_commit_on_public_repo_with_permission_should_succeed
|
|
|
|
Role.find(2).add_permission! :commit_access
|
|
|
|
with_credentials "dlopper", "foo" do
|
|
|
|
assert_success "mkdir --message Creating_a_directory", svn_url(random_filename)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_member_commit_on_public_repo_without_permission_should_fail
|
|
|
|
Role.find(2).remove_permission! :commit_access
|
|
|
|
with_credentials "dlopper", "foo" do
|
|
|
|
assert_failure "mkdir --message Creating_a_directory", svn_url(random_filename)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_member_commit_on_private_repo_with_permission_should_succeed
|
|
|
|
Role.find(2).add_permission! :commit_access
|
|
|
|
Project.find(1).update_attribute :is_public, false
|
|
|
|
with_credentials "dlopper", "foo" do
|
|
|
|
assert_success "mkdir --message Creating_a_directory", svn_url(random_filename)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_member_commit_on_private_repo_without_permission_should_fail
|
|
|
|
Role.find(2).remove_permission! :commit_access
|
|
|
|
Project.find(1).update_attribute :is_public, false
|
|
|
|
with_credentials "dlopper", "foo" do
|
|
|
|
assert_failure "mkdir --message Creating_a_directory", svn_url(random_filename)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_invalid_credentials_should_fail
|
|
|
|
Project.find(1).update_attribute :is_public, false
|
|
|
|
with_credentials "dlopper", "foo" do
|
|
|
|
assert_success "ls", svn_url
|
|
|
|
end
|
|
|
|
with_credentials "dlopper", "wrong" do
|
|
|
|
assert_failure "ls", svn_url
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-06-14 12:04:44 +04:00
|
|
|
def test_anonymous_read_should_fail_with_login_required
|
|
|
|
assert_success "ls", svn_url
|
|
|
|
with_settings :login_required => '1' do
|
|
|
|
assert_failure "ls", svn_url
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_authenticated_read_should_succeed_with_login_required
|
|
|
|
with_settings :login_required => '1' do
|
|
|
|
with_credentials "miscuser8", "foo" do
|
|
|
|
assert_success "ls", svn_url
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-06-26 00:08:49 +04:00
|
|
|
def test_read_on_archived_projects_should_fail
|
|
|
|
Project.find(1).update_attribute :status, Project::STATUS_ARCHIVED
|
|
|
|
assert_failure "ls", svn_url
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_read_on_archived_private_projects_should_fail
|
|
|
|
Project.find(1).update_attribute :status, Project::STATUS_ARCHIVED
|
|
|
|
Project.find(1).update_attribute :is_public, false
|
|
|
|
with_credentials "dlopper", "foo" do
|
|
|
|
assert_failure "ls", svn_url
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_read_on_closed_projects_should_succeed
|
|
|
|
Project.find(1).update_attribute :status, Project::STATUS_CLOSED
|
|
|
|
assert_success "ls", svn_url
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_read_on_closed_private_projects_should_succeed
|
|
|
|
Project.find(1).update_attribute :status, Project::STATUS_CLOSED
|
|
|
|
Project.find(1).update_attribute :is_public, false
|
|
|
|
with_credentials "dlopper", "foo" do
|
|
|
|
assert_success "ls", svn_url
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_commit_on_closed_projects_should_fail
|
|
|
|
Project.find(1).update_attribute :status, Project::STATUS_CLOSED
|
|
|
|
Role.find(2).add_permission! :commit_access
|
|
|
|
with_credentials "dlopper", "foo" do
|
|
|
|
assert_failure "mkdir --message Creating_a_directory", svn_url(random_filename)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_commit_on_closed_private_projects_should_fail
|
|
|
|
Project.find(1).update_attribute :status, Project::STATUS_CLOSED
|
|
|
|
Project.find(1).update_attribute :is_public, false
|
|
|
|
Role.find(2).add_permission! :commit_access
|
|
|
|
with_credentials "dlopper", "foo" do
|
|
|
|
assert_failure "mkdir --message Creating_a_directory", svn_url(random_filename)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-06-14 12:04:44 +04:00
|
|
|
if ldap_configured?
|
|
|
|
def test_user_with_ldap_auth_source_should_authenticate_with_ldap_credentials
|
|
|
|
ldap_user = User.new(:mail => 'example1@redmine.org', :firstname => 'LDAP', :lastname => 'user', :auth_source_id => 1)
|
|
|
|
ldap_user.login = 'example1'
|
|
|
|
ldap_user.save!
|
|
|
|
|
|
|
|
with_settings :login_required => '1' do
|
|
|
|
with_credentials "example1", "123456" do
|
|
|
|
assert_success "ls", svn_url
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
with_settings :login_required => '1' do
|
|
|
|
with_credentials "example1", "wrong" do
|
|
|
|
assert_failure "ls", svn_url
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-06-12 23:33:09 +04:00
|
|
|
def test_checkout
|
|
|
|
Dir.mktmpdir do |dir|
|
|
|
|
assert_success "checkout", svn_url, dir
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_read_commands
|
|
|
|
assert_success "info", svn_url
|
|
|
|
assert_success "ls", svn_url
|
|
|
|
assert_success "log", svn_url
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_write_commands
|
|
|
|
Role.find(2).add_permission! :commit_access
|
2012-06-12 23:59:28 +04:00
|
|
|
filename = random_filename
|
2012-06-12 23:33:09 +04:00
|
|
|
|
|
|
|
Dir.mktmpdir do |dir|
|
|
|
|
assert_success "checkout", svn_url, dir
|
|
|
|
Dir.chdir(dir) do
|
|
|
|
# creates a file in the working copy
|
|
|
|
f = File.new(File.join(dir, filename), "w")
|
|
|
|
f.write "test file content"
|
|
|
|
f.close
|
|
|
|
|
|
|
|
assert_success "add", filename
|
|
|
|
with_credentials "dlopper", "foo" do
|
|
|
|
assert_success "commit --message Committing_a_file"
|
|
|
|
assert_success "copy --message Copying_a_file", svn_url(filename), svn_url("#{filename}_copy")
|
|
|
|
assert_success "delete --message Deleting_a_file", svn_url(filename)
|
|
|
|
assert_success "mkdir --message Creating_a_directory", svn_url("#{filename}_dir")
|
|
|
|
end
|
|
|
|
assert_success "update"
|
|
|
|
|
|
|
|
# checks that the working copy was updated
|
|
|
|
assert File.exists?(File.join(dir, "#{filename}_copy"))
|
|
|
|
assert File.directory?(File.join(dir, "#{filename}_dir"))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_read_invalid_repo_should_fail
|
|
|
|
assert_failure "ls", svn_url("invalid")
|
|
|
|
end
|
|
|
|
|
|
|
|
protected
|
|
|
|
|
|
|
|
def execute(*args)
|
|
|
|
a = [SVN_BIN, "--no-auth-cache --non-interactive"]
|
|
|
|
a << "--username #{username}" if username
|
|
|
|
a << "--password #{password}" if password
|
|
|
|
|
|
|
|
super a, *args
|
|
|
|
end
|
|
|
|
|
|
|
|
def svn_url(path=nil)
|
|
|
|
host = ENV['REDMINE_TEST_DAV_SERVER'] || '127.0.0.1'
|
|
|
|
url = "http://#{host}/svn/ecookbook"
|
|
|
|
url << "/#{path}" if path
|
|
|
|
url
|
|
|
|
end
|
|
|
|
end
|