Commit 73af33e4 authored by Dmitriy Zaporozhets's avatar Dmitriy Zaporozhets

Improve FilterContext tests

Signed-off-by: default avatarDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>
parent 34f994b7
require 'spec_helper' require 'spec_helper'
describe FilterContext do describe FilterContext do
let(:user) { create :user } let(:user) { create :user }
let(:user2) { create :user } let(:user2) { create :user }
let(:project1) { create(:project, creator_id: user.id) } let(:project1) { create(:project) }
let(:project2) { create(:project, creator_id: user.id) } let(:project2) { create(:project) }
let(:merge_request1) { create(:merge_request, author_id: user.id, source_project: project1, target_project: project2) } let(:merge_request1) { create(:merge_request, author: user, source_project: project1, target_project: project2) }
let(:merge_request2) { create(:merge_request, author_id: user.id, source_project: project2, target_project: project1) } let(:merge_request2) { create(:merge_request, author: user, source_project: project2, target_project: project1) }
let(:merge_request3) { create(:merge_request, author_id: user.id, source_project: project2, target_project: project2) } let(:merge_request3) { create(:merge_request, author: user, source_project: project2, target_project: project2) }
let(:merge_request4) { create(:merge_request, author_id: user2.id, source_project: project2, target_project: project2, target_branch:"notes_refactoring") } let(:issue1) { create(:issue, assignee: user, project: project1) }
let(:issue1) { create(:issue, assignee_id: user.id, project: project1) } let(:issue2) { create(:issue, assignee: user, project: project2) }
let(:issue2) { create(:issue, assignee_id: user.id, project: project2) } let(:issue3) { create(:issue, assignee: user2, project: project2) }
let(:issue3) { create(:issue, assignee_id: user2.id, project: project2) }
before do
project1.team << [user, :master]
project2.team << [user, :developer]
end
describe 'merge requests' do describe 'merge requests' do
before :each do before :each do
merge_request1 merge_request1
merge_request2 merge_request2
merge_request3 merge_request3
merge_request4
end end
it 'should by default filter properly' do it 'should filter by scope' do
merge_requests = user.cared_merge_requests params = { scope: 'authored' }
params ={} merge_requests = FilterContext.new(MergeRequest, user, params).execute
merge_requests = FilterContext.new(merge_requests, params).execute
merge_requests.size.should == 3 merge_requests.size.should == 3
end end
it 'should apply blocks passed in on creation to the filters' do it 'should filter by project' do
merge_requests = user.cared_merge_requests params = { project_id: project1.id, scope: 'authored' }
params = {:project_id => project1.id} merge_requests = FilterContext.new(MergeRequest, user, params).execute
merge_requests = FilterContext.new(merge_requests, params).execute
merge_requests.size.should == 1 merge_requests.size.should == 1
end end
end end
...@@ -43,16 +43,22 @@ describe FilterContext do ...@@ -43,16 +43,22 @@ describe FilterContext do
issue2 issue2
issue3 issue3
end end
it 'should by default filter projects properly' do
issues = user.assigned_issues it 'should filter by all' do
params = { scope: "all" }
issues = FilterContext.new(Issue, user, params).execute
issues.size.should == 3
end
it 'should filter by assignee' do
params = {} params = {}
issues = FilterContext.new(issues, params).execute issues = FilterContext.new(Issue, user, params).execute
issues.size.should == 2 issues.size.should == 2
end end
it 'should apply blocks passed in on creation to the filters' do
issues = user.assigned_issues it 'should filter by project' do
params = {:project_id => project1.id} params = { project_id: project1.id }
issues = FilterContext.new(issues, params).execute issues = FilterContext.new(Issue, user, params).execute
issues.size.should == 1 issues.size.should == 1
end end
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment