Commit 0ea2d5db authored by Kamil Trzciński's avatar Kamil Trzciński

Merge branch '7015-epic-states-notes' into 'master'

Create system notes for epic close and reopen

Closes #7015

See merge request gitlab-org/gitlab-ee!7850
parents 84e95169 a581942a
...@@ -212,7 +212,7 @@ module SystemNoteService ...@@ -212,7 +212,7 @@ module SystemNoteService
# "closed via bc17db76" # "closed via bc17db76"
# #
# Returns the created Note object # Returns the created Note object
def change_status(noteable, project, author, status, source) def change_status(noteable, project, author, status, source = nil)
body = status.dup body = status.dup
body << " via #{source.gfm_reference(project)}" if source body << " via #{source.gfm_reference(project)}" if source
......
...@@ -13,6 +13,7 @@ module Epics ...@@ -13,6 +13,7 @@ module Epics
def close_epic(epic) def close_epic(epic)
if epic.close if epic.close
epic.update(closed_by: current_user) epic.update(closed_by: current_user)
SystemNoteService.change_status(epic, nil, current_user, epic.state)
end end
end end
end end
......
...@@ -5,8 +5,15 @@ module Epics ...@@ -5,8 +5,15 @@ module Epics
def execute(epic) def execute(epic)
return epic unless can?(current_user, :update_epic, epic) return epic unless can?(current_user, :update_epic, epic)
epic.reopen reopen_epic(epic)
epic end
private
def reopen_epic(epic)
if epic.reopen
SystemNoteService.change_status(epic, nil, current_user, epic.state)
end
end end
end end
end end
---
title: Create system notes for epic close and reopen
merge_request: 7850
author:
type: added
...@@ -41,6 +41,15 @@ describe Epics::CloseService do ...@@ -41,6 +41,15 @@ describe Epics::CloseService do
it 'changes closed_at' do it 'changes closed_at' do
expect { subject.execute(epic) }.to change { epic.closed_at } expect { subject.execute(epic) }.to change { epic.closed_at }
end end
it 'creates a system note about epic close' do
expect { subject.execute(epic) }.to change { epic.notes.count }.by(1)
note = epic.notes.last
expect(note.note).to eq('closed')
expect(note.system_note_metadata.action).to eq('closed')
end
end end
context 'when trying to close a closed epic' do context 'when trying to close a closed epic' do
...@@ -59,6 +68,10 @@ describe Epics::CloseService do ...@@ -59,6 +68,10 @@ describe Epics::CloseService do
it 'does not change closed_by' do it 'does not change closed_by' do
expect { subject.execute(epic) }.not_to change { epic.closed_by } expect { subject.execute(epic) }.not_to change { epic.closed_by }
end end
it 'does not create a system note' do
expect { subject.execute(epic) }.not_to change { epic.notes.count }
end
end end
end end
......
...@@ -41,6 +41,15 @@ describe Epics::ReopenService do ...@@ -41,6 +41,15 @@ describe Epics::ReopenService do
it 'removes closed_at' do it 'removes closed_at' do
expect { subject.execute(epic) }.to change { epic.closed_at }.to(nil) expect { subject.execute(epic) }.to change { epic.closed_at }.to(nil)
end end
it 'creates a system note about epic reopen' do
expect { subject.execute(epic) }.to change { epic.notes.count }.by(1)
note = epic.notes.last
expect(note.note).to eq('opened')
expect(note.system_note_metadata.action).to eq('opened')
end
end end
context 'when trying to reopen an opened epic' do context 'when trying to reopen an opened epic' do
...@@ -59,6 +68,10 @@ describe Epics::ReopenService do ...@@ -59,6 +68,10 @@ describe Epics::ReopenService do
it 'does not change closed_by' do it 'does not change closed_by' do
expect { subject.execute(epic) }.not_to change { epic.closed_by } expect { subject.execute(epic) }.not_to change { epic.closed_by }
end end
it 'does not create a system note' do
expect { subject.execute(epic) }.not_to change { epic.notes.count }
end
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