2019-07-07 11:18:12 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
RSpec.describe RemoveExpiredMembersWorker do
|
2017-08-17 22:00:37 +05:30
|
|
|
let(:worker) { described_class.new }
|
2016-09-13 17:45:13 +05:30
|
|
|
|
|
|
|
describe '#perform' do
|
|
|
|
context 'project members' do
|
2020-10-04 03:57:07 +05:30
|
|
|
let_it_be(:expired_project_member) { create(:project_member, expires_at: 1.day.from_now, access_level: GroupMember::DEVELOPER) }
|
|
|
|
let_it_be(:project_member_expiring_in_future) { create(:project_member, expires_at: 10.days.from_now, access_level: GroupMember::DEVELOPER) }
|
|
|
|
let_it_be(:non_expiring_project_member) { create(:project_member, expires_at: nil, access_level: GroupMember::DEVELOPER) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
travel_to(3.days.from_now)
|
|
|
|
end
|
2016-09-13 17:45:13 +05:30
|
|
|
|
|
|
|
it 'removes expired members' do
|
|
|
|
expect { worker.perform }.to change { Member.count }.by(-1)
|
|
|
|
expect(Member.find_by(id: expired_project_member.id)).to be_nil
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'leaves members that expire in the future' do
|
|
|
|
worker.perform
|
|
|
|
expect(project_member_expiring_in_future.reload).to be_present
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'leaves members that do not expire at all' do
|
|
|
|
worker.perform
|
|
|
|
expect(non_expiring_project_member.reload).to be_present
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'group members' do
|
2020-10-04 03:57:07 +05:30
|
|
|
let_it_be(:expired_group_member) { create(:group_member, expires_at: 1.day.from_now, access_level: GroupMember::DEVELOPER) }
|
|
|
|
let_it_be(:group_member_expiring_in_future) { create(:group_member, expires_at: 10.days.from_now, access_level: GroupMember::DEVELOPER) }
|
|
|
|
let_it_be(:non_expiring_group_member) { create(:group_member, expires_at: nil, access_level: GroupMember::DEVELOPER) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
travel_to(3.days.from_now)
|
|
|
|
end
|
2016-09-13 17:45:13 +05:30
|
|
|
|
|
|
|
it 'removes expired members' do
|
|
|
|
expect { worker.perform }.to change { Member.count }.by(-1)
|
|
|
|
expect(Member.find_by(id: expired_group_member.id)).to be_nil
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'leaves members that expire in the future' do
|
|
|
|
worker.perform
|
|
|
|
expect(group_member_expiring_in_future.reload).to be_present
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'leaves members that do not expire at all' do
|
|
|
|
worker.perform
|
|
|
|
expect(non_expiring_group_member.reload).to be_present
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the last group owner expires' do
|
2020-10-04 03:57:07 +05:30
|
|
|
let_it_be(:expired_group_owner) { create(:group_member, expires_at: 1.day.from_now, access_level: GroupMember::OWNER) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
travel_to(3.days.from_now)
|
|
|
|
end
|
2016-09-13 17:45:13 +05:30
|
|
|
|
|
|
|
it 'does not delete the owner' do
|
|
|
|
worker.perform
|
|
|
|
expect(expired_group_owner.reload).to be_present
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|