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
|