diff test/functional/.svn/text-base/attachments_controller_test.rb.svn-base @ 441:cbce1fd3b1b7 redmine-1.2

Update to Redmine 1.2-stable branch (Redmine SVN rev 6000)
author Chris Cannam
date Mon, 06 Jun 2011 14:24:13 +0100
parents 8661b858af72
children 753f1380d6bc
line wrap: on
line diff
--- a/test/functional/.svn/text-base/attachments_controller_test.rb.svn-base	Thu Mar 03 11:42:28 2011 +0000
+++ b/test/functional/.svn/text-base/attachments_controller_test.rb.svn-base	Mon Jun 06 14:24:13 2011 +0100
@@ -7,12 +7,12 @@
 # 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.
@@ -27,7 +27,7 @@
 class AttachmentsControllerTest < ActionController::TestCase
   fixtures :users, :projects, :roles, :members, :member_roles, :enabled_modules, :issues, :trackers, :attachments,
            :versions, :wiki_pages, :wikis, :documents
-  
+
   def setup
     @controller = AttachmentsController.new
     @request    = ActionController::TestRequest.new
@@ -35,13 +35,13 @@
     Attachment.storage_path = "#{RAILS_ROOT}/test/fixtures/files"
     User.current = nil
   end
-  
+
   def test_show_diff
     get :show, :id => 14 # 060719210727_changeset_utf8.diff
     assert_response :success
     assert_template 'diff'
     assert_equal 'text/html', @response.content_type
-    
+
     assert_tag 'th',
       :attributes => {:class => /filename/},
       :content => /issues_controller.rb\t\(révision 1484\)/
@@ -49,13 +49,13 @@
       :attributes => {:class => /line-code/},
       :content => /Demande créée avec succès/
   end
-  
+
   def test_show_diff_should_strip_non_utf8_content
     get :show, :id => 5 # 060719210727_changeset_iso8859-1.diff
     assert_response :success
     assert_template 'diff'
     assert_equal 'text/html', @response.content_type
-    
+
     assert_tag 'th',
       :attributes => {:class => /filename/},
       :content => /issues_controller.rb\t\(rvision 1484\)/
@@ -63,57 +63,69 @@
       :attributes => {:class => /line-code/},
       :content => /Demande cre avec succs/
   end
-  
+
   def test_show_text_file
     get :show, :id => 4
     assert_response :success
     assert_template 'file'
     assert_equal 'text/html', @response.content_type
   end
-  
+
   def test_show_text_file_should_send_if_too_big
     Setting.file_max_size_displayed = 512
     Attachment.find(4).update_attribute :filesize, 754.kilobyte
-    
+
     get :show, :id => 4
     assert_response :success
     assert_equal 'application/x-ruby', @response.content_type
   end
-  
+
   def test_show_other
     get :show, :id => 6
     assert_response :success
     assert_equal 'application/octet-stream', @response.content_type
   end
-  
+
+  def test_show_file_from_private_issue_without_permission
+    get :show, :id => 15
+    assert_redirected_to '/login?back_url=http%3A%2F%2Ftest.host%2Fattachments%2F15'
+  end
+
+  def test_show_file_from_private_issue_with_permission
+    @request.session[:user_id] = 2
+    get :show, :id => 15
+    assert_response :success
+    assert_tag 'h2', :content => /private.diff/
+  end
+
   def test_download_text_file
     get :download, :id => 4
     assert_response :success
     assert_equal 'application/x-ruby', @response.content_type
   end
-  
+
   def test_download_should_assign_content_type_if_blank
     Attachment.find(4).update_attribute(:content_type, '')
-    
+
     get :download, :id => 4
     assert_response :success
     assert_equal 'text/x-ruby', @response.content_type
   end
-  
+
   def test_download_missing_file
     get :download, :id => 2
     assert_response 404
   end
-  
+
   def test_anonymous_on_private_private
     get :download, :id => 7
     assert_redirected_to '/login?back_url=http%3A%2F%2Ftest.host%2Fattachments%2Fdownload%2F7'
   end
-  
+
   def test_destroy_issue_attachment
     issue = Issue.find(3)
     @request.session[:user_id] = 2
-    
+
     assert_difference 'issue.attachments.count', -1 do
       post :destroy, :id => 1
     end
@@ -125,7 +137,7 @@
     assert_equal '1', j.details.first.prop_key
     assert_equal 'error281.txt', j.details.first.old_value
   end
-  
+
   def test_destroy_wiki_page_attachment
     @request.session[:user_id] = 2
     assert_difference 'Attachment.count', -1 do
@@ -133,7 +145,7 @@
       assert_response 302
     end
   end
-  
+
   def test_destroy_project_attachment
     @request.session[:user_id] = 2
     assert_difference 'Attachment.count', -1 do
@@ -141,7 +153,7 @@
       assert_response 302
     end
   end
-  
+
   def test_destroy_version_attachment
     @request.session[:user_id] = 2
     assert_difference 'Attachment.count', -1 do
@@ -149,7 +161,7 @@
       assert_response 302
     end
   end
-  
+
   def test_destroy_without_permission
     post :destroy, :id => 3
     assert_redirected_to '/login?back_url=http%3A%2F%2Ftest.host%2Fattachments%2Fdestroy%2F3'