Skip to content

Commit

Permalink
Improve FilterContext tests
Browse files Browse the repository at this point in the history
Signed-off-by: Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>
  • Loading branch information
dzaporozhets committed Dec 25, 2013
1 parent 34f994b commit 73af33e
Showing 1 changed file with 32 additions and 26 deletions.
58 changes: 32 additions & 26 deletions spec/contexts/filter_context_spec.rb
Original file line number Diff line number Diff line change
@@ -1,38 +1,38 @@
require 'spec_helper'

describe FilterContext do

let(:user) { create :user }
let(:user2) { create :user }
let(:project1) { create(:project, creator_id: user.id) }
let(:project2) { create(:project, creator_id: user.id) }
let(:merge_request1) { create(:merge_request, author_id: user.id, source_project: project1, target_project: project2) }
let(:merge_request2) { create(:merge_request, author_id: user.id, source_project: project2, target_project: project1) }
let(:merge_request3) { create(:merge_request, author_id: user.id, 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_id: user.id, project: project1) }
let(:issue2) { create(:issue, assignee_id: user.id, project: project2) }
let(:issue3) { create(:issue, assignee_id: user2.id, project: project2) }
let(:project1) { create(:project) }
let(:project2) { create(:project) }
let(:merge_request1) { create(:merge_request, author: user, source_project: project1, target_project: project2) }
let(:merge_request2) { create(:merge_request, author: user, source_project: project2, target_project: project1) }
let(:merge_request3) { create(:merge_request, author: user, source_project: project2, target_project: project2) }
let(:issue1) { create(:issue, assignee: user, project: project1) }
let(:issue2) { create(:issue, assignee: user, project: project2) }
let(:issue3) { create(:issue, assignee: user2, project: project2) }

before do
project1.team << [user, :master]
project2.team << [user, :developer]
end

describe 'merge requests' do
before :each do
merge_request1
merge_request2
merge_request3
merge_request4
end

it 'should by default filter properly' do
merge_requests = user.cared_merge_requests
params ={}
merge_requests = FilterContext.new(merge_requests, params).execute
it 'should filter by scope' do
params = { scope: 'authored' }
merge_requests = FilterContext.new(MergeRequest, user, params).execute
merge_requests.size.should == 3
end

it 'should apply blocks passed in on creation to the filters' do
merge_requests = user.cared_merge_requests
params = {:project_id => project1.id}
merge_requests = FilterContext.new(merge_requests, params).execute
it 'should filter by project' do
params = { project_id: project1.id, scope: 'authored' }
merge_requests = FilterContext.new(MergeRequest, user, params).execute
merge_requests.size.should == 1
end
end
Expand All @@ -43,16 +43,22 @@
issue2
issue3
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 = {}
issues = FilterContext.new(issues, params).execute
issues = FilterContext.new(Issue, user, params).execute
issues.size.should == 2
end
it 'should apply blocks passed in on creation to the filters' do
issues = user.assigned_issues
params = {:project_id => project1.id}
issues = FilterContext.new(issues, params).execute

it 'should filter by project' do
params = { project_id: project1.id }
issues = FilterContext.new(Issue, user, params).execute
issues.size.should == 1
end
end
Expand Down

0 comments on commit 73af33e

Please sign in to comment.