##// END OF EJS Templates
scm: git: add test of showing non ASCII contents of non ASCII path in functional test....
scm: git: add test of showing non ASCII contents of non ASCII path in functional test. TODO: this test fails in Ruby 1.9 and Encoding.default_external is not UTF-8. git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@5697 e93f8b46-1217-0410-a6f0-8f06a7374b81

File last commit:

r5577:6eb8b5fb4a4a
r5577:6eb8b5fb4a4a
Show More
repositories_git_controller_test.rb
293 lines | 10.6 KiB | text/x-ruby | RubyLexer
/ test / functional / repositories_git_controller_test.rb
Toshi MARUYAMA
scm: git: remove trailing white-spaces from functional test....
r5573 # Redmine - project management software
# Copyright (C) 2006-2011 Jean-Philippe Lang
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 #
# 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.
Toshi MARUYAMA
scm: git: remove trailing white-spaces from functional test....
r5573 #
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 # 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.
Toshi MARUYAMA
scm: git: remove trailing white-spaces from functional test....
r5573 #
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 # 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.
Jean-Baptiste Barth
Use absolute paths in test/**/* requires for Ruby 1.9.2 compatibility. #4050...
r4395 require File.expand_path('../../test_helper', __FILE__)
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 require 'repositories_controller'
# Re-raise errors caught by the controller.
class RepositoriesController; def rescue_action(e) raise e end; end
Eric Davis
Upgraded to Rails 2.3.4 (#3597)...
r2773 class RepositoriesGitControllerTest < ActionController::TestCase
Jean-Philippe Lang
Allows multiple roles on the same project (#706). Prerequisite for user groups feature....
r2627 fixtures :projects, :users, :roles, :members, :member_roles, :repositories, :enabled_modules
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222
# No '..' in the repository path
REPOSITORY_PATH = RAILS_ROOT.gsub(%r{config\/\.\.}, '') + '/tmp/test/git_repository'
Jean-Philippe Lang
Fixes platform determination under JRuby (#1804)....
r1752 REPOSITORY_PATH.gsub!(/\//, "\\") if Redmine::Platform.mswin?
Toshi MARUYAMA
scm: git: use constant value for project id in functional test....
r5576 PRJ_ID = 3
Toshi MARUYAMA
scm: git: add test of showing non ASCII contents of non ASCII path in functional test....
r5577 CHAR_1_HEX = "\xc3\x9c"
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222
def setup
Toshi MARUYAMA
scm: git: add test of showing non ASCII contents of non ASCII path in functional test....
r5577 @ruby19_non_utf8_pass =
(RUBY_VERSION >= '1.9' && Encoding.default_external.to_s != 'UTF-8')
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 @controller = RepositoriesController.new
@request = ActionController::TestRequest.new
@response = ActionController::TestResponse.new
User.current = nil
Toshi MARUYAMA
scm: git: fix PortgreSQL functional test fails (#5251)....
r4950 @repository = Repository::Git.create(
:project => Project.find(3),
:url => REPOSITORY_PATH,
:path_encoding => 'ISO-8859-1'
)
Toshi MARUYAMA
scm: add compatible functional test fof changing diff revisions label at SCM adapter level....
r4545 assert @repository
Toshi MARUYAMA
scm: git: add test of showing non ASCII contents of non ASCII path in functional test....
r5577 @char_1 = CHAR_1_HEX.dup
if @char_1.respond_to?(:force_encoding)
@char_1.force_encoding('UTF-8')
end
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 end
Toshi MARUYAMA
scm: add compatible functional test fof changing diff revisions label at SCM adapter level....
r4545
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 if File.directory?(REPOSITORY_PATH)
def test_browse_root
Toshi MARUYAMA
scm: git: check entries and changesets size are greater than 0 in browse test in functional test....
r5000 @repository.fetch_changesets
@repository.reload
Toshi MARUYAMA
scm: git: use constant value for project id in functional test....
r5576 get :show, :id => PRJ_ID
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 assert_response :success
Eric Davis
Added branch and tag support to the git repository viewer. (#1406)...
r2735 assert_template 'show'
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 assert_not_nil assigns(:entries)
Eric Davis
Support leading and trailing spaces in filenames or directories in the git adapter. #6499...
r4075 assert_equal 9, assigns(:entries).size
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 assert assigns(:entries).detect {|e| e.name == 'images' && e.kind == 'dir'}
Eric Davis
Extend changes.path and changes.from_path to support longer paths. #5771...
r3714 assert assigns(:entries).detect {|e| e.name == 'this_is_a_really_long_and_verbose_directory_name' && e.kind == 'dir'}
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 assert assigns(:entries).detect {|e| e.name == 'sources' && e.kind == 'dir'}
assert assigns(:entries).detect {|e| e.name == 'README' && e.kind == 'file'}
Eric Davis
Added branch and tag support to the git repository viewer. (#1406)...
r2735 assert assigns(:entries).detect {|e| e.name == 'copied_README' && e.kind == 'file'}
assert assigns(:entries).detect {|e| e.name == 'new_file.txt' && e.kind == 'file'}
assert assigns(:entries).detect {|e| e.name == 'renamed_test.txt' && e.kind == 'file'}
Eric Davis
Support spaces in the files or directories in the git adapter. #6054...
r4074 assert assigns(:entries).detect {|e| e.name == 'filemane with spaces.txt' && e.kind == 'file'}
Eric Davis
Support leading and trailing spaces in filenames or directories in the git adapter. #6499...
r4075 assert assigns(:entries).detect {|e| e.name == ' filename with a leading space.txt ' && e.kind == 'file'}
Toshi MARUYAMA
scm: git: check entries and changesets size are greater than 0 in browse test in functional test....
r5000 assert_not_nil assigns(:changesets)
assigns(:changesets).size > 0
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 end
Eric Davis
Added branch and tag support to the git repository viewer. (#1406)...
r2735
def test_browse_branch
Toshi MARUYAMA
scm: git: check entries and changesets size are greater than 0 in browse test in functional test....
r5000 @repository.fetch_changesets
@repository.reload
Toshi MARUYAMA
scm: git: use constant value for project id in functional test....
r5576 get :show, :id => PRJ_ID, :rev => 'test_branch'
Eric Davis
Added branch and tag support to the git repository viewer. (#1406)...
r2735 assert_response :success
assert_template 'show'
assert_not_nil assigns(:entries)
assert_equal 4, assigns(:entries).size
assert assigns(:entries).detect {|e| e.name == 'images' && e.kind == 'dir'}
assert assigns(:entries).detect {|e| e.name == 'sources' && e.kind == 'dir'}
assert assigns(:entries).detect {|e| e.name == 'README' && e.kind == 'file'}
assert assigns(:entries).detect {|e| e.name == 'test.txt' && e.kind == 'file'}
Toshi MARUYAMA
scm: git: check entries and changesets size are greater than 0 in browse test in functional test....
r5000 assert_not_nil assigns(:changesets)
assigns(:changesets).size > 0
Eric Davis
Added branch and tag support to the git repository viewer. (#1406)...
r2735 end
Toshi MARUYAMA
scm: git: add browsing tag test in functional test....
r5001 def test_browse_tag
@repository.fetch_changesets
@repository.reload
[
"tag00.lightweight",
"tag01.annotated",
].each do |t1|
Toshi MARUYAMA
scm: git: use constant value for project id in functional test....
r5576 get :show, :id => PRJ_ID, :rev => t1
Toshi MARUYAMA
scm: git: add browsing tag test in functional test....
r5001 assert_response :success
assert_template 'show'
assert_not_nil assigns(:entries)
assigns(:entries).size > 0
assert_not_nil assigns(:changesets)
assigns(:changesets).size > 0
end
end
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 def test_browse_directory
Toshi MARUYAMA
scm: git: check entries and changesets size are greater than 0 in browse test in functional test....
r5000 @repository.fetch_changesets
@repository.reload
Toshi MARUYAMA
scm: git: use constant value for project id in functional test....
r5576 get :show, :id => PRJ_ID, :path => ['images']
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 assert_response :success
Eric Davis
Added branch and tag support to the git repository viewer. (#1406)...
r2735 assert_template 'show'
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 assert_not_nil assigns(:entries)
Eric Davis
Added branch and tag support to the git repository viewer. (#1406)...
r2735 assert_equal ['edit.png'], assigns(:entries).collect(&:name)
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 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
Toshi MARUYAMA
scm: git: check entries and changesets size are greater than 0 in browse test in functional test....
r5000 assert_not_nil assigns(:changesets)
assigns(:changesets).size > 0
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 end
Toshi MARUYAMA
scm: git: code clean up functional test....
r4999
Jean-Philippe Lang
Fix repository browsing at given revision for various scm and add tests for this....
r1314 def test_browse_at_given_revision
Toshi MARUYAMA
scm: git: check entries and changesets size are greater than 0 in browse test in functional test....
r5000 @repository.fetch_changesets
@repository.reload
Toshi MARUYAMA
scm: git: use constant value for project id in functional test....
r5576 get :show, :id => PRJ_ID, :path => ['images'],
:rev => '7234cb2750b63f47bff735edc50a1c0a433c2518'
Jean-Philippe Lang
Fix repository browsing at given revision for various scm and add tests for this....
r1314 assert_response :success
Eric Davis
Added branch and tag support to the git repository viewer. (#1406)...
r2735 assert_template 'show'
Jean-Philippe Lang
Fix repository browsing at given revision for various scm and add tests for this....
r1314 assert_not_nil assigns(:entries)
assert_equal ['delete.png'], assigns(:entries).collect(&:name)
Toshi MARUYAMA
scm: git: check entries and changesets size are greater than 0 in browse test in functional test....
r5000 assert_not_nil assigns(:changesets)
assigns(:changesets).size > 0
Jean-Philippe Lang
Fix repository browsing at given revision for various scm and add tests for this....
r1314 end
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 def test_changes
Toshi MARUYAMA
scm: git: use constant value for project id in functional test....
r5576 get :changes, :id => PRJ_ID, :path => ['images', 'edit.png']
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 assert_response :success
assert_template 'changes'
assert_tag :tag => 'h2', :content => 'edit.png'
end
Toshi MARUYAMA
scm: git: code clean up functional test....
r4999
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 def test_entry_show
Toshi MARUYAMA
scm: git: use constant value for project id in functional test....
r5576 get :entry, :id => PRJ_ID, :path => ['sources', 'watchers_controller.rb']
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 assert_response :success
assert_template 'entry'
# Line 19
assert_tag :tag => 'th',
Toshi MARUYAMA
scm: git: more strict functional test....
r5333 :content => '11',
:attributes => { :class => 'line-num' },
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 :sibling => { :tag => 'td', :content => /WITHOUT ANY WARRANTY/ }
end
Toshi MARUYAMA
scm: git: code clean up functional test....
r4999
Toshi MARUYAMA
scm: git: add test of showing non ASCII contents of non ASCII path in functional test....
r5577 def test_entry_show_latin_1
if @ruby19_non_utf8_pass
puts_ruby19_non_utf8_pass()
else
with_settings :repositories_encodings => 'UTF-8,ISO-8859-1' do
['57ca437c', '57ca437c0acbbcb749821fdf3726a1367056d364'].each do |r1|
get :entry, :id => PRJ_ID,
:path => ['latin-1-dir', "test-#{@char_1}.txt"], :rev => r1
assert_response :success
assert_template 'entry'
assert_tag :tag => 'th',
:content => '1',
:attributes => { :class => 'line-num' },
:sibling => { :tag => 'td',
:content => /test-#{@char_1}.txt/ }
end
end
end
end
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 def test_entry_download
Toshi MARUYAMA
scm: git: use constant value for project id in functional test....
r5576 get :entry, :id => PRJ_ID, :path => ['sources', 'watchers_controller.rb'],
:format => 'raw'
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 assert_response :success
# File content
assert @response.body.include?('WITHOUT ANY WARRANTY')
end
Toshi MARUYAMA
scm: git: code clean up functional test....
r4999
Jean-Philippe Lang
Fixed: Links to repository directories don't work (#1119)....
r1350 def test_directory_entry
Toshi MARUYAMA
scm: git: use constant value for project id in functional test....
r5576 get :entry, :id => PRJ_ID, :path => ['sources']
Jean-Philippe Lang
Fixed: Links to repository directories don't work (#1119)....
r1350 assert_response :success
Eric Davis
Added branch and tag support to the git repository viewer. (#1406)...
r2735 assert_template 'show'
Jean-Philippe Lang
Fixed: Links to repository directories don't work (#1119)....
r1350 assert_not_nil assigns(:entry)
assert_equal 'sources', assigns(:entry).name
end
Toshi MARUYAMA
scm: add compatible functional test fof changing diff revisions label at SCM adapter level....
r4545
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 def test_diff
Toshi MARUYAMA
scm: add compatible functional test fof changing diff revisions label at SCM adapter level....
r4545 @repository.fetch_changesets
@repository.reload
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 # Full diff of changeset 2f9c0091
Toshi MARUYAMA
scm: git: use constant value for project id in functional test....
r5576 get :diff, :id => PRJ_ID, :rev => '2f9c0091c754a91af7a9c478e36556b4bde8dcf7'
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 assert_response :success
assert_template 'diff'
# Line 22 removed
assert_tag :tag => 'th',
:content => /22/,
Toshi MARUYAMA
scm: git: remove trailing white-spaces from functional test....
r5573 :sibling => { :tag => 'td',
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 :attributes => { :class => /diff_out/ },
:content => /def remove/ }
Toshi MARUYAMA
scm: add compatible functional test fof changing diff revisions label at SCM adapter level....
r4545 assert_tag :tag => 'h2', :content => /2f9c0091/
end
def test_diff_two_revs
@repository.fetch_changesets
@repository.reload
Toshi MARUYAMA
scm: git: use constant value for project id in functional test....
r5576 get :diff, :id => PRJ_ID,
:rev => '61b685fbe55ab05b5ac68402d5720c1a6ac973d1',
:rev_to => '2f9c0091c754a91af7a9c478e36556b4bde8dcf7'
Toshi MARUYAMA
scm: add compatible functional test fof changing diff revisions label at SCM adapter level....
r4545 assert_response :success
assert_template 'diff'
diff = assigns(:diff)
assert_not_nil diff
assert_tag :tag => 'h2', :content => /2f9c0091:61b685fb/
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 end
def test_annotate
Toshi MARUYAMA
scm: git: use constant value for project id in functional test....
r5576 get :annotate, :id => PRJ_ID, :path => ['sources', 'watchers_controller.rb']
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 assert_response :success
assert_template 'annotate'
# Line 23, changeset 2f9c0091
Toshi MARUYAMA
scm: git: more strict functional test....
r5333 assert_tag :tag => 'th', :content => '24',
:sibling => {
:tag => 'td',
:child => {
:tag => 'a',
:content => /2f9c0091c754a91af7a9c478e36556b4bde8dcf7/
}
},
Toshi MARUYAMA
scm: git: fix functional annotate test....
r5574 :sibling => { :tag => 'td', :content => /jsmith/ }
assert_tag :tag => 'th', :content => '24',
:sibling => {
:tag => 'td',
:child => {
:tag => 'a',
:content => /2f9c0091c754a91af7a9c478e36556b4bde8dcf7/
}
},
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 :sibling => { :tag => 'td', :content => /watcher =/ }
end
Toshi MARUYAMA
scm: add compatible functional test fof changing diff revisions label at SCM adapter level....
r4545
Toshi MARUYAMA
scm: functional test of using format_revision() for annotate (#3724)....
r4614 def test_annotate_at_given_revision
@repository.fetch_changesets
@repository.reload
Toshi MARUYAMA
scm: git: use constant value for project id in functional test....
r5576 get :annotate, :id => PRJ_ID, :rev => 'deff7',
:path => ['sources', 'watchers_controller.rb']
Toshi MARUYAMA
scm: functional test of using format_revision() for annotate (#3724)....
r4614 assert_response :success
assert_template 'annotate'
assert_tag :tag => 'h2', :content => /@ deff712f/
end
Jean-Philippe Lang
Always show 'View' and 'Annotate' links on repository files (download will be forced when clicking 'View' if the file is binary)....
r1259 def test_annotate_binary_file
Toshi MARUYAMA
scm: git: use constant value for project id in functional test....
r5576 get :annotate, :id => PRJ_ID, :path => ['images', 'edit.png']
Jean-Philippe Lang
Always show 'View' and 'Annotate' links on repository files (download will be forced when clicking 'View' if the file is binary)....
r1259 assert_response 500
Eric Davis
Fix the tests that were broken by r4286:...
r4175 assert_tag :tag => 'p', :attributes => { :id => /errorExplanation/ },
Toshi MARUYAMA
scm: git: fix annotate test due to changing en.yml (#8035, #7855)....
r5148 :content => /cannot be annotated/
Jean-Philippe Lang
Always show 'View' and 'Annotate' links on repository files (download will be forced when clicking 'View' if the file is binary)....
r1259 end
Toshi MARUYAMA
scm: fix error on revision page for empty revision (#7307)....
r4583
def test_revision
@repository.fetch_changesets
@repository.reload
['61b685fbe55ab05b5ac68402d5720c1a6ac973d1', '61b685f'].each do |r|
Toshi MARUYAMA
scm: git: use constant value for project id in functional test....
r5576 get :revision, :id => PRJ_ID, :rev => r
Toshi MARUYAMA
scm: fix error on revision page for empty revision (#7307)....
r4583 assert_response :success
assert_template 'revision'
end
end
def test_empty_revision
@repository.fetch_changesets
@repository.reload
['', ' ', nil].each do |r|
Toshi MARUYAMA
scm: git: use constant value for project id in functional test....
r5576 get :revision, :id => PRJ_ID, :rev => r
Jean-Philippe Lang
Respond with 404 instead of 500 when revision/entry is not found in the repository (#7307)....
r4590 assert_response 404
Toshi MARUYAMA
scm: fix error on revision page for empty revision (#7307)....
r4583 assert_error_tag :content => /was not found/
end
end
Toshi MARUYAMA
scm: git: add test of showing non ASCII contents of non ASCII path in functional test....
r5577
private
def puts_ruby19_non_utf8_pass
puts "TODO: This test fails in Ruby 1.9 " +
"and Encoding.default_external is not UTF-8. " +
"Current value is '#{Encoding.default_external.to_s}'"
end
Jean-Philippe Lang
Merged Git support branch (r1200 to r1226)....
r1222 else
puts "Git test repository NOT FOUND. Skipping functional tests !!!"
def test_fake; assert true end
end
end