diff options
author | Douglas Barbosa Alexandre <dbalexandre@gmail.com> | 2016-02-17 20:04:14 -0200 |
---|---|---|
committer | Douglas Barbosa Alexandre <dbalexandre@gmail.com> | 2016-02-20 12:12:05 -0200 |
commit | 3b98adcc75f82f4e5e469da5c164467da02b0f0c (patch) | |
tree | b8839b6775ca6817b95daa99501a9038aa38f114 /spec | |
parent | 4120b7941d75217d013dcc9612e3e5dff76f10d5 (diff) | |
download | gitlab-ce-3b98adcc75f82f4e5e469da5c164467da02b0f0c.tar.gz |
Create a pending task when a user is mentioned when edit a issue/mr/note
Diffstat (limited to 'spec')
-rw-r--r-- | spec/factories/tasks.rb | 8 | ||||
-rw-r--r-- | spec/services/issues/close_service_spec.rb | 4 | ||||
-rw-r--r-- | spec/services/issues/update_service_spec.rb | 4 | ||||
-rw-r--r-- | spec/services/merge_requests/close_service_spec.rb | 4 | ||||
-rw-r--r-- | spec/services/merge_requests/update_service_spec.rb | 4 | ||||
-rw-r--r-- | spec/services/notes/update_service_spec.rb | 6 | ||||
-rw-r--r-- | spec/services/task_service_spec.rb | 133 |
7 files changed, 79 insertions, 84 deletions
diff --git a/spec/factories/tasks.rb b/spec/factories/tasks.rb index 710b8324f1f..b31db8a7d8b 100644 --- a/spec/factories/tasks.rb +++ b/spec/factories/tasks.rb @@ -20,14 +20,12 @@ FactoryGirl.define do author user - factory :pending_assigned_task, traits: [:assgined, :pending] - - trait :assgined do + trait :assigned do action { Task::ASSIGNED } end - trait :pending do - state { :pending } + trait :mentioned do + action { Task::MENTIONED } end end end diff --git a/spec/services/issues/close_service_spec.rb b/spec/services/issues/close_service_spec.rb index 7a587a96ddc..fdf0fd819b2 100644 --- a/spec/services/issues/close_service_spec.rb +++ b/spec/services/issues/close_service_spec.rb @@ -5,9 +5,7 @@ describe Issues::CloseService, services: true do let(:user2) { create(:user) } let(:issue) { create(:issue, assignee: user2) } let(:project) { issue.project } - let!(:pending_task) do - create(:pending_assigned_task, user: user, project: project, target: issue, author: user2) - end + let!(:pending_task) { create(:task, :assigned, user: user, project: project, target: issue, author: user2) } before do project.team << [user, :master] diff --git a/spec/services/issues/update_service_spec.rb b/spec/services/issues/update_service_spec.rb index 1b7d5b45168..5674b9f1e9b 100644 --- a/spec/services/issues/update_service_spec.rb +++ b/spec/services/issues/update_service_spec.rb @@ -81,9 +81,7 @@ describe Issues::UpdateService, services: true do end context 'task queue' do - let!(:pending_task) do - create(:pending_assigned_task, user: user, project: project, target: issue, author: user2) - end + let!(:pending_task) { create(:task, :assigned, user: user, project: project, target: issue, author: user2) } context 'when the title change' do before do diff --git a/spec/services/merge_requests/close_service_spec.rb b/spec/services/merge_requests/close_service_spec.rb index 3e72be2dc25..13872a1a2dd 100644 --- a/spec/services/merge_requests/close_service_spec.rb +++ b/spec/services/merge_requests/close_service_spec.rb @@ -5,9 +5,7 @@ describe MergeRequests::CloseService, services: true do let(:user2) { create(:user) } let(:merge_request) { create(:merge_request, assignee: user2) } let(:project) { merge_request.project } - let!(:pending_task) do - create(:pending_assigned_task, user: user, project: project, target: merge_request, author: user2) - end + let!(:pending_task) { create(:task, :assigned, user: user, project: project, target: merge_request, author: user2) } before do project.team << [user, :master] diff --git a/spec/services/merge_requests/update_service_spec.rb b/spec/services/merge_requests/update_service_spec.rb index 77c661fd293..6d70e8ec16a 100644 --- a/spec/services/merge_requests/update_service_spec.rb +++ b/spec/services/merge_requests/update_service_spec.rb @@ -99,9 +99,7 @@ describe MergeRequests::UpdateService, services: true do end context 'task queue' do - let!(:pending_task) do - create(:pending_assigned_task, user: user, project: project, target: merge_request, author: user2) - end + let!(:pending_task) { create(:task, :assigned, user: user, project: project, target: merge_request, author: user2) } context 'when the title change' do before do diff --git a/spec/services/notes/update_service_spec.rb b/spec/services/notes/update_service_spec.rb index e6670143951..a8b3e0d825d 100644 --- a/spec/services/notes/update_service_spec.rb +++ b/spec/services/notes/update_service_spec.rb @@ -19,7 +19,7 @@ describe Notes::UpdateService, services: true do end context 'task queue' do - let!(:task) { create(:pending_assigned_task, user: user, project: project, target: issue, author: user2) } + let!(:pending_task) { create(:task, :assigned, user: user, project: project, target: issue, author: user2) } context 'when the note change' do before do @@ -27,7 +27,7 @@ describe Notes::UpdateService, services: true do end it 'marks pending tasks as done' do - expect(task.reload).to be_done + expect(pending_task.reload).to be_done end end @@ -37,7 +37,7 @@ describe Notes::UpdateService, services: true do end it 'keep pending tasks' do - expect(task.reload).to be_pending + expect(pending_task.reload).to be_pending end end end diff --git a/spec/services/task_service_spec.rb b/spec/services/task_service_spec.rb index 18ad02dd2df..a5a497c7002 100644 --- a/spec/services/task_service_spec.rb +++ b/spec/services/task_service_spec.rb @@ -16,7 +16,7 @@ describe TaskService, services: true do end describe 'Issues' do - let(:issue) { create(:issue, project: project, assignee: john_doe, author: author) } + let(:issue) { create(:issue, project: project, assignee: john_doe, author: author, description: mentions) } let(:unassigned_issue) { create(:issue, project: project, assignee: nil) } describe '#new_issue' do @@ -35,8 +35,6 @@ describe TaskService, services: true do end it 'creates a task for each valid mentioned user' do - issue.update_attribute(:description, mentions) - service.new_issue(issue, author) should_create_task(user: michael, target: issue, action: Task::MENTIONED) @@ -46,20 +44,39 @@ describe TaskService, services: true do end end - describe '#close_issue' do - let!(:first_pending_task) do - create(:pending_assigned_task, user: john_doe, project: project, target: issue, author: author) + describe '#update_issue' do + it 'marks pending tasks to the issue for the user as done' do + pending_task = create(:task, :assigned, user: john_doe, project: project, target: issue, author: author) + service.update_issue(issue, john_doe) + + expect(pending_task.reload).to be_done + end + + it 'creates a task for each valid mentioned user' do + service.update_issue(issue, author) + + should_create_task(user: michael, target: issue, action: Task::MENTIONED) + should_not_create_task(user: author, target: issue, action: Task::MENTIONED) + should_not_create_task(user: john_doe, target: issue, action: Task::MENTIONED) + should_not_create_task(user: stranger, target: issue, action: Task::MENTIONED) end - let!(:second_pending_task) do - create(:pending_assigned_task, user: john_doe, project: project, target: issue, author: author) + it 'does not create a task if user was already mentioned' do + create(:task, :mentioned, user: michael, project: project, target: issue, author: author) + + should_not_create_any_task { service.update_issue(issue, author) } end + end + describe '#close_issue' do it 'marks related pending tasks to the target for the user as done' do + first_task = create(:task, :assigned, user: john_doe, project: project, target: issue, author: author) + second_task = create(:task, :assigned, user: john_doe, project: project, target: issue, author: author) + service.close_issue(issue, john_doe) - expect(first_pending_task.reload).to be_done - expect(second_pending_task.reload).to be_done + expect(first_task.reload).to be_done + expect(second_task.reload).to be_done end end @@ -84,60 +101,38 @@ describe TaskService, services: true do end end - describe '#mark_pending_tasks_as_done' do - let!(:first_pending_task) do - create(:pending_assigned_task, user: john_doe, project: project, target: issue, author: author) - end - - let!(:second_pending_task) do - create(:pending_assigned_task, user: john_doe, project: project, target: issue, author: author) - end - - it 'marks related pending tasks to the target for the user as done' do - service.mark_pending_tasks_as_done(issue, john_doe) - - expect(first_pending_task.reload).to be_done - expect(second_pending_task.reload).to be_done - end - end - describe '#new_note' do - let!(:first_pending_task) do - create(:pending_assigned_task, user: john_doe, project: project, target: issue, author: author) - end - - let!(:second_pending_task) do - create(:pending_assigned_task, user: john_doe, project: project, target: issue, author: author) - end - - let(:note) { create(:note, project: project, noteable: issue, author: john_doe) } + let!(:first_task) { create(:task, :assigned, user: john_doe, project: project, target: issue, author: author) } + let!(:second_task) { create(:task, :assigned, user: john_doe, project: project, target: issue, author: author) } + let(:note) { create(:note, project: project, noteable: issue, author: john_doe, note: mentions) } let(:award_note) { create(:note, :award, project: project, noteable: issue, author: john_doe, note: 'thumbsup') } let(:system_note) { create(:system_note, project: project, noteable: issue) } it 'mark related pending tasks to the noteable for the note author as done' do + first_task = create(:task, :assigned, user: john_doe, project: project, target: issue, author: author) + second_task = create(:task, :assigned, user: john_doe, project: project, target: issue, author: author) + service.new_note(note) - expect(first_pending_task.reload).to be_done - expect(second_pending_task.reload).to be_done + expect(first_task.reload).to be_done + expect(second_task.reload).to be_done end it 'mark related pending tasks to the noteable for the award note author as done' do service.new_note(award_note) - expect(first_pending_task.reload).to be_done - expect(second_pending_task.reload).to be_done + expect(first_task.reload).to be_done + expect(second_task.reload).to be_done end it 'does not mark related pending tasks it is a system note' do service.new_note(system_note) - expect(first_pending_task.reload).to be_pending - expect(second_pending_task.reload).to be_pending + expect(first_task.reload).to be_pending + expect(second_task.reload).to be_pending end it 'creates a task for each valid mentioned user' do - note.update_attribute(:note, mentions) - service.new_note(note) should_create_task(user: michael, target: issue, author: john_doe, action: Task::MENTIONED, note: note) @@ -149,7 +144,7 @@ describe TaskService, services: true do end describe 'Merge Requests' do - let(:mr_assigned) { create(:merge_request, source_project: project, author: author, assignee: john_doe) } + let(:mr_assigned) { create(:merge_request, source_project: project, author: author, assignee: john_doe, description: mentions) } let(:mr_unassigned) { create(:merge_request, source_project: project, author: author, assignee: nil) } describe '#new_merge_request' do @@ -168,8 +163,6 @@ describe TaskService, services: true do end it 'creates a task for each valid mentioned user' do - mr_assigned.update_attribute(:description, mentions) - service.new_merge_request(mr_assigned, author) should_create_task(user: michael, target: mr_assigned, action: Task::MENTIONED) @@ -179,20 +172,38 @@ describe TaskService, services: true do end end - describe '#close_merge_request' do - let!(:first_pending_task) do - create(:pending_assigned_task, user: john_doe, project: project, target: mr_assigned, author: author) + describe '#update_merge_request' do + it 'marks pending tasks to the merge request for the user as done' do + pending_task = create(:task, :assigned, user: john_doe, project: project, target: mr_assigned, author: author) + service.update_merge_request(mr_assigned, john_doe) + + expect(pending_task.reload).to be_done + end + + it 'creates a task for each valid mentioned user' do + service.update_merge_request(mr_assigned, author) + + should_create_task(user: michael, target: mr_assigned, action: Task::MENTIONED) + should_not_create_task(user: author, target: mr_assigned, action: Task::MENTIONED) + should_not_create_task(user: john_doe, target: mr_assigned, action: Task::MENTIONED) + should_not_create_task(user: stranger, target: mr_assigned, action: Task::MENTIONED) end - let!(:second_pending_task) do - create(:pending_assigned_task, user: john_doe, project: project, target: mr_assigned, author: author) + it 'does not create a task if user was already mentioned' do + create(:task, :mentioned, user: michael, project: project, target: mr_assigned, author: author) + + should_not_create_any_task { service.update_merge_request(mr_assigned, author) } end + end + describe '#close_merge_request' do it 'marks related pending tasks to the target for the user as done' do + first_task = create(:task, :assigned, user: john_doe, project: project, target: mr_assigned, author: author) + second_task = create(:task, :assigned, user: john_doe, project: project, target: mr_assigned, author: author) service.close_merge_request(mr_assigned, john_doe) - expect(first_pending_task.reload).to be_done - expect(second_pending_task.reload).to be_done + expect(first_task.reload).to be_done + expect(second_task.reload).to be_done end end @@ -218,19 +229,13 @@ describe TaskService, services: true do end describe '#merge_merge_request' do - let!(:first_pending_task) do - create(:pending_assigned_task, user: john_doe, project: project, target: mr_assigned, author: author) - end - - let!(:second_pending_task) do - create(:pending_assigned_task, user: john_doe, project: project, target: mr_assigned, author: author) - end - it 'marks related pending tasks to the target for the user as done' do + first_task = create(:task, :assigned, user: john_doe, project: project, target: mr_assigned, author: author) + second_task = create(:task, :assigned, user: john_doe, project: project, target: mr_assigned, author: author) service.merge_merge_request(mr_assigned, john_doe) - expect(first_pending_task.reload).to be_done - expect(second_pending_task.reload).to be_done + expect(first_task.reload).to be_done + expect(second_task.reload).to be_done end end end |