debian-mirror-gitlab/spec/services/todos/destroy/confidential_issue_service_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

70 lines
2.8 KiB
Ruby
Raw Normal View History

2019-07-31 22:56:46 +05:30
# frozen_string_literal: true
2018-11-18 11:00:15 +05:30
require 'spec_helper'
2020-07-28 23:09:34 +05:30
RSpec.describe Todos::Destroy::ConfidentialIssueService do
2018-11-18 11:00:15 +05:30
let(:project) { create(:project, :public) }
let(:user) { create(:user) }
let(:author) { create(:user) }
let(:assignee) { create(:user) }
let(:guest) { create(:user) }
let(:project_member) { create(:user) }
2019-09-04 21:01:54 +05:30
let(:issue_1) { create(:issue, :confidential, project: project, author: author, assignees: [assignee]) }
2018-11-18 11:00:15 +05:30
describe '#execute' do
before do
project.add_developer(project_member)
project.add_guest(guest)
2019-09-04 21:01:54 +05:30
# todos not to be deleted
create(:todo, user: project_member, target: issue_1, project: project)
create(:todo, user: author, target: issue_1, project: project)
create(:todo, user: assignee, target: issue_1, project: project)
create(:todo, user: user, project: project)
# Todos to be deleted
create(:todo, user: guest, target: issue_1, project: project)
create(:todo, user: user, target: issue_1, project: project)
2018-11-18 11:00:15 +05:30
end
2019-09-04 21:01:54 +05:30
subject { described_class.new(issue_id: issue_1.id).execute }
2018-11-18 11:00:15 +05:30
2019-09-04 21:01:54 +05:30
context 'when issue_id parameter is present' do
context 'when provided issue is confidential' do
it 'removes issue todos for users who can not access the confidential issue' do
expect { subject }.to change { Todo.count }.from(6).to(4)
end
2018-11-18 11:00:15 +05:30
end
2019-09-04 21:01:54 +05:30
context 'when provided issue is not confidential' do
it 'does not remove any todos' do
2021-01-29 00:20:46 +05:30
issue_1.update!(confidential: false)
2019-09-04 21:01:54 +05:30
expect { subject }.not_to change { Todo.count }
end
2018-11-18 11:00:15 +05:30
end
end
2019-09-04 21:01:54 +05:30
context 'when project_id parameter is present' do
subject { described_class.new(issue_id: nil, project_id: project.id).execute }
it 'removes issues todos for users that cannot access confidential issues' do
issue_2 = create(:issue, :confidential, project: project)
issue_3 = create(:issue, :confidential, project: project, author: author, assignees: [assignee])
issue_4 = create(:issue, project: project)
# Todos not to be deleted
create(:todo, user: guest, target: issue_1, project: project)
create(:todo, user: assignee, target: issue_1, project: project)
create(:todo, user: project_member, target: issue_2, project: project)
create(:todo, user: author, target: issue_3, project: project)
create(:todo, user: user, target: issue_4, project: project)
create(:todo, user: user, project: project)
# Todos to be deleted
create(:todo, user: user, target: issue_1, project: project)
create(:todo, user: guest, target: issue_2, project: project)
expect { subject }.to change { Todo.count }.from(14).to(10)
2018-11-18 11:00:15 +05:30
end
end
end
end