Feature #33167 ยป feature-33167.patch
| app/controllers/news_controller.rb | ||
|---|---|---|
| 22 | 22 |
model_object News |
| 23 | 23 |
before_action :find_model_object, :except => [:new, :create, :index] |
| 24 | 24 |
before_action :find_project_from_association, :except => [:new, :create, :index] |
| 25 |
before_action :find_project_by_project_id, :only => [:new, :create]
|
|
| 26 |
before_action :authorize, :except => [:index] |
|
| 27 |
before_action :find_optional_project, :only => :index
|
|
| 25 |
before_action :find_project_by_project_id, :only => :create
|
|
| 26 |
before_action :authorize, :except => [:index, :new]
|
|
| 27 |
before_action :find_optional_project, :only => [:index, :new]
|
|
| 28 | 28 |
accept_rss_auth :index |
| 29 | 29 |
accept_api_auth :index, :show, :create, :update, :destroy |
| 30 | 30 | |
| ... | ... | |
| 65 | 65 |
end |
| 66 | 66 | |
| 67 | 67 |
def new |
| 68 |
unless User.current.allowed_to?(:manage_news, @project, :global => true) |
|
| 69 |
raise ::Unauthorized |
|
| 70 |
end |
|
| 68 | 71 |
@news = News.new(:project => @project, :author => User.current) |
| 69 | 72 |
end |
| 70 | 73 | |
| ... | ... | |
| 77 | 80 |
format.html {
|
| 78 | 81 |
render_attachment_warning_if_needed(@news) |
| 79 | 82 |
flash[:notice] = l(:notice_successful_create) |
| 80 |
redirect_to project_news_index_path(@project) |
|
| 83 |
redirect_to params[:cross_project] ? news_index_path : project_news_index_path(@project)
|
|
| 81 | 84 |
} |
| 82 | 85 |
format.api { render_api_ok }
|
| 83 | 86 |
end |
| app/views/news/_form.html.erb | ||
|---|---|---|
| 1 | 1 |
<%= error_messages_for @news %> |
| 2 | 2 | |
| 3 | 3 |
<div class="box tabular"> |
| 4 |
<% if @project.nil? %> |
|
| 5 |
<p> |
|
| 6 |
<label><%= l(:field_project) %> <span class="required">*</span></label> |
|
| 7 |
<%= select_tag :project_id, options_for_select(project_tree_options_for_select(Project.allowed_to(:manage_news).to_a), Project.allowed_to(:manage_news).first), {:required => true} %>
|
|
| 8 |
<%= hidden_field_tag :cross_project, 1, id: nil %> |
|
| 9 |
</p> |
|
| 10 |
<% end %> |
|
| 4 | 11 |
<p><%= f.text_field :title, :required => true, :size => 60 %></p> |
| 5 | 12 |
<p><%= f.text_area :summary, :cols => 60, :rows => 2 %></p> |
| 6 | 13 |
<p><%= f.text_area :description, :required => true, :cols => 60, :rows => 15, :class => 'wiki-edit', |
| app/views/news/index.html.erb | ||
|---|---|---|
| 1 | 1 |
<div class="contextual"> |
| 2 | 2 |
<%= link_to(l(:label_news_new), |
| 3 |
new_project_news_path(@project),
|
|
| 3 |
(@project ? project_news_index_path(@project) : news_index_path),
|
|
| 4 | 4 |
:class => 'icon icon-add', |
| 5 |
:onclick => 'showAndScrollTo("add-news", "news_title"); return false;') if @project && User.current.allowed_to?(:manage_news, @project) %>
|
|
| 5 |
:onclick => 'showAndScrollTo("add-news", "news_title"); return false;') if (@project.nil? || (@project && User.current.allowed_to?(:manage_news, @project))) %>
|
|
| 6 | 6 |
<%= watcher_link(@project.enabled_module('news'), User.current) if @project && User.current.logged? %>
|
| 7 | 7 |
</div> |
| 8 | 8 | |
| 9 | 9 |
<div id="add-news" style="display:none;"> |
| 10 | 10 |
<h2><%=l(:label_news_new)%></h2> |
| 11 |
<%= labelled_form_for @news, :url => project_news_index_path(@project),
|
|
| 11 |
<%= labelled_form_for @news, :url => (@project ? project_news_index_path(@project) : news_index_path),
|
|
| 12 | 12 |
:html => { :id => 'news-form', :multipart => true } do |f| %>
|
| 13 | 13 |
<%= render :partial => 'news/form', :locals => { :f => f } %>
|
| 14 | 14 |
<%= submit_tag l(:button_create) %> |
| 15 | 15 |
<%= link_to l(:button_cancel), "#", :onclick => '$("#add-news").hide()' %>
|
| 16 |
<% end if @project %>
|
|
| 16 |
<% end %> |
|
| 17 | 17 |
</div> |
| 18 | 18 | |
| 19 | 19 |
<h2><%=l(:label_news_plural)%></h2> |
| app/views/news/new.html.erb | ||
|---|---|---|
| 1 | 1 |
<h2><%=l(:label_news_new)%></h2> |
| 2 | 2 | |
| 3 |
<%= labelled_form_for @news, :url => project_news_index_path(@project),
|
|
| 3 |
<%= labelled_form_for @news, :url => (@project ? project_news_index_path(@project) : news_index_path),
|
|
| 4 | 4 |
:html => { :id => 'news-form', :multipart => true } do |f| %>
|
| 5 | 5 |
<%= render :partial => 'news/form', :locals => { :f => f } %>
|
| 6 | 6 |
<%= submit_tag l(:button_create) %> |
| config/routes.rb | ||
|---|---|---|
| 206 | 206 |
resources :queries, :except => [:show] |
| 207 | 207 |
get '/queries/filter', :to => 'queries#filter', :as => 'queries_filter' |
| 208 | 208 | |
| 209 |
resources :news, :only => [:index, :show, :edit, :update, :destroy] |
|
| 209 |
resources :news, :only => [:index, :show, :edit, :update, :destroy, :create, :new]
|
|
| 210 | 210 |
match '/news/:id/comments', :to => 'comments#create', :via => :post |
| 211 | 211 |
match '/news/:id/comments/:comment_id', :to => 'comments#destroy', :via => :delete |
| 212 | 212 | |
| test/functional/news_controller_test.rb | ||
|---|---|---|
| 87 | 87 |
assert_response 404 |
| 88 | 88 |
end |
| 89 | 89 | |
| 90 |
def test_get_new |
|
| 90 |
def test_get_new_with_project_id
|
|
| 91 | 91 |
@request.session[:user_id] = 2 |
| 92 | 92 |
get(:new, :params => {:project_id => 1})
|
| 93 | 93 |
assert_response :success |
| 94 |
assert_select 'select[name=project_id]', false |
|
| 94 | 95 |
assert_select 'input[name=?]', 'news[title]' |
| 95 | 96 |
end |
| 96 | 97 | |
| 98 |
def test_get_new_without_project_id |
|
| 99 |
@request.session[:user_id] = 2 |
|
| 100 |
get(:new) |
|
| 101 |
assert_response :success |
|
| 102 |
assert_select 'select[name=project_id]' |
|
| 103 |
assert_select 'input[name=?]', 'news[title]' |
|
| 104 |
end |
|
| 105 | ||
| 106 |
def test_get_new_if_user_does_not_have_permission |
|
| 107 |
@request.session[:user_id] = 2 |
|
| 108 |
User.find(2).roles.each{|u| u.remove_permission! :manage_news }
|
|
| 109 | ||
| 110 |
get(:new) |
|
| 111 |
assert_response :forbidden |
|
| 112 |
assert_select 'select[name=project_id]', false |
|
| 113 |
assert_select 'input[name=?]', 'news[title]', count: 0 |
|
| 114 |
end |
|
| 115 | ||
| 97 | 116 |
def test_post_create |
| 98 | 117 |
ActionMailer::Base.deliveries.clear |
| 99 | 118 |
@request.session[:user_id] = 2 |
| ... | ... | |
| 121 | 140 |
assert_equal 2, ActionMailer::Base.deliveries.size |
| 122 | 141 |
end |
| 123 | 142 | |
| 143 |
def test_post_create_with_cross_project_param |
|
| 144 |
ActionMailer::Base.deliveries.clear |
|
| 145 |
@request.session[:user_id] = 2 |
|
| 146 | ||
| 147 |
with_settings :notified_events => %w(news_added) do |
|
| 148 |
post( |
|
| 149 |
:create, |
|
| 150 |
:params => {
|
|
| 151 |
:project_id => 1, |
|
| 152 |
:cross_project => '1', |
|
| 153 |
:news => {
|
|
| 154 |
:title => 'NewsControllerTest', |
|
| 155 |
:description => 'This is the description', |
|
| 156 |
:summary => '' |
|
| 157 |
} |
|
| 158 |
} |
|
| 159 |
) |
|
| 160 |
end |
|
| 161 |
assert_redirected_to '/news' |
|
| 162 | ||
| 163 |
news = News.find_by_title('NewsControllerTest')
|
|
| 164 |
assert_not_nil news |
|
| 165 |
assert_equal 'This is the description', news.description |
|
| 166 |
assert_equal User.find(2), news.author |
|
| 167 |
assert_equal Project.find(1), news.project |
|
| 168 |
assert_equal 2, ActionMailer::Base.deliveries.size |
|
| 169 |
end |
|
| 170 | ||
| 124 | 171 |
def test_post_create_with_attachment |
| 125 | 172 |
set_tmp_attachments_directory |
| 126 | 173 |
ActionMailer::Base.deliveries.clear |
| test/integration/routing/news_test.rb | ||
|---|---|---|
| 29 | 29 | |
| 30 | 30 |
def test_news |
| 31 | 31 |
should_route 'GET /news' => 'news#index' |
| 32 |
should_route 'GET /news/new' => 'news#new' |
|
| 33 |
should_route 'POST /news' => 'news#create' |
|
| 32 | 34 |
should_route 'GET /news.atom' => 'news#index', :format => 'atom' |
| 33 | 35 |
should_route 'GET /news/2' => 'news#show', :id => '2' |
| 34 | 36 |
should_route 'GET /news/2/edit' => 'news#edit', :id => '2' |