Commit dd180944 authored by Douwe Maan's avatar Douwe Maan

Merge branch 'bvl-backport-board-issue-create-service' into 'master'

This makes the `Boards::CreateService` more reusable for EE

See merge request !12704
parents 939cff89 c478202e
module Boards module Boards
class CreateService < BaseService class CreateService < BaseService
def execute def execute
if project.boards.empty? create_board! if can_create_board?
create_board!
else
project.boards.first
end
end end
private private
def can_create_board?
project.boards.size == 0
end
def create_board! def create_board!
board = project.boards.create board = project.boards.create(params)
board.lists.create(list_type: :backlog)
board.lists.create(list_type: :closed) if board.persisted?
board.lists.create(list_type: :backlog)
board.lists.create(list_type: :closed)
end
board board
end end
......
...@@ -26,6 +26,8 @@ describe Boards::CreateService, services: true do ...@@ -26,6 +26,8 @@ describe Boards::CreateService, services: true do
end end
it 'does not create a new board' do it 'does not create a new board' do
expect(service).to receive(:can_create_board?) { false }
expect { service.execute }.not_to change(project.boards, :count) expect { service.execute }.not_to change(project.boards, :count)
end end
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment