Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Léo-Paul Géneau
gitlab-ce
Commits
501fb04e
Commit
501fb04e
authored
Jul 16, 2018
by
Jarka Kadlecová
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Delete todos when users loses target read permissions
parent
2ca8219a
Changes
23
Show whitespace changes
Inline
Side-by-side
Showing
23 changed files
with
473 additions
and
7 deletions
+473
-7
app/services/issues/update_service.rb
app/services/issues/update_service.rb
+2
-0
app/services/members/destroy_service.rb
app/services/members/destroy_service.rb
+8
-0
app/services/projects/update_service.rb
app/services/projects/update_service.rb
+16
-7
app/services/todos/destroy/base_service.rb
app/services/todos/destroy/base_service.rb
+33
-0
app/services/todos/destroy/confidential_issue_service.rb
app/services/todos/destroy/confidential_issue_service.rb
+30
-0
app/services/todos/destroy/entity_leave_service.rb
app/services/todos/destroy/entity_leave_service.rb
+49
-0
app/services/todos/destroy/project_private_service.rb
app/services/todos/destroy/project_private_service.rb
+30
-0
app/workers/all_queues.yml
app/workers/all_queues.yml
+4
-0
app/workers/concerns/todos_destroyer_queue.rb
app/workers/concerns/todos_destroyer_queue.rb
+12
-0
app/workers/todos_destroyer/confidential_issue_worker.rb
app/workers/todos_destroyer/confidential_issue_worker.rb
+10
-0
app/workers/todos_destroyer/entity_leave_worker.rb
app/workers/todos_destroyer/entity_leave_worker.rb
+10
-0
app/workers/todos_destroyer/project_private_worker.rb
app/workers/todos_destroyer/project_private_worker.rb
+10
-0
changelogs/unreleased/todos-visibility-change.yml
changelogs/unreleased/todos-visibility-change.yml
+5
-0
config/sidekiq_queues.yml
config/sidekiq_queues.yml
+1
-0
spec/services/issues/update_service_spec.rb
spec/services/issues/update_service_spec.rb
+17
-0
spec/services/members/destroy_service_spec.rb
spec/services/members/destroy_service_spec.rb
+5
-0
spec/services/projects/update_service_spec.rb
spec/services/projects/update_service_spec.rb
+22
-0
spec/services/todos/destroy/confidential_issue_service_spec.rb
...services/todos/destroy/confidential_issue_service_spec.rb
+39
-0
spec/services/todos/destroy/entity_leave_service_spec.rb
spec/services/todos/destroy/entity_leave_service_spec.rb
+96
-0
spec/services/todos/destroy/project_private_service_spec.rb
spec/services/todos/destroy/project_private_service_spec.rb
+38
-0
spec/workers/todos_destroyer/confidential_issue_worker_spec.rb
...workers/todos_destroyer/confidential_issue_worker_spec.rb
+12
-0
spec/workers/todos_destroyer/entity_leave_worker_spec.rb
spec/workers/todos_destroyer/entity_leave_worker_spec.rb
+12
-0
spec/workers/todos_destroyer/project_private_worker_spec.rb
spec/workers/todos_destroyer/project_private_worker_spec.rb
+12
-0
No files found.
app/services/issues/update_service.rb
View file @
501fb04e
...
@@ -37,6 +37,8 @@ module Issues
...
@@ -37,6 +37,8 @@ module Issues
end
end
if
issue
.
previous_changes
.
include?
(
'confidential'
)
if
issue
.
previous_changes
.
include?
(
'confidential'
)
# don't enqueue immediately to prevent todos removal in case of a mistake
TodosDestroyer
::
ConfidentialIssueWorker
.
perform_in
(
1
.
hour
,
issue
.
id
)
if
issue
.
confidential?
create_confidentiality_note
(
issue
)
create_confidentiality_note
(
issue
)
end
end
...
...
app/services/members/destroy_service.rb
View file @
501fb04e
...
@@ -15,6 +15,8 @@ module Members
...
@@ -15,6 +15,8 @@ module Members
notification_service
.
decline_access_request
(
member
)
notification_service
.
decline_access_request
(
member
)
end
end
enqeue_delete_todos
(
member
)
after_execute
(
member:
member
)
after_execute
(
member:
member
)
member
member
...
@@ -22,6 +24,12 @@ module Members
...
@@ -22,6 +24,12 @@ module Members
private
private
def
enqeue_delete_todos
(
member
)
type
=
member
.
is_a?
(
GroupMember
)
?
'Group'
:
'Project'
# don't enqueue immediately to prevent todos removal in case of a mistake
TodosDestroyer
::
EntityLeaveWorker
.
perform_in
(
1
.
hour
,
member
.
user_id
,
member
.
source_id
,
type
)
end
def
can_destroy_member?
(
member
)
def
can_destroy_member?
(
member
)
can?
(
current_user
,
destroy_member_permission
(
member
),
member
)
can?
(
current_user
,
destroy_member_permission
(
member
),
member
)
end
end
...
...
app/services/projects/update_service.rb
View file @
501fb04e
...
@@ -25,13 +25,7 @@ module Projects
...
@@ -25,13 +25,7 @@ module Projects
return
validation_failed!
if
project
.
errors
.
any?
return
validation_failed!
if
project
.
errors
.
any?
if
project
.
update
(
params
.
except
(
:default_branch
))
if
project
.
update
(
params
.
except
(
:default_branch
))
if
project
.
previous_changes
.
include?
(
'path'
)
after_update
project
.
rename_repo
else
system_hook_service
.
execute_hooks_for
(
project
,
:update
)
end
update_pages_config
if
changing_pages_https_only?
success
success
else
else
...
@@ -47,6 +41,21 @@ module Projects
...
@@ -47,6 +41,21 @@ module Projects
private
private
def
after_update
if
project
.
previous_changes
.
include?
(
:visibility_level
)
&&
project
.
private?
# don't enqueue immediately to prevent todos removal in case of a mistake
TodosDestroyer
::
ProjectPrivateWorker
.
perform_in
(
1
.
hour
,
project
.
id
)
end
if
project
.
previous_changes
.
include?
(
'path'
)
project
.
rename_repo
else
system_hook_service
.
execute_hooks_for
(
project
,
:update
)
end
update_pages_config
if
changing_pages_https_only?
end
def
validation_failed!
def
validation_failed!
model_errors
=
project
.
errors
.
full_messages
.
to_sentence
model_errors
=
project
.
errors
.
full_messages
.
to_sentence
error_message
=
model_errors
.
presence
||
'Project could not be updated!'
error_message
=
model_errors
.
presence
||
'Project could not be updated!'
...
...
app/services/todos/destroy/base_service.rb
0 → 100644
View file @
501fb04e
module
Todos
module
Destroy
class
BaseService
def
execute
return
unless
todos_to_remove?
without_authorized
(
todos
).
delete_all
end
private
def
without_authorized
(
items
)
items
.
where
(
'user_id NOT IN (?)'
,
authorized_users
)
end
def
authorized_users
ProjectAuthorization
.
select
(
:user_id
).
where
(
project_id:
project_ids
)
end
def
todos
# overridden in subclasses
end
def
project_ids
# overridden in subclasses
end
def
todos_to_remove?
# overridden in subclasses
end
end
end
end
app/services/todos/destroy/confidential_issue_service.rb
0 → 100644
View file @
501fb04e
module
Todos
module
Destroy
class
ConfidentialIssueService
<
::
Todos
::
Destroy
::
BaseService
extend
::
Gitlab
::
Utils
::
Override
attr_reader
:issue
def
initialize
(
issue_id
)
@issue
=
Issue
.
find_by
(
id:
issue_id
)
end
private
override
:todos
def
todos
Todo
.
where
(
target:
issue
)
end
override
:todos_to_remove?
def
todos_to_remove?
issue
&
.
confidential?
end
override
:project_ids
def
project_ids
issue
.
project_id
end
end
end
end
app/services/todos/destroy/entity_leave_service.rb
0 → 100644
View file @
501fb04e
module
Todos
module
Destroy
class
EntityLeaveService
<
::
Todos
::
Destroy
::
BaseService
extend
::
Gitlab
::
Utils
::
Override
attr_reader
:user_id
,
:entity
def
initialize
(
user_id
,
entity_id
,
entity_type
)
unless
%w(Group Project)
.
include?
(
entity_type
)
raise
ArgumentError
.
new
(
"
#{
entity_type
}
is not an entity user can leave"
)
end
@user_id
=
user_id
@entity
=
entity_type
.
constantize
.
find_by
(
id:
entity_id
)
end
private
override
:todos
def
todos
if
entity
.
private?
Todo
.
where
(
project_id:
project_ids
,
user_id:
user_id
)
else
Todo
.
where
(
target_id:
confidential_issues
.
select
(
:id
),
target_type:
Issue
)
end
end
override
:project_ids
def
project_ids
if
entity
.
is_a?
(
Project
)
entity
.
id
else
Project
.
select
(
:id
).
where
(
namespace_id:
entity
.
self_and_descendants
.
select
(
:id
))
end
end
override
:todos_to_remove?
def
todos_to_remove?
return
unless
entity
entity
.
private?
||
confidential_issues
.
count
>
0
end
def
confidential_issues
Issue
.
where
(
project_id:
project_ids
,
confidential:
true
)
end
end
end
end
app/services/todos/destroy/project_private_service.rb
0 → 100644
View file @
501fb04e
module
Todos
module
Destroy
class
ProjectPrivateService
<
::
Todos
::
Destroy
::
BaseService
extend
::
Gitlab
::
Utils
::
Override
attr_reader
:project
def
initialize
(
project_id
)
@project
=
Project
.
find_by
(
id:
project_id
)
end
private
override
:todos
def
todos
Todo
.
where
(
project_id:
project_ids
)
end
override
:project_ids
def
project_ids
project
.
id
end
override
:todos_to_remove?
def
todos_to_remove?
project
&
.
private?
end
end
end
end
app/workers/all_queues.yml
View file @
501fb04e
...
@@ -73,6 +73,10 @@
...
@@ -73,6 +73,10 @@
-
repository_check:repository_check_batch
-
repository_check:repository_check_batch
-
repository_check:repository_check_single_repository
-
repository_check:repository_check_single_repository
-
todos_destroyer:todos_destroyer_confidential_issue
-
todos_destroyer:todos_destroyer_entity_leave
-
todos_destroyer:todos_destroyer_project_private
-
default
-
default
-
mailers
# ActionMailer::DeliveryJob.queue_name
-
mailers
# ActionMailer::DeliveryJob.queue_name
...
...
app/workers/concerns/todos_destroyer_queue.rb
0 → 100644
View file @
501fb04e
# frozen_string_literal: true
##
# Concern for setting Sidekiq settings for the various Todos Destroyers.
#
module
TodosDestroyerQueue
extend
ActiveSupport
::
Concern
included
do
queue_namespace
:todos_destroyer
end
end
app/workers/todos_destroyer/confidential_issue_worker.rb
0 → 100644
View file @
501fb04e
module
TodosDestroyer
class
ConfidentialIssueWorker
include
ApplicationWorker
include
TodosDestroyerQueue
def
perform
(
issue_id
)
::
Todos
::
Destroy
::
ConfidentialIssueService
.
new
(
issue_id
).
execute
end
end
end
app/workers/todos_destroyer/entity_leave_worker.rb
0 → 100644
View file @
501fb04e
module
TodosDestroyer
class
EntityLeaveWorker
include
ApplicationWorker
include
TodosDestroyerQueue
def
perform
(
user_id
,
entity_id
,
entity_type
)
::
Todos
::
Destroy
::
EntityLeaveService
.
new
(
user_id
,
entity_id
,
entity_type
).
execute
end
end
end
app/workers/todos_destroyer/project_private_worker.rb
0 → 100644
View file @
501fb04e
module
TodosDestroyer
class
ProjectPrivateWorker
include
ApplicationWorker
include
TodosDestroyerQueue
def
perform
(
project_id
)
::
Todos
::
Destroy
::
ProjectPrivateService
.
new
(
project_id
).
execute
end
end
end
changelogs/unreleased/todos-visibility-change.yml
0 → 100644
View file @
501fb04e
---
title
:
Delete todos when user loses access to read the target
merge_request
:
20665
author
:
type
:
other
config/sidekiq_queues.yml
View file @
501fb04e
...
@@ -45,6 +45,7 @@
...
@@ -45,6 +45,7 @@
- [github_import_advance_stage, 1]
- [github_import_advance_stage, 1]
- [project_service, 1]
- [project_service, 1]
- [delete_user, 1]
- [delete_user, 1]
- [todos_destroyer, 1]
- [delete_merged_branches, 1]
- [delete_merged_branches, 1]
- [authorized_projects, 1]
- [authorized_projects, 1]
- [expire_build_instance_artifacts, 1]
- [expire_build_instance_artifacts, 1]
...
...
spec/services/issues/update_service_spec.rb
View file @
501fb04e
...
@@ -55,6 +55,8 @@ describe Issues::UpdateService, :mailer do
...
@@ -55,6 +55,8 @@ describe Issues::UpdateService, :mailer do
end
end
it
'updates the issue with the given params'
do
it
'updates the issue with the given params'
do
expect
(
TodosDestroyer
::
ConfidentialIssueWorker
).
not_to
receive
(
:perform_in
)
update_issue
(
opts
)
update_issue
(
opts
)
expect
(
issue
).
to
be_valid
expect
(
issue
).
to
be_valid
...
@@ -74,6 +76,21 @@ describe Issues::UpdateService, :mailer do
...
@@ -74,6 +76,21 @@ describe Issues::UpdateService, :mailer do
.
to
change
{
project
.
open_issues_count
}.
from
(
1
).
to
(
0
)
.
to
change
{
project
.
open_issues_count
}.
from
(
1
).
to
(
0
)
end
end
it
'enqueues ConfidentialIssueWorker when an issue is made confidential'
do
expect
(
TodosDestroyer
::
ConfidentialIssueWorker
).
to
receive
(
:perform_in
).
with
(
1
.
hour
,
issue
.
id
)
update_issue
(
confidential:
true
)
end
it
'does not enqueue ConfidentialIssueWorker when an issue is made non confidential'
do
# set confidentiality to true before the actual update
issue
.
update!
(
confidential:
true
)
expect
(
TodosDestroyer
::
ConfidentialIssueWorker
).
not_to
receive
(
:perform_in
)
update_issue
(
confidential:
false
)
end
it
'updates open issue counter for assignees when issue is reassigned'
do
it
'updates open issue counter for assignees when issue is reassigned'
do
update_issue
(
assignee_ids:
[
user2
.
id
])
update_issue
(
assignee_ids:
[
user2
.
id
])
...
...
spec/services/members/destroy_service_spec.rb
View file @
501fb04e
...
@@ -20,6 +20,11 @@ describe Members::DestroyService do
...
@@ -20,6 +20,11 @@ describe Members::DestroyService do
end
end
shared_examples
'a service destroying a member'
do
shared_examples
'a service destroying a member'
do
before
do
type
=
member
.
is_a?
(
GroupMember
)
?
'Group'
:
'Project'
expect
(
TodosDestroyer
::
EntityLeaveWorker
).
to
receive
(
:perform_in
).
with
(
1
.
hour
,
member
.
user_id
,
member
.
source_id
,
type
)
end
it
'destroys the member'
do
it
'destroys the member'
do
expect
{
described_class
.
new
(
current_user
).
execute
(
member
,
opts
)
}.
to
change
{
member
.
source
.
members_and_requesters
.
count
}.
by
(
-
1
)
expect
{
described_class
.
new
(
current_user
).
execute
(
member
,
opts
)
}.
to
change
{
member
.
source
.
members_and_requesters
.
count
}.
by
(
-
1
)
end
end
...
...
spec/services/projects/update_service_spec.rb
View file @
501fb04e
...
@@ -15,6 +15,8 @@ describe Projects::UpdateService do
...
@@ -15,6 +15,8 @@ describe Projects::UpdateService do
context
'when changing visibility level'
do
context
'when changing visibility level'
do
context
'when visibility_level is INTERNAL'
do
context
'when visibility_level is INTERNAL'
do
it
'updates the project to internal'
do
it
'updates the project to internal'
do
expect
(
TodosDestroyer
::
ProjectPrivateWorker
).
not_to
receive
(
:perform_in
)
result
=
update_project
(
project
,
user
,
visibility_level:
Gitlab
::
VisibilityLevel
::
INTERNAL
)
result
=
update_project
(
project
,
user
,
visibility_level:
Gitlab
::
VisibilityLevel
::
INTERNAL
)
expect
(
result
).
to
eq
({
status: :success
})
expect
(
result
).
to
eq
({
status: :success
})
...
@@ -24,12 +26,30 @@ describe Projects::UpdateService do
...
@@ -24,12 +26,30 @@ describe Projects::UpdateService do
context
'when visibility_level is PUBLIC'
do
context
'when visibility_level is PUBLIC'
do
it
'updates the project to public'
do
it
'updates the project to public'
do
expect
(
TodosDestroyer
::
ProjectPrivateWorker
).
not_to
receive
(
:perform_in
)
result
=
update_project
(
project
,
user
,
visibility_level:
Gitlab
::
VisibilityLevel
::
PUBLIC
)
result
=
update_project
(
project
,
user
,
visibility_level:
Gitlab
::
VisibilityLevel
::
PUBLIC
)
expect
(
result
).
to
eq
({
status: :success
})
expect
(
result
).
to
eq
({
status: :success
})
expect
(
project
).
to
be_public
expect
(
project
).
to
be_public
end
end
end
end
context
'when visibility_level is PRIVATE'
do
before
do
project
.
update!
(
visibility_level:
Gitlab
::
VisibilityLevel
::
PUBLIC
)
end
it
'updates the project to private'
do
expect
(
TodosDestroyer
::
ProjectPrivateWorker
).
to
receive
(
:perform_in
).
with
(
1
.
hour
,
project
.
id
)
result
=
update_project
(
project
,
user
,
visibility_level:
Gitlab
::
VisibilityLevel
::
PRIVATE
)
expect
(
result
).
to
eq
({
status: :success
})
expect
(
project
).
to
be_private
end
end
context
'when visibility levels are restricted to PUBLIC only'
do
context
'when visibility levels are restricted to PUBLIC only'
do
before
do
before
do
stub_application_setting
(
restricted_visibility_levels:
[
Gitlab
::
VisibilityLevel
::
PUBLIC
])
stub_application_setting
(
restricted_visibility_levels:
[
Gitlab
::
VisibilityLevel
::
PUBLIC
])
...
@@ -38,6 +58,7 @@ describe Projects::UpdateService do
...
@@ -38,6 +58,7 @@ describe Projects::UpdateService do
context
'when visibility_level is INTERNAL'
do
context
'when visibility_level is INTERNAL'
do
it
'updates the project to internal'
do
it
'updates the project to internal'
do
result
=
update_project
(
project
,
user
,
visibility_level:
Gitlab
::
VisibilityLevel
::
INTERNAL
)
result
=
update_project
(
project
,
user
,
visibility_level:
Gitlab
::
VisibilityLevel
::
INTERNAL
)
expect
(
result
).
to
eq
({
status: :success
})
expect
(
result
).
to
eq
({
status: :success
})
expect
(
project
).
to
be_internal
expect
(
project
).
to
be_internal
end
end
...
@@ -54,6 +75,7 @@ describe Projects::UpdateService do
...
@@ -54,6 +75,7 @@ describe Projects::UpdateService do
context
'when updated by an admin'
do
context
'when updated by an admin'
do
it
'updates the project to public'
do
it
'updates the project to public'
do
result
=
update_project
(
project
,
admin
,
visibility_level:
Gitlab
::
VisibilityLevel
::
PUBLIC
)
result
=
update_project
(
project
,
admin
,
visibility_level:
Gitlab
::
VisibilityLevel
::
PUBLIC
)
expect
(
result
).
to
eq
({
status: :success
})
expect
(
result
).
to
eq
({
status: :success
})
expect
(
project
).
to
be_public
expect
(
project
).
to
be_public
end
end
...
...
spec/services/todos/destroy/confidential_issue_service_spec.rb
0 → 100644
View file @
501fb04e
require
'spec_helper'
describe
Todos
::
Destroy
::
ConfidentialIssueService
do
let
(
:project
)
{
create
(
:project
,
:public
)
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:project_member
)
{
create
(
:user
)
}
let
(
:issue
)
{
create
(
:issue
,
project:
project
)
}
let!
(
:todo_issue_non_member
)
{
create
(
:todo
,
user:
user
,
target:
issue
,
project:
project
)
}
let!
(
:todo_issue_member
)
{
create
(
:todo
,
user:
project_member
,
target:
issue
,
project:
project
)
}
let!
(
:todo_another_non_member
)
{
create
(
:todo
,
user:
user
,
project:
project
)
}
describe
'#execute'
do
before
do
project
.
add_developer
(
project_member
)
end
subject
{
described_class
.
new
(
issue
.
id
).
execute
}
context
'when provided issue is confidential'
do
before
do
issue
.
update!
(
confidential:
true
)
end
it
'removes issue todos for a user who is not a project member'
do
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
3
).
to
(
2
)
expect
(
user
.
todos
).
to
match_array
([
todo_another_non_member
])
expect
(
project_member
.
todos
).
to
match_array
([
todo_issue_member
])
end
end
context
'when provided issue is not confidential'
do
it
'does not remove any todos'
do
expect
{
subject
}.
not_to
change
{
Todo
.
count
}
end
end
end
end
spec/services/todos/destroy/entity_leave_service_spec.rb
0 → 100644
View file @
501fb04e
require
'spec_helper'
describe
Todos
::
Destroy
::
EntityLeaveService
do
let
(
:group
)
{
create
(
:group
,
:private
)
}
let
(
:project
)
{
create
(
:project
,
group:
group
)
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:project_member
)
{
create
(
:user
)
}
let
(
:issue
)
{
create
(
:issue
,
:confidential
,
project:
project
)
}
let!
(
:todo_non_member
)
{
create
(
:todo
,
user:
user
,
project:
project
)
}
let!
(
:todo_conf_issue_non_member
)
{
create
(
:todo
,
user:
user
,
target:
issue
,
project:
project
)
}
let!
(
:todo_conf_issue_member
)
{
create
(
:todo
,
user:
project_member
,
target:
issue
,
project:
project
)
}
describe
'#execute'
do
before
do
project
.
add_developer
(
project_member
)
end
context
'when a user leaves a project'
do
subject
{
described_class
.
new
(
user
.
id
,
project
.
id
,
'Project'
).
execute
}
context
'when project is private'
do
it
'removes todos for a user who is not a member'
do
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
3
).
to
(
1
)
expect
(
user
.
todos
).
to
be_empty
expect
(
project_member
.
todos
).
to
match_array
([
todo_conf_issue_member
])
end
end
context
'when project is not private'
do
before
do
group
.
update!
(
visibility_level:
Gitlab
::
VisibilityLevel
::
INTERNAL
)
project
.
update!
(
visibility_level:
Gitlab
::
VisibilityLevel
::
INTERNAL
)
end
it
'removes only confidential issues todos'
do
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
3
).
to
(
2
)
end
end
end
context
'when a user leaves a group'
do
subject
{
described_class
.
new
(
user
.
id
,
group
.
id
,
'Group'
).
execute
}
context
'when group is private'
do
it
'removes todos for a user who is not a member'
do
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
3
).
to
(
1
)
expect
(
user
.
todos
).
to
be_empty
expect
(
project_member
.
todos
).
to
match_array
([
todo_conf_issue_member
])
end
context
'with nested groups'
,
:nested_groups
do
let
(
:subgroup
)
{
create
(
:group
,
:private
,
parent:
group
)
}
let
(
:subproject
)
{
create
(
:project
,
group:
subgroup
)
}
let!
(
:todo_subproject_non_member
)
{
create
(
:todo
,
user:
user
,
project:
subproject
)
}
let!
(
:todo_subproject_member
)
{
create
(
:todo
,
user:
project_member
,
project:
subproject
)
}
it
'removes todos for a user who is not a member'
do
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
5
).
to
(
2
)
expect
(
user
.
todos
).
to
be_empty
expect
(
project_member
.
todos
)
.
to
match_array
([
todo_conf_issue_member
,
todo_subproject_member
])
end
end
end
context
'when group is not private'
do
before
do
group
.
update!
(
visibility_level:
Gitlab
::
VisibilityLevel
::
INTERNAL
)
end
it
'removes only confidential issues todos'
do
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
3
).
to
(
2
)
end
end
end
context
'when entity type is not valid'
do
it
'raises an exception'
do
expect
{
described_class
.
new
(
user
.
id
,
group
.
id
,
'GroupWrongly'
).
execute
}
.
to
raise_error
(
ArgumentError
)
end
end
context
'when entity was not found'
do
it
'does not remove any todos'
do
expect
{
described_class
.
new
(
user
.
id
,
999999
,
'Group'
).
execute
}
.
not_to
change
{
Todo
.
count
}
end
end
end
end
spec/services/todos/destroy/project_private_service_spec.rb
0 → 100644
View file @
501fb04e
require
'spec_helper'
describe
Todos
::
Destroy
::
ProjectPrivateService
do
let
(
:project
)
{
create
(
:project
,
:public
)
}
let
(
:user
)
{
create
(
:user
)
}
let
(
:project_member
)
{
create
(
:user
)
}
let!
(
:todo_issue_non_member
)
{
create
(
:todo
,
user:
user
,
project:
project
)
}
let!
(
:todo_issue_member
)
{
create
(
:todo
,
user:
project_member
,
project:
project
)
}
let!
(
:todo_another_non_member
)
{
create
(
:todo
,
user:
user
,
project:
project
)
}
describe
'#execute'
do
before
do
project
.
add_developer
(
project_member
)
end
subject
{
described_class
.
new
(
project
.
id
).
execute
}
context
'when a project set to private'
do
before
do
project
.
update!
(
visibility_level:
Gitlab
::
VisibilityLevel
::
PRIVATE
)
end
it
'removes issue todos for a user who is not a member'
do
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
3
).
to
(
1
)
expect
(
user
.
todos
).
to
be_empty
expect
(
project_member
.
todos
).
to
match_array
([
todo_issue_member
])
end
end
context
'when project is not private'
do
it
'does not remove any todos'
do
expect
{
subject
}.
not_to
change
{
Todo
.
count
}
end
end
end
end
spec/workers/todos_destroyer/confidential_issue_worker_spec.rb
0 → 100644
View file @
501fb04e
require
'spec_helper'
describe
TodosDestroyer
::
ConfidentialIssueWorker
do
it
"calls the Todos::Destroy::ConfidentialIssueService with the params it was given"
do
service
=
double
expect
(
::
Todos
::
Destroy
::
ConfidentialIssueService
).
to
receive
(
:new
).
with
(
100
).
and_return
(
service
)
expect
(
service
).
to
receive
(
:execute
)
described_class
.
new
.
perform
(
100
)
end
end
spec/workers/todos_destroyer/entity_leave_worker_spec.rb
0 → 100644
View file @
501fb04e
require
'spec_helper'
describe
TodosDestroyer
::
EntityLeaveWorker
do
it
"calls the Todos::Destroy::EntityLeaveService with the params it was given"
do
service
=
double
expect
(
::
Todos
::
Destroy
::
EntityLeaveService
).
to
receive
(
:new
).
with
(
100
,
5
,
'Group'
).
and_return
(
service
)
expect
(
service
).
to
receive
(
:execute
)
described_class
.
new
.
perform
(
100
,
5
,
'Group'
)
end
end
spec/workers/todos_destroyer/project_private_worker_spec.rb
0 → 100644
View file @
501fb04e
require
'spec_helper'
describe
TodosDestroyer
::
ProjectPrivateWorker
do
it
"calls the Todos::Destroy::ProjectPrivateService with the params it was given"
do
service
=
double
expect
(
::
Todos
::
Destroy
::
ProjectPrivateService
).
to
receive
(
:new
).
with
(
100
).
and_return
(
service
)
expect
(
service
).
to
receive
(
:execute
)
described_class
.
new
.
perform
(
100
)
end
end
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment