##// END OF EJS Templates
Fixed notes preview in issue history broken and hidden by a broken test....
Etienne Massip -
r10747:2304f5d42c2b
parent child
Show More
@@ -1,54 +1,55
1 # Redmine - project management software
1 # Redmine - project management software
2 # Copyright (C) 2006-2012 Jean-Philippe Lang
2 # Copyright (C) 2006-2012 Jean-Philippe Lang
3 #
3 #
4 # This program is free software; you can redistribute it and/or
4 # This program is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU General Public License
5 # modify it under the terms of the GNU General Public License
6 # as published by the Free Software Foundation; either version 2
6 # as published by the Free Software Foundation; either version 2
7 # of the License, or (at your option) any later version.
7 # of the License, or (at your option) any later version.
8 #
8 #
9 # This program is distributed in the hope that it will be useful,
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU General Public License for more details.
12 # GNU General Public License for more details.
13 #
13 #
14 # You should have received a copy of the GNU General Public License
14 # You should have received a copy of the GNU General Public License
15 # along with this program; if not, write to the Free Software
15 # along with this program; if not, write to the Free Software
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17
17
18 class PreviewsController < ApplicationController
18 class PreviewsController < ApplicationController
19 before_filter :find_project
19 before_filter :find_project
20
20
21 def issue
21 def issue
22 @issue = @project.issues.find_by_id(params[:id]) unless params[:id].blank?
22 @issue = @project.issues.find_by_id(params[:id]) unless params[:id].blank?
23 if @issue
23 if @issue
24 @attachements = @issue.attachments
24 @attachements = @issue.attachments
25 @description = params[:issue] && params[:issue][:description]
25 @description = params[:issue] && params[:issue][:description]
26 if @description && @description.gsub(/(\r?\n|\n\r?)/, "\n") == @issue.description.to_s.gsub(/(\r?\n|\n\r?)/, "\n")
26 if @description && @description.gsub(/(\r?\n|\n\r?)/, "\n") == @issue.description.to_s.gsub(/(\r?\n|\n\r?)/, "\n")
27 @description = nil
27 @description = nil
28 end
28 end
29 @notes = (params[:issue] ? params[:issue][:notes] : nil)
29 # params[:notes] is useful for preview of notes in issue history
30 @notes = params[:notes] || (params[:issue] ? params[:issue][:notes] : nil)
30 else
31 else
31 @description = (params[:issue] ? params[:issue][:description] : nil)
32 @description = (params[:issue] ? params[:issue][:description] : nil)
32 end
33 end
33 render :layout => false
34 render :layout => false
34 end
35 end
35
36
36 def news
37 def news
37 if params[:id].present? && news = News.visible.find_by_id(params[:id])
38 if params[:id].present? && news = News.visible.find_by_id(params[:id])
38 @previewed = news
39 @previewed = news
39 @attachments = news.attachments
40 @attachments = news.attachments
40 end
41 end
41 @text = (params[:news] ? params[:news][:description] : nil)
42 @text = (params[:news] ? params[:news][:description] : nil)
42 render :partial => 'common/preview'
43 render :partial => 'common/preview'
43 end
44 end
44
45
45 private
46 private
46
47
47 def find_project
48 def find_project
48 project_id = (params[:issue] && params[:issue][:project_id]) || params[:project_id]
49 project_id = (params[:issue] && params[:issue][:project_id]) || params[:project_id]
49 @project = Project.find(project_id)
50 @project = Project.find(project_id)
50 rescue ActiveRecord::RecordNotFound
51 rescue ActiveRecord::RecordNotFound
51 render_404
52 render_404
52 end
53 end
53
54
54 end
55 end
@@ -1,82 +1,82
1 # Redmine - project management software
1 # Redmine - project management software
2 # Copyright (C) 2006-2012 Jean-Philippe Lang
2 # Copyright (C) 2006-2012 Jean-Philippe Lang
3 #
3 #
4 # This program is free software; you can redistribute it and/or
4 # This program is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU General Public License
5 # modify it under the terms of the GNU General Public License
6 # as published by the Free Software Foundation; either version 2
6 # as published by the Free Software Foundation; either version 2
7 # of the License, or (at your option) any later version.
7 # of the License, or (at your option) any later version.
8 #
8 #
9 # This program is distributed in the hope that it will be useful,
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU General Public License for more details.
12 # GNU General Public License for more details.
13 #
13 #
14 # You should have received a copy of the GNU General Public License
14 # You should have received a copy of the GNU General Public License
15 # along with this program; if not, write to the Free Software
15 # along with this program; if not, write to the Free Software
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17
17
18 require File.expand_path('../../test_helper', __FILE__)
18 require File.expand_path('../../test_helper', __FILE__)
19
19
20 class PreviewsControllerTest < ActionController::TestCase
20 class PreviewsControllerTest < ActionController::TestCase
21 fixtures :projects, :trackers, :issue_statuses, :issues,
21 fixtures :projects, :trackers, :issue_statuses, :issues,
22 :enumerations, :users, :issue_categories,
22 :enumerations, :users, :issue_categories,
23 :projects_trackers,
23 :projects_trackers,
24 :roles,
24 :roles,
25 :member_roles,
25 :member_roles,
26 :members,
26 :members,
27 :enabled_modules,
27 :enabled_modules,
28 :workflows,
28 :workflows,
29 :journals, :journal_details,
29 :journals, :journal_details,
30 :news
30 :news
31
31
32 def test_preview_new_issue
32 def test_preview_new_issue
33 @request.session[:user_id] = 2
33 @request.session[:user_id] = 2
34 post :issue, :project_id => '1', :issue => {:description => 'Foo'}
34 post :issue, :project_id => '1', :issue => {:description => 'Foo'}
35 assert_response :success
35 assert_response :success
36 assert_template 'preview'
36 assert_template 'preview'
37 assert_not_nil assigns(:description)
37 assert_not_nil assigns(:description)
38 end
38 end
39
39
40 def test_preview_issue_notes
40 def test_preview_issue_notes
41 @request.session[:user_id] = 2
41 @request.session[:user_id] = 2
42 post :issue, :project_id => '1', :id => 1,
42 post :issue, :project_id => '1', :id => 1,
43 :issue => {:description => Issue.find(1).description, :notes => 'Foo'}
43 :issue => {:description => Issue.find(1).description, :notes => 'Foo'}
44 assert_response :success
44 assert_response :success
45 assert_template 'preview'
45 assert_template 'preview'
46 assert_not_nil assigns(:notes)
46 assert_not_nil assigns(:notes)
47 end
47 end
48
48
49 def test_preview_journal_notes_for_update
49 def test_preview_journal_notes_for_update
50 @request.session[:user_id] = 2
50 @request.session[:user_id] = 2
51 post :issue, :project_id => '1', :id => 1, :issue => {:notes => 'Foo'}
51 post :issue, :project_id => '1', :id => 1, :notes => 'Foo'
52 assert_response :success
52 assert_response :success
53 assert_template 'preview'
53 assert_template 'preview'
54 assert_not_nil assigns(:notes)
54 assert_not_nil assigns(:notes)
55 assert_tag :p, :content => 'Foo'
55 assert_tag :p, :content => 'Foo'
56 end
56 end
57
57
58 def test_preview_new_news
58 def test_preview_new_news
59 get :news, :project_id => 1,
59 get :news, :project_id => 1,
60 :news => {:title => '',
60 :news => {:title => '',
61 :description => 'News description',
61 :description => 'News description',
62 :summary => ''}
62 :summary => ''}
63 assert_response :success
63 assert_response :success
64 assert_template 'common/_preview'
64 assert_template 'common/_preview'
65 assert_tag :tag => 'fieldset', :attributes => { :class => 'preview' },
65 assert_tag :tag => 'fieldset', :attributes => { :class => 'preview' },
66 :content => /News description/
66 :content => /News description/
67 end
67 end
68
68
69 def test_existing_new_news
69 def test_existing_new_news
70 get :news, :project_id => 1, :id => 2,
70 get :news, :project_id => 1, :id => 2,
71 :news => {:title => '',
71 :news => {:title => '',
72 :description => 'News description',
72 :description => 'News description',
73 :summary => ''}
73 :summary => ''}
74 assert_response :success
74 assert_response :success
75 assert_template 'common/_preview'
75 assert_template 'common/_preview'
76 assert_equal News.find(2), assigns(:previewed)
76 assert_equal News.find(2), assigns(:previewed)
77 assert_not_nil assigns(:attachments)
77 assert_not_nil assigns(:attachments)
78
78
79 assert_tag :tag => 'fieldset', :attributes => { :class => 'preview' },
79 assert_tag :tag => 'fieldset', :attributes => { :class => 'preview' },
80 :content => /News description/
80 :content => /News description/
81 end
81 end
82 end
82 end
General Comments 0
You need to be logged in to leave comments. Login now