repositories_mercurial_controller_test.rb
374 lines
| 12.9 KiB
| text/x-ruby
|
RubyLexer
|
r978 | # redMine - project management software | ||
|
r1314 | # Copyright (C) 2006-2008 Jean-Philippe Lang | ||
|
r978 | # | ||
# 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__) | ||
|
r978 | require 'repositories_controller' | ||
# Re-raise errors caught by the controller. | ||||
class RepositoriesController; def rescue_action(e) raise e end; end | ||||
|
r2773 | class RepositoriesMercurialControllerTest < ActionController::TestCase | ||
|
r2627 | fixtures :projects, :users, :roles, :members, :member_roles, :repositories, :enabled_modules | ||
|
r978 | |||
# No '..' in the repository path | ||||
REPOSITORY_PATH = RAILS_ROOT.gsub(%r{config\/\.\.}, '') + '/tmp/test/mercurial_repository' | ||||
|
r4880 | CHAR_1_HEX = "\xc3\x9c" | ||
ruby19_non_utf8_pass = (RUBY_VERSION >= '1.9' && Encoding.default_external.to_s != 'UTF-8') | ||||
|
r978 | |||
def setup | ||||
@controller = RepositoriesController.new | ||||
@request = ActionController::TestRequest.new | ||||
@response = ActionController::TestResponse.new | ||||
User.current = nil | ||||
|
r4876 | @repository = Repository::Mercurial.create( | ||
:project => Project.find(3), | ||||
:url => REPOSITORY_PATH, | ||||
:path_encoding => 'ISO-8859-1' | ||||
) | ||||
|
r4566 | assert @repository | ||
|
r4735 | @diff_c_support = true | ||
|
r4880 | @char_1 = CHAR_1_HEX.dup | ||
|
r4998 | @tag_char_1 = "tag-#{CHAR_1_HEX}-00" | ||
@branch_char_0 = "branch-#{CHAR_1_HEX}-00" | ||||
@branch_char_1 = "branch-#{CHAR_1_HEX}-01" | ||||
|
r4880 | if @char_1.respond_to?(:force_encoding) | ||
@char_1.force_encoding('UTF-8') | ||||
|
r4998 | @tag_char_1.force_encoding('UTF-8') | ||
@branch_char_0.force_encoding('UTF-8') | ||||
@branch_char_1.force_encoding('UTF-8') | ||||
|
r4880 | end | ||
|
r978 | end | ||
|
r4566 | |||
|
r4880 | if ruby19_non_utf8_pass | ||
puts "TODO: Mercurial functional test fails in Ruby 1.9 " + | ||||
"and Encoding.default_external is not UTF-8. " + | ||||
"Current value is '#{Encoding.default_external.to_s}'" | ||||
def test_fake; assert true end | ||||
elsif File.directory?(REPOSITORY_PATH) | ||||
|
r1006 | def test_show | ||
get :show, :id => 3 | ||||
assert_response :success | ||||
assert_template 'show' | ||||
assert_not_nil assigns(:entries) | ||||
assert_not_nil assigns(:changesets) | ||||
end | ||||
|
r4598 | |||
|
r2735 | def test_show_root | ||
|
r5002 | @repository.fetch_changesets | ||
@repository.reload | ||||
|
r2735 | get :show, :id => 3 | ||
|
r1006 | assert_response :success | ||
|
r2735 | assert_template 'show' | ||
|
r1006 | assert_not_nil assigns(:entries) | ||
|
r4514 | assert_equal 4, assigns(:entries).size | ||
|
r4511 | assert assigns(:entries).detect {|e| e.name == 'images' && e.kind == 'dir'} | ||
|
r1006 | assert assigns(:entries).detect {|e| e.name == 'sources' && e.kind == 'dir'} | ||
|
r4511 | assert assigns(:entries).detect {|e| e.name == 'README' && e.kind == 'file'} | ||
|
r5002 | assert_not_nil assigns(:changesets) | ||
assigns(:changesets).size > 0 | ||||
|
r1006 | end | ||
|
r4598 | |||
|
r2735 | def test_show_directory | ||
|
r5002 | @repository.fetch_changesets | ||
@repository.reload | ||||
|
r2735 | get :show, :id => 3, :path => ['images'] | ||
|
r1006 | assert_response :success | ||
|
r2735 | assert_template 'show' | ||
|
r1006 | assert_not_nil assigns(:entries) | ||
|
r1314 | assert_equal ['delete.png', 'edit.png'], assigns(:entries).collect(&:name) | ||
|
r1006 | entry = assigns(:entries).detect {|e| e.name == 'edit.png'} | ||
assert_not_nil entry | ||||
assert_equal 'file', entry.kind | ||||
assert_equal 'images/edit.png', entry.path | ||||
|
r5002 | assert_not_nil assigns(:changesets) | ||
assigns(:changesets).size > 0 | ||||
|
r1006 | end | ||
|
r4544 | |||
|
r2735 | def test_show_at_given_revision | ||
|
r5002 | @repository.fetch_changesets | ||
@repository.reload | ||||
|
r4544 | [0, '0', '0885933ad4f6'].each do |r1| | ||
get :show, :id => 3, :path => ['images'], :rev => r1 | ||||
assert_response :success | ||||
assert_template 'show' | ||||
assert_not_nil assigns(:entries) | ||||
assert_equal ['delete.png'], assigns(:entries).collect(&:name) | ||||
|
r5002 | assert_not_nil assigns(:changesets) | ||
assigns(:changesets).size > 0 | ||||
|
r4544 | end | ||
|
r1314 | end | ||
|
r4515 | |||
def test_show_directory_sql_escape_percent | ||||
|
r5002 | @repository.fetch_changesets | ||
@repository.reload | ||||
|
r4544 | [13, '13', '3a330eb32958'].each do |r1| | ||
get :show, :id => 3, :path => ['sql_escape', 'percent%dir'], :rev => r1 | ||||
assert_response :success | ||||
assert_template 'show' | ||||
|
r4515 | |||
|
r4544 | assert_not_nil assigns(:entries) | ||
assert_equal ['percent%file1.txt', 'percentfile1.txt'], assigns(:entries).collect(&:name) | ||||
changesets = assigns(:changesets) | ||||
|
r5004 | assert_not_nil changesets | ||
|
r5002 | assigns(:changesets).size > 0 | ||
|
r5004 | assert_equal %w(13 11 10 9), changesets.collect(&:revision) | ||
|
r4544 | end | ||
|
r4515 | end | ||
|
r4880 | def test_show_directory_latin_1 | ||
@repository.fetch_changesets | ||||
@repository.reload | ||||
[21, '21', 'adf805632193'].each do |r1| | ||||
get :show, :id => 3, :path => ['latin-1-dir'], :rev => r1 | ||||
assert_response :success | ||||
assert_template 'show' | ||||
assert_not_nil assigns(:entries) | ||||
assert_equal ["make-latin-1-file.rb", | ||||
"test-#{@char_1}-1.txt", | ||||
"test-#{@char_1}-2.txt", | ||||
"test-#{@char_1}.txt"], assigns(:entries).collect(&:name) | ||||
changesets = assigns(:changesets) | ||||
assert_not_nil changesets | ||||
|
r5003 | assert_equal %w(21 20 19 18 17), changesets.collect(&:revision) | ||
|
r4880 | end | ||
end | ||||
|
r5010 | def test_show_branch | ||
@repository.fetch_changesets | ||||
@repository.reload | ||||
[ | ||||
'default', | ||||
@branch_char_1, | ||||
'branch (1)[2]&,%.-3_4', | ||||
@branch_char_0, | ||||
'test_branch.latin-1', | ||||
'test-branch-00', | ||||
].each do |bra| | ||||
get :show, :id => 3, :rev => bra | ||||
assert_response :success | ||||
assert_template 'show' | ||||
assert_not_nil assigns(:entries) | ||||
assert assigns(:entries).size > 0 | ||||
assert_not_nil assigns(:changesets) | ||||
assigns(:changesets).size > 0 | ||||
end | ||||
end | ||||
|
r5011 | def test_show_tag | ||
@repository.fetch_changesets | ||||
@repository.reload | ||||
[ | ||||
@tag_char_1, | ||||
'tag_test.00', | ||||
'tag-init-revision' | ||||
].each do |tag| | ||||
get :show, :id => 3, :rev => tag | ||||
assert_response :success | ||||
assert_template 'show' | ||||
assert_not_nil assigns(:entries) | ||||
assert assigns(:entries).size > 0 | ||||
assert_not_nil assigns(:changesets) | ||||
assigns(:changesets).size > 0 | ||||
end | ||||
end | ||||
|
r1006 | def test_changes | ||
get :changes, :id => 3, :path => ['images', 'edit.png'] | ||||
assert_response :success | ||||
assert_template 'changes' | ||||
assert_tag :tag => 'h2', :content => 'edit.png' | ||||
end | ||||
def test_entry_show | ||||
get :entry, :id => 3, :path => ['sources', 'watchers_controller.rb'] | ||||
assert_response :success | ||||
assert_template 'entry' | ||||
|
r4511 | # Line 10 | ||
|
r1006 | assert_tag :tag => 'th', | ||
|
r4511 | :content => '10', | ||
:attributes => { :class => 'line-num' }, | ||||
|
r1006 | :sibling => { :tag => 'td', :content => /WITHOUT ANY WARRANTY/ } | ||
end | ||||
|
r4880 | |||
def test_entry_show_latin_1 | ||||
[21, '21', 'adf805632193'].each do |r1| | ||||
get :entry, :id => 3, :path => ['latin-1-dir', "test-#{@char_1}-2.txt"], :rev => r1 | ||||
assert_response :success | ||||
assert_template 'entry' | ||||
assert_tag :tag => 'th', | ||||
:content => '1', | ||||
:attributes => { :class => 'line-num' }, | ||||
:sibling => { :tag => 'td', :content => /Mercurial is a distributed version control system/ } | ||||
end | ||||
end | ||||
|
r1006 | |||
def test_entry_download | ||||
get :entry, :id => 3, :path => ['sources', 'watchers_controller.rb'], :format => 'raw' | ||||
assert_response :success | ||||
# File content | ||||
assert @response.body.include?('WITHOUT ANY WARRANTY') | ||||
end | ||||
|
r1350 | |||
def test_directory_entry | ||||
get :entry, :id => 3, :path => ['sources'] | ||||
assert_response :success | ||||
|
r2735 | assert_template 'show' | ||
|
r1350 | assert_not_nil assigns(:entry) | ||
assert_equal 'sources', assigns(:entry).name | ||||
end | ||||
|
r1006 | def test_diff | ||
|
r4579 | @repository.fetch_changesets | ||
@repository.reload | ||||
|
r4544 | [4, '4', 'def6d2f1254a'].each do |r1| | ||
# Full diff of changeset 4 | ||||
|
r4598 | get :diff, :id => 3, :rev => r1 | ||
|
r4544 | assert_response :success | ||
assert_template 'diff' | ||||
|
r4566 | |||
|
r4733 | if @diff_c_support | ||
|
r4566 | # Line 22 removed | ||
assert_tag :tag => 'th', | ||||
:content => '22', | ||||
:sibling => { :tag => 'td', | ||||
:attributes => { :class => /diff_out/ }, | ||||
:content => /def remove/ } | ||||
|
r4579 | assert_tag :tag => 'h2', :content => /4:def6d2f1254a/ | ||
end | ||||
end | ||||
end | ||||
def test_diff_two_revs | ||||
@repository.fetch_changesets | ||||
@repository.reload | ||||
[2, '400bb8672109', '400', 400].each do |r1| | ||||
[4, 'def6d2f1254a'].each do |r2| | ||||
get :diff, :id => 3, :rev => r1, | ||||
:rev_to => r2 | ||||
assert_response :success | ||||
assert_template 'diff' | ||||
diff = assigns(:diff) | ||||
assert_not_nil diff | ||||
assert_tag :tag => 'h2', :content => /4:def6d2f1254a 2:400bb8672109/ | ||||
|
r4566 | end | ||
|
r4544 | end | ||
|
r1006 | end | ||
|
r4543 | |||
|
r4880 | def test_diff_latin_1 | ||
[21, 'adf805632193'].each do |r1| | ||||
get :diff, :id => 3, :rev => r1 | ||||
assert_response :success | ||||
assert_template 'diff' | ||||
assert_tag :tag => 'th', | ||||
:content => '2', | ||||
:sibling => { :tag => 'td', | ||||
:attributes => { :class => /diff_in/ }, | ||||
:content => /It is written in Python/ } | ||||
end | ||||
end | ||||
|
r1006 | def test_annotate | ||
get :annotate, :id => 3, :path => ['sources', 'watchers_controller.rb'] | ||||
assert_response :success | ||||
assert_template 'annotate' | ||||
|
r4505 | # Line 23, revision 4:def6d2f1254a | ||
assert_tag :tag => 'th', | ||||
:content => '23', | ||||
:attributes => { :class => 'line-num' }, | ||||
:sibling => | ||||
{ | ||||
:tag => 'td', | ||||
:attributes => { :class => 'revision' }, | ||||
|
r4543 | :child => { :tag => 'a', :content => '4:def6d2f1254a' } | ||
|
r4505 | } | ||
assert_tag :tag => 'th', | ||||
:content => '23', | ||||
:attributes => { :class => 'line-num' }, | ||||
:sibling => | ||||
{ | ||||
:tag => 'td' , | ||||
:content => 'jsmith' , | ||||
:attributes => { :class => 'author' }, | ||||
} | ||||
assert_tag :tag => 'th', | ||||
:content => '23', | ||||
:attributes => { :class => 'line-num' }, | ||||
|
r1006 | :sibling => { :tag => 'td', :content => /watcher =/ } | ||
end | ||||
|
r4584 | |||
|
r4614 | def test_annotate_at_given_revision | ||
@repository.fetch_changesets | ||||
@repository.reload | ||||
[2, '400bb8672109', '400', 400].each do |r1| | ||||
get :annotate, :id => 3, :rev => r1, :path => ['sources', 'watchers_controller.rb'] | ||||
assert_response :success | ||||
assert_template 'annotate' | ||||
assert_tag :tag => 'h2', :content => /@ 2:400bb8672109/ | ||||
end | ||||
end | ||||
|
r4880 | def test_annotate_latin_1 | ||
[21, '21', 'adf805632193'].each do |r1| | ||||
get :annotate, :id => 3, :path => ['latin-1-dir', "test-#{@char_1}-2.txt"], :rev => r1 | ||||
assert_response :success | ||||
assert_template 'annotate' | ||||
assert_tag :tag => 'th', | ||||
:content => '1', | ||||
:attributes => { :class => 'line-num' }, | ||||
:sibling => | ||||
{ | ||||
:tag => 'td', | ||||
:attributes => { :class => 'revision' }, | ||||
:child => { :tag => 'a', :content => '20:709858aafd1b' } | ||||
} | ||||
assert_tag :tag => 'th', | ||||
:content => '1', | ||||
:attributes => { :class => 'line-num' }, | ||||
:sibling => | ||||
{ | ||||
:tag => 'td' , | ||||
:content => 'jsmith' , | ||||
:attributes => { :class => 'author' }, | ||||
} | ||||
assert_tag :tag => 'th', | ||||
:content => '1', | ||||
:attributes => { :class => 'line-num' }, | ||||
:sibling => { :tag => 'td', :content => /Mercurial is a distributed version control system/ } | ||||
end | ||||
end | ||||
|
r4584 | def test_empty_revision | ||
@repository.fetch_changesets | ||||
@repository.reload | ||||
['', ' ', nil].each do |r| | ||||
|
r4594 | get :revision, :id => 3, :rev => r | ||
|
r4590 | assert_response 404 | ||
|
r4584 | assert_error_tag :content => /was not found/ | ||
end | ||||
end | ||||
|
r1006 | else | ||
puts "Mercurial test repository NOT FOUND. Skipping functional tests !!!" | ||||
def test_fake; assert true end | ||||
|
r978 | end | ||
end | ||||