diff options
author | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2014-11-08 10:52:59 +0000 |
---|---|---|
committer | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2014-11-08 10:52:59 +0000 |
commit | 13f9ccaed853654df5cfb990884345b513f0b88c (patch) | |
tree | 7e7bc0be36a46b5e87032e89862f56894f68f422 /test | |
parent | 34bb545e4f327d24bd81a0bdb4ec02c6fb6ee0e7 (diff) | |
download | redmine-13f9ccaed853654df5cfb990884345b513f0b88c.tar.gz redmine-13f9ccaed853654df5cfb990884345b513f0b88c.zip |
Adds configuration settings to limit valid repository path (#1415).
git-svn-id: http://svn.redmine.org/redmine/trunk@13573 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'test')
-rw-r--r-- | test/unit/repository_cvs_test.rb | 18 | ||||
-rw-r--r-- | test/unit/repository_subversion_test.rb | 31 |
2 files changed, 49 insertions, 0 deletions
diff --git a/test/unit/repository_cvs_test.rb b/test/unit/repository_cvs_test.rb index 8b5ac6271..fec41329a 100644 --- a/test/unit/repository_cvs_test.rb +++ b/test/unit/repository_cvs_test.rb @@ -93,6 +93,24 @@ class RepositoryCvsTest < ActiveSupport::TestCase assert_include str, repo.errors.full_messages end + def test_root_url_should_be_validated_against_regexp_set_in_configuration + Redmine::Configuration.with 'scm_cvs_path_regexp' => '/cvspath/[a-z]+' do + repo = Repository::Cvs.new( + :project => @project, + :identifier => 'test', + :log_encoding => 'UTF-8', + :path_encoding => '', + :url => MODULE_NAME + ) + repo.root_url = '/wrong_path' + assert !repo.valid? + assert repo.errors[:root_url].present? + + repo.root_url = '/cvspath/foo' + assert repo.valid? + end + end + if File.directory?(REPOSITORY_PATH) def test_fetch_changesets_from_scratch assert_equal 0, @repository.changesets.count diff --git a/test/unit/repository_subversion_test.rb b/test/unit/repository_subversion_test.rb index 2fe50da14..42e963288 100644 --- a/test/unit/repository_subversion_test.rb +++ b/test/unit/repository_subversion_test.rb @@ -57,6 +57,37 @@ class RepositorySubversionTest < ActiveSupport::TestCase end end + def test_url_should_be_validated_against_regexp_set_in_configuration + Redmine::Configuration.with 'scm_subversion_path_regexp' => 'file:///svnpath/[a-z]+' do + repo = Repository::Subversion.new(:project => @project, :identifier => 'test') + repo.url = 'http://foo' + assert !repo.valid? + assert repo.errors[:url].present? + + repo.url = 'file:///svnpath/foo/bar' + assert !repo.valid? + assert repo.errors[:url].present? + + repo.url = 'file:///svnpath/foo' + assert repo.valid? + end + end + + def test_url_should_be_validated_against_regexp_set_in_configuration_with_project_identifier + Redmine::Configuration.with 'scm_subversion_path_regexp' => 'file:///svnpath/%project%(\.[a-z]+)?' do + repo = Repository::Subversion.new(:project => @project, :identifier => 'test') + repo.url = 'file:///svnpath/invalid' + assert !repo.valid? + assert repo.errors[:url].present? + + repo.url = 'file:///svnpath/subproject1' + assert repo.valid? + + repo.url = 'file:///svnpath/subproject1.foo' + assert repo.valid? + end + end + if repository_configured?('subversion') def test_fetch_changesets_from_scratch assert_equal 0, @repository.changesets.count |