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
1
Merge Requests
1
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
nexedi
gitlab-ce
Commits
efad1f1a
Commit
efad1f1a
authored
Sep 21, 2020
by
Brett Walker
Committed by
Heinrich Lee Yu
Sep 21, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Refactored the EntityLeaveService specs
to use shared examples and parameterized specs
parent
151c7fc7
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
152 additions
and
143 deletions
+152
-143
spec/services/todos/destroy/entity_leave_service_spec.rb
spec/services/todos/destroy/entity_leave_service_spec.rb
+152
-143
No files found.
spec/services/todos/destroy/entity_leave_service_spec.rb
View file @
efad1f1a
...
@@ -3,77 +3,111 @@
...
@@ -3,77 +3,111 @@
require
'spec_helper'
require
'spec_helper'
RSpec
.
describe
Todos
::
Destroy
::
EntityLeaveService
do
RSpec
.
describe
Todos
::
Destroy
::
EntityLeaveService
do
let
(
:group
)
{
create
(
:group
,
:private
)
}
let_it_be
(
:group
,
reload:
true
)
{
create
(
:group
,
:private
)
}
let
(
:project
)
{
create
(
:project
,
group:
group
)
}
let_it_be
(
:project
,
reload:
true
)
{
create
(
:project
,
group:
group
)
}
let
(
:user
)
{
create
(
:user
)
}
let_it_be
(
:user
,
reload:
true
)
{
create
(
:user
)
}
let
(
:user2
)
{
create
(
:user
)
}
let_it_be
(
:user2
,
reload:
true
)
{
create
(
:user
)
}
let
(
:issue
)
{
create
(
:issue
,
project:
project
,
confidential:
true
)
}
let_it_be
(
:issue
)
{
create
(
:issue
,
project:
project
)
}
let
(
:mr
)
{
create
(
:merge_request
,
source_project:
project
)
}
let_it_be
(
:issue_c
)
{
create
(
:issue
,
project:
project
,
confidential:
true
)
}
let_it_be
(
:todo_group_user
)
{
create
(
:todo
,
user:
user
,
group:
group
)
}
let_it_be
(
:todo_group_user2
)
{
create
(
:todo
,
user:
user2
,
group:
group
)
}
let
(
:mr
)
{
create
(
:merge_request
,
source_project:
project
)
}
let!
(
:todo_mr_user
)
{
create
(
:todo
,
user:
user
,
target:
mr
,
project:
project
)
}
let!
(
:todo_mr_user
)
{
create
(
:todo
,
user:
user
,
target:
mr
,
project:
project
)
}
let!
(
:todo_issue_user
)
{
create
(
:todo
,
user:
user
,
target:
issue
,
project:
project
)
}
let!
(
:todo_issue_user
)
{
create
(
:todo
,
user:
user
,
target:
issue
,
project:
project
)
}
let!
(
:todo_group_user
)
{
create
(
:todo
,
user:
user
,
group:
group
)
}
let!
(
:todo_issue_c_user
)
{
create
(
:todo
,
user:
user
,
target:
issue_c
,
project:
project
)
}
let!
(
:todo_issue_user2
)
{
create
(
:todo
,
user:
user2
,
target:
issue
,
project:
project
)
}
let!
(
:todo_issue_c_user2
)
{
create
(
:todo
,
user:
user2
,
target:
issue_c
,
project:
project
)
}
let!
(
:todo_group_user2
)
{
create
(
:todo
,
user:
user2
,
group:
group
)
}
describe
'#execute'
do
shared_examples
'using different access permissions'
do
|
access_table
|
context
'when a user leaves a project'
do
using
RSpec
::
Parameterized
::
TableSyntax
subject
{
described_class
.
new
(
user
.
id
,
project
.
id
,
'Project'
).
execute
}
context
'when project is private'
do
where
(
:group_access
,
:project_access
,
:c_todos
,
:mr_todos
,
:method
,
&
access_table
)
it
'removes project todos for the provided user'
do
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
5
).
to
(
3
)
expect
(
user
.
todos
).
to
match_array
([
todo_group_user
])
with_them
do
expect
(
user2
.
todos
).
to
match_array
([
todo_issue_user2
,
todo_group_user2
])
before
do
set_access
(
project
,
user
,
project_access
)
if
project_access
set_access
(
group
,
user
,
group_access
)
if
group_access
end
end
context
'when the user is member of the project'
do
it
"
#{
params
[
:method
].
to_s
.
humanize
(
capitalize:
false
)
}
"
do
before
do
send
(
method
)
project
.
add_developer
(
user
)
end
end
end
end
it
'does not remove any todos'
do
shared_examples
'does not remove any todos'
do
expect
{
subject
}.
not_to
change
{
Todo
.
count
}
it
{
does_not_remove_any_todos
}
end
end
shared_examples
'removes only confidential issues todos'
do
it
{
removes_only_confidential_issues_todos
}
end
end
context
'when the user is a project guest'
do
shared_examples
'removes confidential issues and merge request todos'
do
before
do
it
{
removes_confidential_issues_and_merge_request_todos
}
project
.
add_guest
(
user
)
end
end
it
'removes only confidential issues todos'
do
def
does_not_remove_any_todos
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
5
).
to
(
4
)
expect
{
subject
}.
not_to
change
{
Todo
.
count
}
end
end
def
removes_only_confidential_issues_todos
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
6
).
to
(
5
)
end
end
context
'when the user is member of a parent group'
do
def
removes_confidential_issues_and_merge_request_todos
before
do
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
6
).
to
(
4
)
group
.
add_developer
(
user
)
expect
(
user
.
todos
).
to
match_array
([
todo_issue_user
,
todo_group_user
]
)
end
end
it
'does not remove any todos'
do
def
set_access
(
object
,
user
,
access_name
)
expect
{
subject
}.
not_to
change
{
Todo
.
count
}
case
access_name
when
:developer
object
.
add_developer
(
user
)
when
:reporter
object
.
add_reporter
(
user
)
when
:guest
object
.
add_guest
(
user
)
end
end
end
end
context
'when the user is guest of a parent group'
do
describe
'#execute'
do
before
do
describe
'updating a Project'
do
project
.
add_guest
(
user
)
subject
{
described_class
.
new
(
user
.
id
,
project
.
id
,
'Project'
).
execute
}
context
'when project is private'
do
context
'when a user leaves a project'
do
it
'removes project todos for the provided user'
do
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
6
).
to
(
3
)
expect
(
user
.
todos
).
to
match_array
([
todo_group_user
])
expect
(
user2
.
todos
).
to
match_array
([
todo_issue_c_user2
,
todo_group_user2
])
end
end
end
it
'removes only confidential issues todos'
do
context
'access permissions'
do
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
5
).
to
(
4
)
# rubocop:disable RSpec/LeakyConstantDeclaration
PROJECT_PRIVATE_ACCESS_TABLE
=
lambda
do
|
_
|
[
# :group_access, :project_access, :c_todos, :mr_todos, :method
[
nil
,
:reporter
,
:keep
,
:keep
,
:does_not_remove_any_todos
],
[
nil
,
:guest
,
:delete
,
:keep
,
:removes_only_confidential_issues_todos
],
[
:reporter
,
nil
,
:keep
,
:keep
,
:does_not_remove_any_todos
],
[
:guest
,
nil
,
:delete
,
:keep
,
:removes_only_confidential_issues_todos
]
]
end
end
# rubocop:enable RSpec/LeakyConstantDeclaration
it_behaves_like
'using different access permissions'
,
PROJECT_PRIVATE_ACCESS_TABLE
end
end
end
end
context
'when project is not private'
do
context
'when project is not private'
do
before
do
let_it_be
(
:group
,
reload:
true
)
{
create
(
:group
,
:internal
)
}
group
.
update!
(
visibility_level:
Gitlab
::
VisibilityLevel
::
INTERNAL
)
let_it_be
(
:project
,
reload:
true
)
{
create
(
:project
,
:internal
,
group:
group
)
}
project
.
update!
(
visibility_level:
Gitlab
::
VisibilityLevel
::
INTERNAL
)
let_it_be
(
:issue
,
reload:
true
)
{
create
(
:issue
,
project:
project
)
}
end
let_it_be
(
:issue_c
,
reload:
true
)
{
create
(
:issue
,
project:
project
,
confidential:
true
)
}
it
'enqueues the PrivateFeaturesWorker'
do
it
'enqueues the PrivateFeaturesWorker'
do
expect
(
TodosDestroyer
::
PrivateFeaturesWorker
)
expect
(
TodosDestroyer
::
PrivateFeaturesWorker
)
...
@@ -84,50 +118,41 @@ RSpec.describe Todos::Destroy::EntityLeaveService do
...
@@ -84,50 +118,41 @@ RSpec.describe Todos::Destroy::EntityLeaveService do
context
'confidential issues'
do
context
'confidential issues'
do
context
'when a user is not an author of confidential issue'
do
context
'when a user is not an author of confidential issue'
do
it
'removes only confidential issues todos'
do
it_behaves_like
'removes only confidential issues todos'
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
5
).
to
(
4
)
end
end
end
context
'when a user is an author of confidential issue'
do
context
'when a user is an author of confidential issue'
do
before
do
before
do
issue
.
update!
(
author:
user
)
issue
_c
.
update!
(
author:
user
)
end
end
it
'does not remove any todos'
do
it_behaves_like
'does not remove any todos'
expect
{
subject
}.
not_to
change
{
Todo
.
count
}
end
end
end
context
'when a user is an assignee of confidential issue'
do
context
'when a user is an assignee of confidential issue'
do
before
do
before
do
issue
.
assignees
<<
user
issue
_c
.
assignees
<<
user
end
end
it
'does not remove any todos'
do
it_behaves_like
'does not remove any todos'
expect
{
subject
}.
not_to
change
{
Todo
.
count
}
end
end
end
context
'when a user is a project guest'
do
context
'access permissions'
do
before
do
# rubocop:disable RSpec/LeakyConstantDeclaration
project
.
add_guest
(
user
)
PROJECT_NOT_PRIVATE_ACCESS_TABLE
=
lambda
do
|
_
|
[
# :group_access, :project_access, :c_todos, :mr_todos, :method
[
nil
,
:reporter
,
:keep
,
:keep
,
:does_not_remove_any_todos
],
[
nil
,
:guest
,
:delete
,
:keep
,
:removes_only_confidential_issues_todos
],
[
:reporter
,
nil
,
:keep
,
:keep
,
:does_not_remove_any_todos
],
[
:guest
,
nil
,
:delete
,
:keep
,
:removes_only_confidential_issues_todos
],
[
:reporter
,
:guest
,
:keep
,
:keep
,
:does_not_remove_any_todos
]
]
end
end
# rubocop:enable RSpec/LeakyConstantDeclaration
it
'removes only confidential issues todos'
do
it_behaves_like
'using different access permissions'
,
PROJECT_NOT_PRIVATE_ACCESS_TABLE
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
5
).
to
(
4
)
end
end
context
'when a user is a project guest but group developer'
do
before
do
project
.
add_guest
(
user
)
group
.
add_developer
(
user
)
end
it
'does not remove any todos'
do
expect
{
subject
}.
not_to
change
{
Todo
.
count
}
end
end
end
end
end
...
@@ -138,42 +163,39 @@ RSpec.describe Todos::Destroy::EntityLeaveService do
...
@@ -138,42 +163,39 @@ RSpec.describe Todos::Destroy::EntityLeaveService do
end
end
it
'removes only users issue todos'
do
it
'removes only users issue todos'
do
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
5
).
to
(
4
)
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
6
).
to
(
5
)
end
end
end
end
end
end
end
end
end
end
context
'when a user leaves a g
roup'
do
describe
'updating a G
roup'
do
subject
{
described_class
.
new
(
user
.
id
,
group
.
id
,
'Group'
).
execute
}
subject
{
described_class
.
new
(
user
.
id
,
group
.
id
,
'Group'
).
execute
}
context
'when group is private'
do
context
'when group is private'
do
context
'when a user leaves a group'
do
it
'removes group and subproject todos for the user'
do
it
'removes group and subproject todos for the user'
do
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
5
).
to
(
2
)
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
6
).
to
(
2
)
expect
(
user
.
todos
).
to
be_empty
expect
(
user
.
todos
).
to
be_empty
expect
(
user2
.
todos
).
to
match_array
([
todo_issue
_user2
,
todo_group_user2
])
expect
(
user2
.
todos
).
to
match_array
([
todo_issue_c
_user2
,
todo_group_user2
])
end
end
context
'when the user is member of the group'
do
before
do
group
.
add_developer
(
user
)
end
end
it
'does not remove any todos'
do
context
'access permissions'
do
expect
{
subject
}.
not_to
change
{
Todo
.
count
}
# rubocop:disable RSpec/LeakyConstantDeclaration
end
GROUP_PRIVATE_ACCESS_TABLE
=
lambda
do
|
_
|
[
# :group_access, :project_access, :c_todos, :mr_todos, :method
[
nil
,
:reporter
,
:keep
,
:keep
,
:does_not_remove_any_todos
],
[
:reporter
,
nil
,
:keep
,
:keep
,
:does_not_remove_any_todos
]
]
end
end
# rubocop:enable RSpec/LeakyConstantDeclaration
context
'when the user is member of the group project but not the group'
do
it_behaves_like
'using different access permissions'
,
GROUP_PRIVATE_ACCESS_TABLE
before
do
project
.
add_developer
(
user
)
end
it
'does not remove any todos'
do
expect
{
subject
}.
not_to
change
{
Todo
.
count
}
end
end
end
context
'with nested groups'
do
context
'with nested groups'
do
...
@@ -191,12 +213,12 @@ RSpec.describe Todos::Destroy::EntityLeaveService do
...
@@ -191,12 +213,12 @@ RSpec.describe Todos::Destroy::EntityLeaveService do
context
'when the user is not a member of any groups/projects'
do
context
'when the user is not a member of any groups/projects'
do
it
'removes todos for the user including subprojects todos'
do
it
'removes todos for the user including subprojects todos'
do
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
1
1
).
to
(
4
)
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
1
2
).
to
(
4
)
expect
(
user
.
todos
).
to
be_empty
expect
(
user
.
todos
).
to
be_empty
expect
(
user2
.
todos
)
expect
(
user2
.
todos
)
.
to
match_array
(
.
to
match_array
(
[
todo_issue_user2
,
todo_group_user2
,
todo_subproject_user2
,
todo_subpgroup_user2
]
[
todo_issue_
c_
user2
,
todo_group_user2
,
todo_subproject_user2
,
todo_subpgroup_user2
]
)
)
end
end
end
end
...
@@ -208,9 +230,7 @@ RSpec.describe Todos::Destroy::EntityLeaveService do
...
@@ -208,9 +230,7 @@ RSpec.describe Todos::Destroy::EntityLeaveService do
parent_group
.
add_developer
(
user
)
parent_group
.
add_developer
(
user
)
end
end
it
'does not remove any todos'
do
it_behaves_like
'does not remove any todos'
expect
{
subject
}.
not_to
change
{
Todo
.
count
}
end
end
end
context
'when the user is member of a subgroup'
do
context
'when the user is member of a subgroup'
do
...
@@ -219,12 +239,12 @@ RSpec.describe Todos::Destroy::EntityLeaveService do
...
@@ -219,12 +239,12 @@ RSpec.describe Todos::Destroy::EntityLeaveService do
end
end
it
'does not remove group and subproject todos'
do
it
'does not remove group and subproject todos'
do
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
1
1
).
to
(
7
)
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
1
2
).
to
(
7
)
expect
(
user
.
todos
).
to
match_array
([
todo_group_user
,
todo_subgroup_user
,
todo_subproject_user
])
expect
(
user
.
todos
).
to
match_array
([
todo_group_user
,
todo_subgroup_user
,
todo_subproject_user
])
expect
(
user2
.
todos
)
expect
(
user2
.
todos
)
.
to
match_array
(
.
to
match_array
(
[
todo_issue_user2
,
todo_group_user2
,
todo_subproject_user2
,
todo_subpgroup_user2
]
[
todo_issue_
c_
user2
,
todo_group_user2
,
todo_subproject_user2
,
todo_subpgroup_user2
]
)
)
end
end
end
end
...
@@ -235,12 +255,12 @@ RSpec.describe Todos::Destroy::EntityLeaveService do
...
@@ -235,12 +255,12 @@ RSpec.describe Todos::Destroy::EntityLeaveService do
end
end
it
'does not remove subproject and group todos'
do
it
'does not remove subproject and group todos'
do
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
1
1
).
to
(
7
)
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
1
2
).
to
(
7
)
expect
(
user
.
todos
).
to
match_array
([
todo_subgroup_user
,
todo_group_user
,
todo_subproject_user
])
expect
(
user
.
todos
).
to
match_array
([
todo_subgroup_user
,
todo_group_user
,
todo_subproject_user
])
expect
(
user2
.
todos
)
expect
(
user2
.
todos
)
.
to
match_array
(
.
to
match_array
(
[
todo_issue_user2
,
todo_group_user2
,
todo_subproject_user2
,
todo_subpgroup_user2
]
[
todo_issue_
c_
user2
,
todo_group_user2
,
todo_subproject_user2
,
todo_subpgroup_user2
]
)
)
end
end
end
end
...
@@ -248,10 +268,10 @@ RSpec.describe Todos::Destroy::EntityLeaveService do
...
@@ -248,10 +268,10 @@ RSpec.describe Todos::Destroy::EntityLeaveService do
end
end
context
'when group is not private'
do
context
'when group is not private'
do
before
do
let_it_be
(
:group
,
reload:
true
)
{
create
(
:group
,
:internal
)
}
group
.
update!
(
visibility_level:
Gitlab
::
VisibilityLevel
::
INTERNAL
)
let_it_be
(
:project
,
reload:
true
)
{
create
(
:project
,
:internal
,
group:
group
)
}
project
.
update!
(
visibility_level:
Gitlab
::
VisibilityLevel
::
INTERNAL
)
let_it_be
(
:issue
,
reload:
true
)
{
create
(
:issue
,
project:
project
)
}
end
let_it_be
(
:issue_c
,
reload:
true
)
{
create
(
:issue
,
project:
project
,
confidential:
true
)
}
it
'enqueues the PrivateFeaturesWorker'
do
it
'enqueues the PrivateFeaturesWorker'
do
expect
(
TodosDestroyer
::
PrivateFeaturesWorker
)
expect
(
TodosDestroyer
::
PrivateFeaturesWorker
)
...
@@ -260,31 +280,20 @@ RSpec.describe Todos::Destroy::EntityLeaveService do
...
@@ -260,31 +280,20 @@ RSpec.describe Todos::Destroy::EntityLeaveService do
subject
subject
end
end
context
'when user is not member'
do
context
'access permissions'
do
it
'removes only confidential issues todos'
do
# rubocop:disable RSpec/LeakyConstantDeclaration
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
5
).
to
(
4
)
GROUP_NOT_PRIVATE_ACCESS_TABLE
=
end
lambda
do
|
_
|
end
[
# :group_access, :project_access, :c_todos, :mr_todos, :method
context
'when user is a project guest'
do
[
nil
,
nil
,
:delete
,
:keep
,
:removes_only_confidential_issues_todos
],
before
do
[
nil
,
:guest
,
:delete
,
:keep
,
:removes_only_confidential_issues_todos
],
project
.
add_guest
(
user
)
[
:reporter
,
:guest
,
:keep
,
:keep
,
:does_not_remove_any_todos
]
end
]
it
'removes only confidential issues todos'
do
expect
{
subject
}.
to
change
{
Todo
.
count
}.
from
(
5
).
to
(
4
)
end
end
context
'when user is a project guest & group developer'
do
before
do
project
.
add_guest
(
user
)
group
.
add_developer
(
user
)
end
end
# rubocop:enable RSpec/LeakyConstantDeclaration
it
'does not remove any todos'
do
it_behaves_like
'using different access permissions'
,
GROUP_NOT_PRIVATE_ACCESS_TABLE
expect
{
subject
}.
not_to
change
{
Todo
.
count
}
end
end
end
end
end
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