summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFelipe Artur <felipefac@gmail.com>2016-03-31 16:11:49 -0300
committerFelipe Artur <felipefac@gmail.com>2016-04-05 11:53:39 -0300
commit1ba9a91c6d3b98e1825e173fe281ba065d35890c (patch)
treec9c7abff27c62679bffeb45dc873e7aad7989aee
parent59466a478038210113b21ffa40530799dcdeed40 (diff)
downloadgitlab-ce-1ba9a91c6d3b98e1825e173fe281ba065d35890c.tar.gz
Fix problem when creating milestones in groups without projects
-rw-r--r--app/controllers/groups/milestones_controller.rb28
-rw-r--r--spec/controllers/groups/milestones_controller_spec.rb6
2 files changed, 29 insertions, 5 deletions
diff --git a/app/controllers/groups/milestones_controller.rb b/app/controllers/groups/milestones_controller.rb
index b23c3022fb5..2c05d9e0fe1 100644
--- a/app/controllers/groups/milestones_controller.rb
+++ b/app/controllers/groups/milestones_controller.rb
@@ -18,14 +18,14 @@ class Groups::MilestonesController < Groups::ApplicationController
end
def create
- project_ids = params[:milestone][:project_ids]
+ project_ids = params[:milestone][:project_ids].reject(&:blank?)
title = milestone_params[:title]
- @projects.where(id: project_ids).each do |project|
- Milestones::CreateService.new(project, current_user, milestone_params).execute
+ if project_ids.present?
+ create_milestones(project_ids, title)
+ else
+ render_new_with_error("Select a project(s).")
end
-
- redirect_to milestone_path(title)
end
def show
@@ -41,6 +41,24 @@ class Groups::MilestonesController < Groups::ApplicationController
private
+ def create_milestones(project_ids, title)
+ begin
+ @projects.where(id: project_ids).each do |project|
+ ActiveRecord::Base.transaction { Milestones::CreateService.new(project, current_user, milestone_params).execute }
+ end
+
+ redirect_to milestone_path(title)
+ rescue => e
+ render_new_with_error("Error creating milestones: #{e.message}")
+ end
+ end
+
+ def render_new_with_error(error)
+ @milestone = Milestone.new(milestone_params)
+ flash[:alert] = error
+ render :new
+ end
+
def authorize_admin_milestones!
return render_404 unless can?(current_user, :admin_milestones, group)
end
diff --git a/spec/controllers/groups/milestones_controller_spec.rb b/spec/controllers/groups/milestones_controller_spec.rb
index eb0c6ac6d80..f258d6fa0c7 100644
--- a/spec/controllers/groups/milestones_controller_spec.rb
+++ b/spec/controllers/groups/milestones_controller_spec.rb
@@ -23,5 +23,11 @@ describe Groups::MilestonesController do
expect(response).to redirect_to(group_milestone_path(group, title.to_slug.to_s, title: title))
expect(Milestone.where(title: title).count).to eq(2)
end
+
+ it "redirects to new when there are no project ids" do
+ post :create, group_id: group.id, milestone: { title: title, project_ids: [""] }
+ expect(response).to render_template :new
+ expect(flash[:alert]).to_not be_nil
+ end
end
end