repositories_mercurial_controller_test.rb
525 lines
| 18.7 KiB
| text/x-ruby
|
RubyLexer
|
r5563 | # Redmine - project management software | ||
|
r9453 | # Copyright (C) 2006-2012 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. | ||||
|
r5563 | # | ||
|
r978 | # 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. | ||||
|
r5563 | # | ||
|
r978 | # 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 | |||
|
r2773 | class RepositoriesMercurialControllerTest < ActionController::TestCase | ||
|
r7929 | tests RepositoriesController | ||
|
r5932 | fixtures :projects, :users, :roles, :members, :member_roles, | ||
:repositories, :enabled_modules | ||||
|
r978 | |||
|
r5932 | REPOSITORY_PATH = Rails.root.join('tmp/test/mercurial_repository').to_s | ||
|
r4880 | CHAR_1_HEX = "\xc3\x9c" | ||
|
r5566 | PRJ_ID = 3 | ||
|
r7542 | NUM_REV = 32 | ||
|
r5081 | |||
|
r5566 | ruby19_non_utf8_pass = | ||
(RUBY_VERSION >= '1.9' && Encoding.default_external.to_s != 'UTF-8') | ||||
|
r978 | |||
def setup | ||||
User.current = nil | ||||
|
r6122 | @project = Project.find(PRJ_ID) | ||
|
r4876 | @repository = Repository::Mercurial.create( | ||
|
r6122 | :project => @project, | ||
|
r4876 | :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. " + | ||||
|
r5563 | "Current value is '#{Encoding.default_external.to_s}'" | ||
|
r4880 | def test_fake; assert true end | ||
elsif File.directory?(REPOSITORY_PATH) | ||||
|
r7929 | |||
|
r8528 | def test_get_new | ||
|
r7929 | @request.session[:user_id] = 1 | ||
@project.repository.destroy | ||||
|
r8528 | get :new, :project_id => 'subproject1', :repository_scm => 'Mercurial' | ||
|
r7929 | assert_response :success | ||
|
r8528 | assert_template 'new' | ||
|
r7929 | assert_kind_of Repository::Mercurial, assigns(:repository) | ||
assert assigns(:repository).new_record? | ||||
end | ||||
|
r2735 | def test_show_root | ||
|
r7007 | assert_equal 0, @repository.changesets.count | ||
|
r5002 | @repository.fetch_changesets | ||
|
r7007 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r5081 | get :show, :id => PRJ_ID | ||
|
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) | ||
|
r6103 | assert assigns(:changesets).size > 0 | ||
|
r1006 | end | ||
|
r4598 | |||
|
r2735 | def test_show_directory | ||
|
r7008 | assert_equal 0, @repository.changesets.count | ||
|
r5002 | @repository.fetch_changesets | ||
|
r7008 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r8816 | get :show, :id => PRJ_ID, :path => repository_path_hash(['images'])[:param] | ||
|
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) | ||
|
r6103 | assert assigns(:changesets).size > 0 | ||
|
r1006 | end | ||
|
r4544 | |||
|
r2735 | def test_show_at_given_revision | ||
|
r7009 | assert_equal 0, @repository.changesets.count | ||
|
r5002 | @repository.fetch_changesets | ||
|
r7009 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r4544 | [0, '0', '0885933ad4f6'].each do |r1| | ||
|
r8816 | get :show, :id => PRJ_ID, :path => repository_path_hash(['images'])[:param], | ||
:rev => r1 | ||||
|
r4544 | 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) | ||
|
r6103 | assert assigns(:changesets).size > 0 | ||
|
r4544 | end | ||
|
r1314 | end | ||
|
r4515 | |||
def test_show_directory_sql_escape_percent | ||||
|
r7087 | assert_equal 0, @repository.changesets.count | ||
|
r5002 | @repository.fetch_changesets | ||
|
r7087 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r4544 | [13, '13', '3a330eb32958'].each do |r1| | ||
|
r8816 | get :show, :id => PRJ_ID, | ||
:path => repository_path_hash(['sql_escape', 'percent%dir'])[:param], | ||||
|
r5566 | :rev => r1 | ||
|
r4544 | assert_response :success | ||
assert_template 'show' | ||||
|
r4515 | |||
|
r4544 | assert_not_nil assigns(:entries) | ||
|
r5566 | assert_equal ['percent%file1.txt', 'percentfile1.txt'], | ||
assigns(:entries).collect(&:name) | ||||
|
r4544 | changesets = assigns(:changesets) | ||
|
r5004 | assert_not_nil changesets | ||
|
r6103 | assert assigns(:changesets).size > 0 | ||
|
r5004 | assert_equal %w(13 11 10 9), changesets.collect(&:revision) | ||
|
r4544 | end | ||
|
r4515 | end | ||
|
r5565 | def test_show_directory_latin_1_path | ||
|
r7088 | assert_equal 0, @repository.changesets.count | ||
|
r4880 | @repository.fetch_changesets | ||
|
r7088 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r4880 | [21, '21', 'adf805632193'].each do |r1| | ||
|
r8816 | get :show, :id => PRJ_ID, | ||
:path => repository_path_hash(['latin-1-dir'])[:param], | ||||
:rev => r1 | ||||
|
r4880 | 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 | ||||
|
r8558 | def show_should_show_branch_selection_form | ||
@repository.fetch_changesets | ||||
@project.reload | ||||
get :show, :id => PRJ_ID | ||||
assert_tag 'form', :attributes => {:id => 'revision_selector', :action => '/projects/subproject1/repository/show'} | ||||
assert_tag 'select', :attributes => {:name => 'branch'}, | ||||
:child => {:tag => 'option', :attributes => {:value => 'test-branch-01'}}, | ||||
:parent => {:tag => 'form', :attributes => {:id => 'revision_selector'}} | ||||
end | ||||
|
r5010 | def test_show_branch | ||
|
r7089 | assert_equal 0, @repository.changesets.count | ||
|
r5010 | @repository.fetch_changesets | ||
|
r7089 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r5010 | [ | ||
'default', | ||||
@branch_char_1, | ||||
'branch (1)[2]&,%.-3_4', | ||||
@branch_char_0, | ||||
'test_branch.latin-1', | ||||
'test-branch-00', | ||||
].each do |bra| | ||||
|
r5081 | get :show, :id => PRJ_ID, :rev => bra | ||
|
r5010 | assert_response :success | ||
assert_template 'show' | ||||
assert_not_nil assigns(:entries) | ||||
assert assigns(:entries).size > 0 | ||||
assert_not_nil assigns(:changesets) | ||||
|
r6103 | assert assigns(:changesets).size > 0 | ||
|
r5010 | end | ||
end | ||||
|
r5011 | def test_show_tag | ||
|
r7090 | assert_equal 0, @repository.changesets.count | ||
|
r5011 | @repository.fetch_changesets | ||
|
r7090 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r5011 | [ | ||
@tag_char_1, | ||||
'tag_test.00', | ||||
'tag-init-revision' | ||||
].each do |tag| | ||||
|
r5081 | get :show, :id => PRJ_ID, :rev => tag | ||
|
r5011 | assert_response :success | ||
assert_template 'show' | ||||
assert_not_nil assigns(:entries) | ||||
assert assigns(:entries).size > 0 | ||||
assert_not_nil assigns(:changesets) | ||||
|
r6103 | assert assigns(:changesets).size > 0 | ||
|
r5011 | end | ||
end | ||||
|
r1006 | def test_changes | ||
|
r8816 | get :changes, :id => PRJ_ID, | ||
:path => repository_path_hash(['images', 'edit.png'])[:param] | ||||
|
r1006 | assert_response :success | ||
assert_template 'changes' | ||||
assert_tag :tag => 'h2', :content => 'edit.png' | ||||
end | ||||
|
r5563 | |||
|
r1006 | def test_entry_show | ||
|
r8816 | get :entry, :id => PRJ_ID, | ||
:path => repository_path_hash(['sources', 'watchers_controller.rb'])[:param] | ||||
|
r1006 | 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 | |||
|
r5565 | def test_entry_show_latin_1_path | ||
|
r4880 | [21, '21', 'adf805632193'].each do |r1| | ||
|
r5565 | get :entry, :id => PRJ_ID, | ||
|
r8816 | :path => repository_path_hash(['latin-1-dir', "test-#{@char_1}-2.txt"])[:param], | ||
:rev => r1 | ||||
|
r4880 | assert_response :success | ||
assert_template 'entry' | ||||
assert_tag :tag => 'th', | ||||
:content => '1', | ||||
:attributes => { :class => 'line-num' }, | ||||
|
r5081 | :sibling => { :tag => 'td', | ||
:content => /Mercurial is a distributed version control system/ } | ||||
|
r4880 | end | ||
end | ||||
|
r5563 | |||
|
r5570 | def test_entry_show_latin_1_contents | ||
with_settings :repositories_encodings => 'UTF-8,ISO-8859-1' do | ||||
[27, '27', '7bbf4c738e71'].each do |r1| | ||||
get :entry, :id => PRJ_ID, | ||||
|
r8816 | :path => repository_path_hash(['latin-1-dir', "test-#{@char_1}.txt"])[:param], | ||
:rev => r1 | ||||
|
r5570 | 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 | ||||
|
r1006 | def test_entry_download | ||
|
r5566 | get :entry, :id => PRJ_ID, | ||
|
r8816 | :path => repository_path_hash(['sources', 'watchers_controller.rb'])[:param], | ||
:format => 'raw' | ||||
|
r1006 | assert_response :success | ||
# File content | ||||
assert @response.body.include?('WITHOUT ANY WARRANTY') | ||||
end | ||||
|
r1350 | |||
|
r5082 | def test_entry_binary_force_download | ||
|
r8816 | get :entry, :id => PRJ_ID, :rev => 1, | ||
:path => repository_path_hash(['images', 'edit.png'])[:param] | ||||
|
r5082 | assert_response :success | ||
|
r5090 | assert_equal 'image/png', @response.content_type | ||
|
r5082 | end | ||
|
r1350 | def test_directory_entry | ||
|
r8816 | get :entry, :id => PRJ_ID, | ||
:path => repository_path_hash(['sources'])[:param] | ||||
|
r1350 | assert_response :success | ||
|
r2735 | assert_template 'show' | ||
|
r1350 | assert_not_nil assigns(:entry) | ||
assert_equal 'sources', assigns(:entry).name | ||||
end | ||||
|
r5082 | |||
|
r1006 | def test_diff | ||
|
r7091 | assert_equal 0, @repository.changesets.count | ||
|
r4579 | @repository.fetch_changesets | ||
|
r7091 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r4544 | [4, '4', 'def6d2f1254a'].each do |r1| | ||
# Full diff of changeset 4 | ||||
|
r5863 | ['inline', 'sbs'].each do |dt| | ||
get :diff, :id => PRJ_ID, :rev => r1, :type => dt | ||||
assert_response :success | ||||
assert_template 'diff' | ||||
if @diff_c_support | ||||
# Line 22 removed | ||||
assert_tag :tag => 'th', | ||||
:content => '22', | ||||
:sibling => { :tag => 'td', | ||||
:attributes => { :class => /diff_out/ }, | ||||
:content => /def remove/ } | ||||
assert_tag :tag => 'h2', :content => /4:def6d2f1254a/ | ||||
end | ||||
|
r4579 | end | ||
end | ||||
end | ||||
def test_diff_two_revs | ||||
|
r7092 | assert_equal 0, @repository.changesets.count | ||
|
r4579 | @repository.fetch_changesets | ||
|
r7092 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r4579 | [2, '400bb8672109', '400', 400].each do |r1| | ||
[4, 'def6d2f1254a'].each do |r2| | ||||
|
r5864 | ['inline', 'sbs'].each do |dt| | ||
get :diff, | ||||
:id => PRJ_ID, | ||||
:rev => r1, | ||||
:rev_to => r2, | ||||
:type => dt | ||||
assert_response :success | ||||
assert_template 'diff' | ||||
diff = assigns(:diff) | ||||
assert_not_nil diff | ||||
assert_tag :tag => 'h2', | ||||
:content => /4:def6d2f1254a 2:400bb8672109/ | ||||
end | ||||
|
r4566 | end | ||
|
r4544 | end | ||
|
r1006 | end | ||
|
r4543 | |||
|
r5565 | def test_diff_latin_1_path | ||
|
r5569 | with_settings :repositories_encodings => 'UTF-8,ISO-8859-1' do | ||
[21, 'adf805632193'].each do |r1| | ||||
|
r5865 | ['inline', 'sbs'].each do |dt| | ||
get :diff, :id => PRJ_ID, :rev => r1, :type => dt | ||||
assert_response :success | ||||
assert_template 'diff' | ||||
assert_tag :tag => 'thead', | ||||
|
r5569 | :descendant => { | ||
|
r5865 | :tag => 'th', | ||
:attributes => { :class => 'filename' } , | ||||
:content => /latin-1-dir\/test-#{@char_1}-2.txt/ , | ||||
}, | ||||
:sibling => { | ||||
:tag => 'tbody', | ||||
:descendant => { | ||||
:tag => 'td', | ||||
:attributes => { :class => /diff_in/ }, | ||||
:content => /It is written in Python/ | ||||
} | ||||
|
r5569 | } | ||
|
r5865 | end | ||
|
r5569 | end | ||
|
r4880 | end | ||
end | ||||
|
r10245 | def test_diff_should_show_modified_filenames | ||
get :diff, :id => PRJ_ID, :rev => '400bb8672109', :type => 'inline' | ||||
assert_response :success | ||||
assert_template 'diff' | ||||
assert_select 'th.filename', :text => 'sources/watchers_controller.rb' | ||||
end | ||||
def test_diff_should_show_deleted_filenames | ||||
get :diff, :id => PRJ_ID, :rev => 'b3a615152df8', :type => 'inline' | ||||
assert_response :success | ||||
assert_template 'diff' | ||||
assert_select 'th.filename', :text => 'sources/welcome_controller.rb' | ||||
end | ||||
|
r1006 | def test_annotate | ||
|
r8816 | get :annotate, :id => PRJ_ID, | ||
:path => repository_path_hash(['sources', 'watchers_controller.rb'])[:param] | ||||
|
r1006 | assert_response :success | ||
assert_template 'annotate' | ||||
|
r9923 | |||
|
r9922 | # Line 22, revision 4:def6d2f1254a | ||
|
r9923 | assert_select 'tr' do | ||
assert_select 'th.line-num', :text => '22' | ||||
assert_select 'td.revision', :text => '4:def6d2f1254a' | ||||
assert_select 'td.author', :text => 'jsmith' | ||||
assert_select 'td', :text => /remove_watcher/ | ||||
end | ||||
|
r1006 | end | ||
|
r4584 | |||
|
r5921 | def test_annotate_not_in_tip | ||
|
r7093 | assert_equal 0, @repository.changesets.count | ||
|
r5921 | @repository.fetch_changesets | ||
|
r7093 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r5921 | get :annotate, :id => PRJ_ID, | ||
|
r8816 | :path => repository_path_hash(['sources', 'welcome_controller.rb'])[:param] | ||
|
r5921 | assert_response 404 | ||
assert_error_tag :content => /was not found/ | ||||
end | ||||
|
r4614 | def test_annotate_at_given_revision | ||
|
r7094 | assert_equal 0, @repository.changesets.count | ||
|
r4614 | @repository.fetch_changesets | ||
|
r7094 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r4614 | [2, '400bb8672109', '400', 400].each do |r1| | ||
|
r5566 | get :annotate, :id => PRJ_ID, :rev => r1, | ||
|
r8816 | :path => repository_path_hash(['sources', 'watchers_controller.rb'])[:param] | ||
|
r4614 | assert_response :success | ||
assert_template 'annotate' | ||||
assert_tag :tag => 'h2', :content => /@ 2:400bb8672109/ | ||||
end | ||||
end | ||||
|
r5565 | def test_annotate_latin_1_path | ||
|
r4880 | [21, '21', 'adf805632193'].each do |r1| | ||
|
r5571 | get :annotate, :id => PRJ_ID, | ||
|
r8816 | :path => repository_path_hash(['latin-1-dir', "test-#{@char_1}-2.txt"])[:param], | ||
:rev => r1 | ||||
|
r4880 | 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' }, | ||||
|
r5081 | :sibling => { :tag => 'td', | ||
:content => /Mercurial is a distributed version control system/ } | ||||
|
r4880 | |||
end | ||||
end | ||||
|
r5572 | def test_annotate_latin_1_contents | ||
with_settings :repositories_encodings => 'UTF-8,ISO-8859-1' do | ||||
[27, '7bbf4c738e71'].each do |r1| | ||||
get :annotate, :id => PRJ_ID, | ||||
|
r8816 | :path => repository_path_hash(['latin-1-dir', "test-#{@char_1}.txt"])[:param], | ||
:rev => r1 | ||||
|
r5572 | assert_tag :tag => 'th', | ||
:content => '1', | ||||
:attributes => { :class => 'line-num' }, | ||||
:sibling => { :tag => 'td', | ||||
:content => /test-#{@char_1}.txt/ } | ||||
end | ||||
end | ||||
end | ||||
|
r4584 | def test_empty_revision | ||
|
r7095 | assert_equal 0, @repository.changesets.count | ||
|
r4584 | @repository.fetch_changesets | ||
|
r7095 | @project.reload | ||
assert_equal NUM_REV, @repository.changesets.count | ||||
|
r4584 | ['', ' ', nil].each do |r| | ||
|
r5081 | get :revision, :id => PRJ_ID, :rev => r | ||
|
r4590 | assert_response 404 | ||
|
r4584 | assert_error_tag :content => /was not found/ | ||
end | ||||
end | ||||
|
r6123 | |||
def test_destroy_valid_repository | ||||
@request.session[:user_id] = 1 # admin | ||||
|
r7085 | assert_equal 0, @repository.changesets.count | ||
|
r6123 | @repository.fetch_changesets | ||
|
r7085 | assert_equal NUM_REV, @repository.changesets.count | ||
|
r6123 | |||
|
r8528 | assert_difference 'Repository.count', -1 do | ||
delete :destroy, :id => @repository.id | ||||
end | ||||
|
r6123 | assert_response 302 | ||
@project.reload | ||||
assert_nil @project.repository | ||||
end | ||||
|
r6127 | |||
def test_destroy_invalid_repository | ||||
@request.session[:user_id] = 1 # admin | ||||
|
r8528 | @project.repository.destroy | ||
@repository = Repository::Mercurial.create!( | ||||
|
r6127 | :project => Project.find(PRJ_ID), | ||
:url => "/invalid", | ||||
:path_encoding => 'ISO-8859-1' | ||||
) | ||||
@repository.fetch_changesets | ||||
assert_equal 0, @repository.changesets.count | ||||
|
r8528 | assert_difference 'Repository.count', -1 do | ||
delete :destroy, :id => @repository.id | ||||
end | ||||
|
r6127 | assert_response 302 | ||
@project.reload | ||||
assert_nil @project.repository | ||||
end | ||||
|
r1006 | else | ||
puts "Mercurial test repository NOT FOUND. Skipping functional tests !!!" | ||||
def test_fake; assert true end | ||||
|
r978 | end | ||
end | ||||