Chris@1115: # Redmine - project management software Chris@1115: # Copyright (C) 2006-2012 Jean-Philippe Lang Chris@1115: # Chris@1115: # This program is free software; you can redistribute it and/or Chris@1115: # modify it under the terms of the GNU General Public License Chris@1115: # as published by the Free Software Foundation; either version 2 Chris@1115: # of the License, or (at your option) any later version. Chris@1115: # Chris@1115: # This program is distributed in the hope that it will be useful, Chris@1115: # but WITHOUT ANY WARRANTY; without even the implied warranty of Chris@1115: # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the Chris@1115: # GNU General Public License for more details. Chris@1115: # Chris@1115: # You should have received a copy of the GNU General Public License Chris@1115: # along with this program; if not, write to the Free Software Chris@1115: # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. Chris@1115: Chris@1115: require File.expand_path('../test_case', __FILE__) Chris@1115: require 'tmpdir' Chris@1115: Chris@1115: class RedminePmTest::RepositorySubversionTest < RedminePmTest::TestCase Chris@1115: fixtures :projects, :users, :members, :roles, :member_roles, :auth_sources Chris@1115: Chris@1115: SVN_BIN = Redmine::Configuration['scm_subversion_command'] || "svn" Chris@1115: Chris@1115: def test_anonymous_read_on_public_repo_with_permission_should_succeed Chris@1115: assert_success "ls", svn_url Chris@1115: end Chris@1115: Chris@1115: def test_anonymous_read_on_public_repo_without_permission_should_fail Chris@1115: Role.anonymous.remove_permission! :browse_repository Chris@1115: assert_failure "ls", svn_url Chris@1115: end Chris@1115: Chris@1115: def test_anonymous_read_on_private_repo_should_fail Chris@1115: Project.find(1).update_attribute :is_public, false Chris@1115: assert_failure "ls", svn_url Chris@1115: end Chris@1115: Chris@1115: def test_anonymous_commit_on_public_repo_should_fail Chris@1115: Role.anonymous.add_permission! :commit_access Chris@1115: assert_failure "mkdir --message Creating_a_directory", svn_url(random_filename) Chris@1115: end Chris@1115: Chris@1115: def test_anonymous_commit_on_private_repo_should_fail Chris@1115: Role.anonymous.add_permission! :commit_access Chris@1115: Project.find(1).update_attribute :is_public, false Chris@1115: assert_failure "mkdir --message Creating_a_directory", svn_url(random_filename) Chris@1115: end Chris@1115: Chris@1115: def test_non_member_read_on_public_repo_with_permission_should_succeed Chris@1115: Role.anonymous.remove_permission! :browse_repository Chris@1115: with_credentials "miscuser8", "foo" do Chris@1115: assert_success "ls", svn_url Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: def test_non_member_read_on_public_repo_without_permission_should_fail Chris@1115: Role.anonymous.remove_permission! :browse_repository Chris@1115: Role.non_member.remove_permission! :browse_repository Chris@1115: with_credentials "miscuser8", "foo" do Chris@1115: assert_failure "ls", svn_url Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: def test_non_member_read_on_private_repo_should_fail Chris@1115: Project.find(1).update_attribute :is_public, false Chris@1115: with_credentials "miscuser8", "foo" do Chris@1115: assert_failure "ls", svn_url Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: def test_non_member_commit_on_public_repo_should_fail Chris@1115: Role.non_member.add_permission! :commit_access Chris@1115: assert_failure "mkdir --message Creating_a_directory", svn_url(random_filename) Chris@1115: end Chris@1115: Chris@1115: def test_non_member_commit_on_private_repo_should_fail Chris@1115: Role.non_member.add_permission! :commit_access Chris@1115: Project.find(1).update_attribute :is_public, false Chris@1115: assert_failure "mkdir --message Creating_a_directory", svn_url(random_filename) Chris@1115: end Chris@1115: Chris@1115: def test_member_read_on_public_repo_with_permission_should_succeed Chris@1115: Role.anonymous.remove_permission! :browse_repository Chris@1115: Role.non_member.remove_permission! :browse_repository Chris@1115: with_credentials "dlopper", "foo" do Chris@1115: assert_success "ls", svn_url Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: def test_member_read_on_public_repo_without_permission_should_fail Chris@1115: Role.anonymous.remove_permission! :browse_repository Chris@1115: Role.non_member.remove_permission! :browse_repository Chris@1115: Role.find(2).remove_permission! :browse_repository Chris@1115: with_credentials "dlopper", "foo" do Chris@1115: assert_failure "ls", svn_url Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: def test_member_read_on_private_repo_with_permission_should_succeed Chris@1115: Project.find(1).update_attribute :is_public, false Chris@1115: with_credentials "dlopper", "foo" do Chris@1115: assert_success "ls", svn_url Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: def test_member_read_on_private_repo_without_permission_should_fail Chris@1115: Role.find(2).remove_permission! :browse_repository Chris@1115: Project.find(1).update_attribute :is_public, false Chris@1115: with_credentials "dlopper", "foo" do Chris@1115: assert_failure "ls", svn_url Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: def test_member_commit_on_public_repo_with_permission_should_succeed Chris@1115: Role.find(2).add_permission! :commit_access Chris@1115: with_credentials "dlopper", "foo" do Chris@1115: assert_success "mkdir --message Creating_a_directory", svn_url(random_filename) Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: def test_member_commit_on_public_repo_without_permission_should_fail Chris@1115: Role.find(2).remove_permission! :commit_access Chris@1115: with_credentials "dlopper", "foo" do Chris@1115: assert_failure "mkdir --message Creating_a_directory", svn_url(random_filename) Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: def test_member_commit_on_private_repo_with_permission_should_succeed Chris@1115: Role.find(2).add_permission! :commit_access Chris@1115: Project.find(1).update_attribute :is_public, false Chris@1115: with_credentials "dlopper", "foo" do Chris@1115: assert_success "mkdir --message Creating_a_directory", svn_url(random_filename) Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: def test_member_commit_on_private_repo_without_permission_should_fail Chris@1115: Role.find(2).remove_permission! :commit_access Chris@1115: Project.find(1).update_attribute :is_public, false Chris@1115: with_credentials "dlopper", "foo" do Chris@1115: assert_failure "mkdir --message Creating_a_directory", svn_url(random_filename) Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: def test_invalid_credentials_should_fail Chris@1115: Project.find(1).update_attribute :is_public, false Chris@1115: with_credentials "dlopper", "foo" do Chris@1115: assert_success "ls", svn_url Chris@1115: end Chris@1115: with_credentials "dlopper", "wrong" do Chris@1115: assert_failure "ls", svn_url Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: def test_anonymous_read_should_fail_with_login_required Chris@1115: assert_success "ls", svn_url Chris@1115: with_settings :login_required => '1' do Chris@1115: assert_failure "ls", svn_url Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: def test_authenticated_read_should_succeed_with_login_required Chris@1115: with_settings :login_required => '1' do Chris@1115: with_credentials "miscuser8", "foo" do Chris@1115: assert_success "ls", svn_url Chris@1115: end Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: def test_read_on_archived_projects_should_fail Chris@1115: Project.find(1).update_attribute :status, Project::STATUS_ARCHIVED Chris@1115: assert_failure "ls", svn_url Chris@1115: end Chris@1115: Chris@1115: def test_read_on_archived_private_projects_should_fail Chris@1115: Project.find(1).update_attribute :status, Project::STATUS_ARCHIVED Chris@1115: Project.find(1).update_attribute :is_public, false Chris@1115: with_credentials "dlopper", "foo" do Chris@1115: assert_failure "ls", svn_url Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: def test_read_on_closed_projects_should_succeed Chris@1115: Project.find(1).update_attribute :status, Project::STATUS_CLOSED Chris@1115: assert_success "ls", svn_url Chris@1115: end Chris@1115: Chris@1115: def test_read_on_closed_private_projects_should_succeed Chris@1115: Project.find(1).update_attribute :status, Project::STATUS_CLOSED Chris@1115: Project.find(1).update_attribute :is_public, false Chris@1115: with_credentials "dlopper", "foo" do Chris@1115: assert_success "ls", svn_url Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: def test_commit_on_closed_projects_should_fail Chris@1115: Project.find(1).update_attribute :status, Project::STATUS_CLOSED Chris@1115: Role.find(2).add_permission! :commit_access Chris@1115: with_credentials "dlopper", "foo" do Chris@1115: assert_failure "mkdir --message Creating_a_directory", svn_url(random_filename) Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: def test_commit_on_closed_private_projects_should_fail Chris@1115: Project.find(1).update_attribute :status, Project::STATUS_CLOSED Chris@1115: Project.find(1).update_attribute :is_public, false Chris@1115: Role.find(2).add_permission! :commit_access Chris@1115: with_credentials "dlopper", "foo" do Chris@1115: assert_failure "mkdir --message Creating_a_directory", svn_url(random_filename) Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: if ldap_configured? Chris@1115: def test_user_with_ldap_auth_source_should_authenticate_with_ldap_credentials Chris@1115: ldap_user = User.new(:mail => 'example1@redmine.org', :firstname => 'LDAP', :lastname => 'user', :auth_source_id => 1) Chris@1115: ldap_user.login = 'example1' Chris@1115: ldap_user.save! Chris@1115: Chris@1115: with_settings :login_required => '1' do Chris@1115: with_credentials "example1", "123456" do Chris@1115: assert_success "ls", svn_url Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: with_settings :login_required => '1' do Chris@1115: with_credentials "example1", "wrong" do Chris@1115: assert_failure "ls", svn_url Chris@1115: end Chris@1115: end Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: def test_checkout Chris@1115: Dir.mktmpdir do |dir| Chris@1115: assert_success "checkout", svn_url, dir Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: def test_read_commands Chris@1115: assert_success "info", svn_url Chris@1115: assert_success "ls", svn_url Chris@1115: assert_success "log", svn_url Chris@1115: end Chris@1115: Chris@1115: def test_write_commands Chris@1115: Role.find(2).add_permission! :commit_access Chris@1115: filename = random_filename Chris@1115: Chris@1115: Dir.mktmpdir do |dir| Chris@1115: assert_success "checkout", svn_url, dir Chris@1115: Dir.chdir(dir) do Chris@1115: # creates a file in the working copy Chris@1115: f = File.new(File.join(dir, filename), "w") Chris@1115: f.write "test file content" Chris@1115: f.close Chris@1115: Chris@1115: assert_success "add", filename Chris@1115: with_credentials "dlopper", "foo" do Chris@1115: assert_success "commit --message Committing_a_file" Chris@1115: assert_success "copy --message Copying_a_file", svn_url(filename), svn_url("#{filename}_copy") Chris@1115: assert_success "delete --message Deleting_a_file", svn_url(filename) Chris@1115: assert_success "mkdir --message Creating_a_directory", svn_url("#{filename}_dir") Chris@1115: end Chris@1115: assert_success "update" Chris@1115: Chris@1115: # checks that the working copy was updated Chris@1115: assert File.exists?(File.join(dir, "#{filename}_copy")) Chris@1115: assert File.directory?(File.join(dir, "#{filename}_dir")) Chris@1115: end Chris@1115: end Chris@1115: end Chris@1115: Chris@1115: def test_read_invalid_repo_should_fail Chris@1115: assert_failure "ls", svn_url("invalid") Chris@1115: end Chris@1115: Chris@1115: protected Chris@1115: Chris@1115: def execute(*args) Chris@1115: a = [SVN_BIN, "--no-auth-cache --non-interactive"] Chris@1115: a << "--username #{username}" if username Chris@1115: a << "--password #{password}" if password Chris@1115: Chris@1115: super a, *args Chris@1115: end Chris@1115: Chris@1115: def svn_url(path=nil) Chris@1115: host = ENV['REDMINE_TEST_DAV_SERVER'] || '127.0.0.1' Chris@1115: url = "http://#{host}/svn/ecookbook" Chris@1115: url << "/#{path}" if path Chris@1115: url Chris@1115: end Chris@1115: end