summaryrefslogtreecommitdiff
path: root/spec/finders
diff options
context:
space:
mode:
authorJarka Kadlecová <jarka@gitlab.com>2018-07-16 15:35:19 +0200
committerJarka Kadlecová <jarka@gitlab.com>2018-08-02 10:42:45 +0200
commit15179878d57addb010b5afeadd4bde8b62ef3acb (patch)
treeaad121955d9ab691584613e3aea20a1b9c5eeaea /spec/finders
parent0233fffe283857d9934460625f9c17fcd278536b (diff)
downloadgitlab-ce-15179878d57addb010b5afeadd4bde8b62ef3acb.tar.gz
Revert "Revert "Merge branch 'ee-5481-epic-todos' into 'master'""
This reverts commit 8717c7dad9b5a8fa21ec9a652c54718a6b4c2175.
Diffstat (limited to 'spec/finders')
-rw-r--r--spec/finders/todos_finder_spec.rb64
1 files changed, 64 insertions, 0 deletions
diff --git a/spec/finders/todos_finder_spec.rb b/spec/finders/todos_finder_spec.rb
index 9747b9402a7..6061021d3b0 100644
--- a/spec/finders/todos_finder_spec.rb
+++ b/spec/finders/todos_finder_spec.rb
@@ -5,12 +5,76 @@ describe TodosFinder do
let(:user) { create(:user) }
let(:group) { create(:group) }
let(:project) { create(:project, namespace: group) }
+ let(:issue) { create(:issue, project: project) }
+ let(:merge_request) { create(:merge_request, source_project: project) }
let(:finder) { described_class }
before do
group.add_developer(user)
end
+ describe '#execute' do
+ context 'visibility' do
+ let(:private_group_access) { create(:group, :private) }
+ let(:private_group_hidden) { create(:group, :private) }
+ let(:public_project) { create(:project, :public) }
+ let(:private_project_hidden) { create(:project) }
+ let(:public_group) { create(:group) }
+
+ let!(:todo1) { create(:todo, user: user, project: project, group: nil) }
+ let!(:todo2) { create(:todo, user: user, project: public_project, group: nil) }
+ let!(:todo3) { create(:todo, user: user, project: private_project_hidden, group: nil) }
+ let!(:todo4) { create(:todo, user: user, project: nil, group: group) }
+ let!(:todo5) { create(:todo, user: user, project: nil, group: private_group_access) }
+ let!(:todo6) { create(:todo, user: user, project: nil, group: private_group_hidden) }
+ let!(:todo7) { create(:todo, user: user, project: nil, group: public_group) }
+
+ before do
+ private_group_access.add_developer(user)
+ end
+
+ it 'returns only todos with a target a user has access to' do
+ todos = finder.new(user).execute
+
+ expect(todos).to match_array([todo1, todo2, todo4, todo5, todo7])
+ end
+ end
+
+ context 'filtering' do
+ let!(:todo1) { create(:todo, user: user, project: project, target: issue) }
+ let!(:todo2) { create(:todo, user: user, group: group, target: merge_request) }
+
+ it 'returns correct todos when filtered by a project' do
+ todos = finder.new(user, { project_id: project.id }).execute
+
+ expect(todos).to match_array([todo1])
+ end
+
+ it 'returns correct todos when filtered by a group' do
+ todos = finder.new(user, { group_id: group.id }).execute
+
+ expect(todos).to match_array([todo1, todo2])
+ end
+
+ it 'returns correct todos when filtered by a type' do
+ todos = finder.new(user, { type: 'Issue' }).execute
+
+ expect(todos).to match_array([todo1])
+ end
+
+ context 'with subgroups', :nested_groups do
+ let(:subgroup) { create(:group, parent: group) }
+ let!(:todo3) { create(:todo, user: user, group: subgroup, target: issue) }
+
+ it 'returns todos from subgroups when filtered by a group' do
+ todos = finder.new(user, { group_id: group.id }).execute
+
+ expect(todos).to match_array([todo1, todo2, todo3])
+ end
+ end
+ end
+ end
+
describe '#sort' do
context 'by date' do
let!(:todo1) { create(:todo, user: user, project: project) }