2016-02-16 17:21:24 -05:00
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe Notes::UpdateService, services: true do
|
|
|
|
let(:project) { create(:empty_project) }
|
|
|
|
let(:user) { create(:user) }
|
|
|
|
let(:user2) { create(:user) }
|
2017-03-28 02:25:43 -04:00
|
|
|
let(:user3) { create(:user) }
|
2016-02-16 17:21:24 -05:00
|
|
|
let(:issue) { create(:issue, project: project) }
|
2017-03-28 02:25:43 -04:00
|
|
|
let(:note) { create(:note, project: project, noteable: issue, author: user, note: "Old note #{user2.to_reference}") }
|
2016-02-16 17:21:24 -05:00
|
|
|
|
|
|
|
before do
|
|
|
|
project.team << [user, :master]
|
|
|
|
project.team << [user2, :developer]
|
2017-03-28 02:25:43 -04:00
|
|
|
project.team << [user3, :developer]
|
2016-02-16 17:21:24 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
describe '#execute' do
|
|
|
|
def update_note(opts)
|
|
|
|
@note = Notes::UpdateService.new(project, user, opts).execute(note)
|
|
|
|
@note.reload
|
|
|
|
end
|
|
|
|
|
2016-02-20 08:59:59 -05:00
|
|
|
context 'todos' do
|
|
|
|
let!(:todo) { create(:todo, :assigned, user: user, project: project, target: issue, author: user2) }
|
2016-02-16 17:21:24 -05:00
|
|
|
|
|
|
|
context 'when the note change' do
|
|
|
|
before do
|
2017-03-28 02:25:43 -04:00
|
|
|
update_note({ note: "New note #{user2.to_reference} #{user3.to_reference}" })
|
2016-02-16 17:21:24 -05:00
|
|
|
end
|
|
|
|
|
2016-02-20 08:59:59 -05:00
|
|
|
it 'marks todos as done' do
|
|
|
|
expect(todo.reload).to be_done
|
2016-02-16 17:21:24 -05:00
|
|
|
end
|
2017-03-28 02:25:43 -04:00
|
|
|
|
|
|
|
it 'creates only 1 new todo' do
|
|
|
|
expect(Todo.count).to eq(2)
|
|
|
|
end
|
2016-02-16 17:21:24 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the note does not change' do
|
|
|
|
before do
|
2017-03-28 02:25:43 -04:00
|
|
|
update_note({ note: "Old note #{user2.to_reference}" })
|
2016-02-16 17:21:24 -05:00
|
|
|
end
|
|
|
|
|
2016-02-20 08:59:59 -05:00
|
|
|
it 'keep todos' do
|
|
|
|
expect(todo.reload).to be_pending
|
2016-02-16 17:21:24 -05:00
|
|
|
end
|
2017-03-28 02:25:43 -04:00
|
|
|
|
|
|
|
it 'does not create any new todos' do
|
|
|
|
expect(Todo.count).to eq(1)
|
|
|
|
end
|
2016-02-16 17:21:24 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|