debian-mirror-gitlab/spec/finders/user_recent_events_finder_spec.rb

88 lines
2.9 KiB
Ruby
Raw Normal View History

2019-12-21 20:55:43 +05:30
# frozen_string_literal: true
2018-03-27 19:54:05 +05:30
require 'spec_helper'
2020-06-23 00:09:42 +05:30
RSpec.describe UserRecentEventsFinder do
2020-07-28 23:09:34 +05:30
let_it_be(:project_owner, reload: true) { create(:user) }
let_it_be(:current_user, reload: true) { create(:user) }
2018-06-27 16:04:02 +05:30
let(:private_project) { create(:project, :private, creator: project_owner) }
let(:internal_project) { create(:project, :internal, creator: project_owner) }
let(:public_project) { create(:project, :public, creator: project_owner) }
let!(:private_event) { create(:event, project: private_project, author: project_owner) }
let!(:internal_event) { create(:event, project: internal_project, author: project_owner) }
let!(:public_event) { create(:event, project: public_project, author: project_owner) }
2020-09-03 11:15:55 +05:30
let(:limit) { nil }
let(:params) { { limit: limit } }
2018-03-27 19:54:05 +05:30
2020-09-03 11:15:55 +05:30
subject(:finder) { described_class.new(current_user, project_owner, params) }
2018-03-27 19:54:05 +05:30
describe '#execute' do
2018-11-20 20:47:30 +05:30
context 'when profile is public' do
it 'returns all the events' do
expect(finder.execute).to include(private_event, internal_event, public_event)
2018-06-27 16:04:02 +05:30
end
2018-03-27 19:54:05 +05:30
end
2018-11-20 20:47:30 +05:30
context 'when profile is private' do
it 'returns no event' do
allow(Ability).to receive(:allowed?).and_call_original
allow(Ability).to receive(:allowed?).with(current_user, :read_user_profile, project_owner).and_return(false)
2018-03-27 19:54:05 +05:30
expect(finder.execute).to be_empty
end
end
2018-06-27 16:04:02 +05:30
2018-11-20 20:47:30 +05:30
it 'does not include the events if the user cannot read cross project' do
2019-02-15 15:39:39 +05:30
allow(Ability).to receive(:allowed?).and_call_original
2018-11-20 20:47:30 +05:30
expect(Ability).to receive(:allowed?).with(current_user, :read_cross_project) { false }
2019-02-15 15:39:39 +05:30
2018-11-20 20:47:30 +05:30
expect(finder.execute).to be_empty
2018-06-27 16:04:02 +05:30
end
2020-07-28 23:09:34 +05:30
describe 'design activity events' do
let_it_be(:event_a) { create(:design_event, author: project_owner) }
let_it_be(:event_b) { create(:design_event, author: project_owner) }
it 'only includes design events', :aggregate_failures do
events = finder.execute
expect(events).to include(event_a)
expect(events).to include(event_b)
end
end
2020-09-03 11:15:55 +05:30
context 'limits' do
before do
stub_const("#{described_class}::DEFAULT_LIMIT", 1)
stub_const("#{described_class}::MAX_LIMIT", 3)
end
context 'when limit is not set' do
it 'returns events limited to DEFAULT_LIMIT' do
expect(finder.execute.size).to eq(described_class::DEFAULT_LIMIT)
end
end
context 'when limit is set' do
let(:limit) { 2 }
it 'returns events limited to specified limit' do
expect(finder.execute.size).to eq(limit)
end
end
context 'when limit is set to a number that exceeds maximum limit' do
let(:limit) { 4 }
before do
create(:event, project: public_project, author: project_owner)
end
it 'returns events limited to MAX_LIMIT' do
expect(finder.execute.size).to eq(described_class::MAX_LIMIT)
end
end
end
2018-03-27 19:54:05 +05:30
end
end