mirror of
https://github.com/redmine/redmine.git
synced 2025-11-04 20:35:57 +01:00
Patch by Holger Just (user:hjust). git-svn-id: https://svn.redmine.org/redmine/trunk@23944 e93f8b46-1217-0410-a6f0-8f06a7374b81
537 lines
15 KiB
Ruby
537 lines
15 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
# Redmine - project management software
|
|
# Copyright (C) 2006- 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.
|
|
|
|
require_relative '../test_helper'
|
|
|
|
class RepositoriesControllerTest < Redmine::RepositoryControllerTest
|
|
def setup
|
|
super
|
|
User.current = nil
|
|
end
|
|
|
|
def test_new
|
|
@request.session[:user_id] = 1
|
|
get(
|
|
:new,
|
|
:params => {
|
|
:project_id => 'subproject1'
|
|
}
|
|
)
|
|
assert_response :success
|
|
assert_includes @response.headers['Cache-Control'], 'no-store'
|
|
|
|
assert_select 'select[name=?]', 'repository_scm' do
|
|
assert_select 'option[value=?][selected=selected]', 'Subversion'
|
|
end
|
|
assert_select 'input[name=?]:not([disabled])', 'repository[url]'
|
|
end
|
|
|
|
def test_new_should_propose_enabled_scm_only
|
|
@request.session[:user_id] = 1
|
|
with_settings :enabled_scm => ['Mercurial', 'Git'] do
|
|
get(
|
|
:new,
|
|
:params => {
|
|
:project_id => 'subproject1'
|
|
}
|
|
)
|
|
end
|
|
assert_response :success
|
|
assert_select 'select[name=repository_scm]' do
|
|
assert_select 'option', 3
|
|
assert_select 'option[value=Mercurial][selected=selected]'
|
|
assert_select 'option[value=Git]:not([selected])'
|
|
end
|
|
end
|
|
|
|
def test_get_new_with_type
|
|
@request.session[:user_id] = 1
|
|
get(
|
|
:new,
|
|
:params => {
|
|
:project_id => 'subproject1',
|
|
:repository_scm => 'Git'
|
|
}
|
|
)
|
|
assert_response :success
|
|
assert_select 'select[name=?]', 'repository_scm' do
|
|
assert_select 'option[value=?][selected=selected]', 'Git'
|
|
end
|
|
end
|
|
|
|
def test_create
|
|
@request.session[:user_id] = 1
|
|
assert_difference 'Repository.count' do
|
|
post(
|
|
:create,
|
|
:params => {
|
|
:project_id => 'subproject1',
|
|
:repository_scm => 'Subversion',
|
|
:repository => {
|
|
:url => 'file:///test',
|
|
:is_default => '1',
|
|
:identifier => ''
|
|
}
|
|
}
|
|
)
|
|
end
|
|
assert_response :found
|
|
repository = Repository.order('id DESC').first
|
|
assert_kind_of Repository::Subversion, repository
|
|
assert_equal 'file:///test', repository.url
|
|
end
|
|
|
|
def test_create_with_failure
|
|
@request.session[:user_id] = 1
|
|
assert_no_difference 'Repository.count' do
|
|
post(
|
|
:create,
|
|
:params => {
|
|
:project_id => 'subproject1',
|
|
:repository_scm => 'Subversion',
|
|
:repository => {
|
|
:url => 'invalid'
|
|
}
|
|
}
|
|
)
|
|
end
|
|
assert_response :success
|
|
assert_includes @response.headers['Cache-Control'], 'no-store'
|
|
|
|
assert_select_error /URL is invalid/
|
|
assert_select 'select[name=?]', 'repository_scm' do
|
|
assert_select 'option[value=?][selected=selected]', 'Subversion'
|
|
end
|
|
end
|
|
|
|
def test_edit
|
|
@request.session[:user_id] = 1
|
|
get(:edit, :params => {:id => 11})
|
|
assert_response :success
|
|
assert_includes @response.headers['Cache-Control'], 'no-store'
|
|
|
|
assert_select 'input[name=?][value=?][disabled=disabled]', 'repository[url]', 'svn://localhost/test'
|
|
end
|
|
|
|
def test_update
|
|
@request.session[:user_id] = 1
|
|
put(
|
|
:update,
|
|
:params => {
|
|
:id => 11,
|
|
:repository => {
|
|
:password => 'test_update'
|
|
}
|
|
}
|
|
)
|
|
assert_response :found
|
|
assert_equal 'test_update', Repository.find(11).password
|
|
end
|
|
|
|
def test_update_with_failure
|
|
@request.session[:user_id] = 1
|
|
put(
|
|
:update,
|
|
:params => {
|
|
:id => 11,
|
|
:repository => {
|
|
:password => 'x'*260
|
|
}
|
|
}
|
|
)
|
|
assert_response :success
|
|
assert_includes @response.headers['Cache-Control'], 'no-store'
|
|
|
|
assert_select_error /Password is too long/
|
|
end
|
|
|
|
def test_destroy
|
|
@request.session[:user_id] = 1
|
|
assert_difference 'Repository.count', -1 do
|
|
delete(:destroy, :params => {:id => 11})
|
|
end
|
|
assert_response :found
|
|
assert_nil Repository.find_by_id(11)
|
|
end
|
|
|
|
def test_show_with_autofetch_changesets_enabled_should_fetch_changesets
|
|
Repository::Subversion.any_instance.expects(:fetch_changesets).once
|
|
with_settings :autofetch_changesets => '1' do
|
|
get(:show, :params => {:id => 1})
|
|
end
|
|
end
|
|
|
|
def test_show_with_autofetch_changesets_disabled_should_not_fetch_changesets
|
|
Repository::Subversion.any_instance.expects(:fetch_changesets).never
|
|
with_settings :autofetch_changesets => '0' do
|
|
get(:show, :params => {:id => 1})
|
|
end
|
|
end
|
|
|
|
def test_show_with_closed_project_should_not_fetch_changesets
|
|
Repository::Subversion.any_instance.expects(:fetch_changesets).never
|
|
Project.find(1).close
|
|
with_settings :autofetch_changesets => '1' do
|
|
get(:show, :params => {:id => 1})
|
|
end
|
|
end
|
|
|
|
def test_show_without_main_repository_should_display_first_repository
|
|
skip unless repository_configured?('subversion')
|
|
skip unless Repository::Subversion.scm_available
|
|
|
|
project = Project.find(1)
|
|
repos = project.repositories
|
|
repos << Repository::Subversion.create(:identifier => 'test', :url => 'svn://valid')
|
|
assert_equal true, repos.exists?(:is_default => true)
|
|
|
|
repos.update_all(:is_default => false)
|
|
repos.reload
|
|
assert_equal false, repos.exists?(:is_default => true)
|
|
|
|
repository = repos.sort.first # rubocop:disable Style/RedundantSort
|
|
@request.session[:user_id] = 2
|
|
|
|
get(:show, :params => {:id => 1})
|
|
assert_response :success
|
|
assert_select '#sidebar' do
|
|
assert_select 'a.repository.selected[href=?]', "/projects/#{project.identifier}/repository/#{repository.identifier_param}"
|
|
end
|
|
end
|
|
|
|
def test_show_should_show_diff_button_depending_on_browse_repository_permission
|
|
skip unless repository_configured?('subversion')
|
|
skip unless Repository::Subversion.scm_available
|
|
|
|
@request.session[:user_id] = 2
|
|
role = Role.find(1)
|
|
|
|
role.add_permission! :browse_repository
|
|
get(:show, :params => {:id => 1})
|
|
assert_response :success
|
|
assert_select 'input[value="View differences"]'
|
|
|
|
role.remove_permission! :browse_repository
|
|
get(:show, :params => {:id => 1})
|
|
assert_response :success
|
|
assert_select 'input[value="View differences"]', :count => 0
|
|
end
|
|
|
|
def test_fetch_changesets
|
|
skip unless repository_configured?('subversion')
|
|
|
|
@request.session[:user_id] = 2
|
|
role = Role.find(1)
|
|
|
|
with_settings :autofetch_changesets => '0' do
|
|
role.add_permission! :manage_repository
|
|
Repository::Subversion.any_instance.expects(:fetch_changesets).once
|
|
post(:fetch_changesets, :params => {:id => 1, :repository_id => 10})
|
|
assert_redirected_to '/projects/ecookbook/repository/10'
|
|
|
|
role.remove_permission! :manage_repository
|
|
Repository::Subversion.any_instance.expects(:fetch_changesets).never
|
|
post(:fetch_changesets, :params => {:id => 1, :repository_id => 10})
|
|
assert_response :forbidden
|
|
end
|
|
end
|
|
|
|
def test_revisions
|
|
get(
|
|
:revisions,
|
|
:params => {
|
|
:id => 1,
|
|
:repository_id => 10
|
|
}
|
|
)
|
|
assert_response :success
|
|
assert_select 'table.changesets'
|
|
end
|
|
|
|
def test_revisions_for_other_repository
|
|
repository = Repository::Subversion.create!(:project_id => 1, :identifier => 'foo', :url => 'file:///foo')
|
|
get(
|
|
:revisions,
|
|
:params => {
|
|
:id => 1,
|
|
:repository_id => 'foo'
|
|
}
|
|
)
|
|
assert_response :success
|
|
assert_select 'table.changesets'
|
|
end
|
|
|
|
def test_revisions_for_invalid_repository
|
|
get(
|
|
:revisions,
|
|
:params => {
|
|
:id => 1,
|
|
:repository_id => 'foo'
|
|
}
|
|
)
|
|
assert_response :not_found
|
|
end
|
|
|
|
def test_revision
|
|
get(
|
|
:revision,
|
|
:params => {
|
|
:id => 1,
|
|
:repository_id => 10,
|
|
:rev => 1
|
|
}
|
|
)
|
|
assert_response :success
|
|
assert_select 'h2', :text => 'Revision 1'
|
|
end
|
|
|
|
def test_revision_should_not_format_comments_when_disabled
|
|
Changeset.where(:id => 100).update_all(:comments => 'Simple *text*')
|
|
with_settings :commit_logs_formatting => '0' do
|
|
get(
|
|
:revision,
|
|
:params => {
|
|
:id => 1,
|
|
:repository_id => 10,
|
|
:rev => 1
|
|
}
|
|
)
|
|
assert_response :success
|
|
assert_select '.changeset-comments', :text => 'Simple *text*'
|
|
end
|
|
end
|
|
|
|
def test_revision_should_show_add_related_issue_form
|
|
Role.find(1).add_permission! :manage_related_issues
|
|
@request.session[:user_id] = 2
|
|
get(
|
|
:revision,
|
|
:params => {
|
|
:id => 1,
|
|
:repository_id => 10,
|
|
:rev => 1
|
|
}
|
|
)
|
|
assert_response :success
|
|
assert_select 'form[action=?]', '/projects/ecookbook/repository/10/revisions/1/issues' do
|
|
assert_select 'input[name=?]', 'issue_id'
|
|
end
|
|
end
|
|
|
|
def test_revision_should_not_change_the_project_menu_link
|
|
get(
|
|
:revision,
|
|
:params => {
|
|
:id => 1,
|
|
:repository_id => 10,
|
|
:rev => 1
|
|
}
|
|
)
|
|
assert_response :success
|
|
assert_select '#main-menu a.repository[href=?]', '/projects/ecookbook/repository'
|
|
end
|
|
|
|
def test_revision_with_before_nil_and_afer_normal
|
|
get(
|
|
:revision,
|
|
:params => {
|
|
:id => 1,
|
|
:repository_id => 10,
|
|
:rev => 1
|
|
}
|
|
)
|
|
assert_response :success
|
|
assert_select 'div.contextual' do
|
|
assert_select 'a[href=?]', '/projects/ecookbook/repository/10/revisions/0', 0
|
|
assert_select 'a[href=?]', '/projects/ecookbook/repository/10/revisions/2'
|
|
end
|
|
end
|
|
|
|
def test_add_related_issue
|
|
@request.session[:user_id] = 2
|
|
assert_difference 'Changeset.find(103).issues.size' do
|
|
post(
|
|
:add_related_issue,
|
|
:params => {
|
|
:id => 1,
|
|
:repository_id => 10,
|
|
:rev => 4,
|
|
:issue_id => 2,
|
|
:format => 'js'
|
|
},
|
|
:xhr => true
|
|
)
|
|
assert_response :success
|
|
assert_equal 'text/javascript', response.media_type
|
|
end
|
|
assert_equal [2], Changeset.find(103).issue_ids
|
|
assert_include 'related-issues', response.body
|
|
assert_include 'Feature request #2', response.body
|
|
end
|
|
|
|
def test_add_related_issue_should_accept_issue_id_with_sharp
|
|
@request.session[:user_id] = 2
|
|
assert_difference 'Changeset.find(103).issues.size' do
|
|
post(
|
|
:add_related_issue,
|
|
:params => {
|
|
:id => 1,
|
|
:repository_id => 10,
|
|
:rev => 4,
|
|
:issue_id => "#2",
|
|
:format => 'js'
|
|
},
|
|
:xhr => true
|
|
)
|
|
end
|
|
assert_equal [2], Changeset.find(103).issue_ids
|
|
end
|
|
|
|
def test_add_related_issue_with_invalid_issue_id
|
|
@request.session[:user_id] = 2
|
|
assert_no_difference 'Changeset.find(103).issues.size' do
|
|
post(
|
|
:add_related_issue,
|
|
:params => {
|
|
:id => 1,
|
|
:repository_id => 10,
|
|
:rev => 4,
|
|
:issue_id => 9999,
|
|
:format => 'js'
|
|
},
|
|
:xhr => true
|
|
)
|
|
assert_response :success
|
|
assert_equal 'text/javascript', response.media_type
|
|
end
|
|
assert_include 'alert("Issue is invalid")', response.body
|
|
end
|
|
|
|
def test_remove_related_issue
|
|
Changeset.find(103).issues << Issue.find(1)
|
|
Changeset.find(103).issues << Issue.find(2)
|
|
@request.session[:user_id] = 2
|
|
assert_difference 'Changeset.find(103).issues.size', -1 do
|
|
delete(
|
|
:remove_related_issue,
|
|
:params => {
|
|
:id => 1,
|
|
:repository_id => 10,
|
|
:rev => 4,
|
|
:issue_id => 2,
|
|
:format => 'js'
|
|
},
|
|
:xhr => true
|
|
)
|
|
assert_response :success
|
|
assert_equal 'text/javascript', response.media_type
|
|
end
|
|
assert_equal [1], Changeset.find(103).issue_ids
|
|
assert_include 'related-issue-2', response.body
|
|
end
|
|
|
|
def test_graph_commits_per_month
|
|
# Make sure there's some data to display
|
|
latest = Project.find(1).repository.changesets.maximum(:commit_date)
|
|
assert_not_nil latest
|
|
Date.stubs(:today).returns(latest.to_date + 10)
|
|
get(
|
|
:graph,
|
|
:params => {
|
|
:id => 1,
|
|
:repository_id => 10,
|
|
:graph => 'commits_per_month'
|
|
}
|
|
)
|
|
assert_response :success
|
|
assert_equal 'application/json', response.media_type
|
|
data = ActiveSupport::JSON.decode(response.body)
|
|
assert_not_nil data['labels']
|
|
assert_not_nil data['commits']
|
|
assert_not_nil data['changes']
|
|
end
|
|
|
|
def test_graph_commits_per_author
|
|
get(
|
|
:graph,
|
|
:params => {
|
|
:id => 1,
|
|
:repository_id => 10,
|
|
:graph => 'commits_per_author'
|
|
}
|
|
)
|
|
assert_response :success
|
|
assert_equal 'application/json', response.media_type
|
|
data = ActiveSupport::JSON.decode(response.body)
|
|
assert_not_nil data['labels']
|
|
assert_not_nil data['commits']
|
|
assert_not_nil data['changes']
|
|
end
|
|
|
|
def test_get_committers
|
|
@request.session[:user_id] = 2
|
|
# add a commit with an unknown user
|
|
Changeset.
|
|
create!(
|
|
:repository => Project.find(1).repository,
|
|
:committer => 'foo',
|
|
:committed_on => Time.now,
|
|
:revision => 100,
|
|
:comments => 'Committed by foo.'
|
|
)
|
|
get(:committers, :params => {:id => 10})
|
|
assert_response :success
|
|
assert_select 'input[value=dlopper] + select option[value="3"][selected=selected]', :text => 'Dave Lopper'
|
|
assert_select 'input[value=foo] + select option[selected=selected]', 0 # no option selected
|
|
end
|
|
|
|
def test_get_committers_without_changesets
|
|
Changeset.delete_all
|
|
@request.session[:user_id] = 2
|
|
get(:committers, :params => {:id => 10})
|
|
assert_response :success
|
|
end
|
|
|
|
def test_post_committers
|
|
@request.session[:user_id] = 2
|
|
# add a commit with an unknown user
|
|
c = Changeset.
|
|
create!(
|
|
:repository => Project.find(1).repository,
|
|
:committer => 'foo',
|
|
:committed_on => Time.now,
|
|
:revision => 100,
|
|
:comments => 'Committed by foo.'
|
|
)
|
|
assert_no_difference "Changeset.where(:user_id => 3).count" do
|
|
post(
|
|
:committers,
|
|
:params => {
|
|
:id => 10,
|
|
:committers => {
|
|
'0' => ['foo', '2'], '1' => ['dlopper', '3']
|
|
}
|
|
}
|
|
)
|
|
assert_response :found
|
|
assert_equal User.find(2), c.reload.user
|
|
end
|
|
end
|
|
end
|