9124310f28
At the moment we cannot see weather a user left a project due to their membership expiring of if they themselves opted to leave the project. This adds a new event type that allows us to make this differentiation. Note that is not really feasable to go back and reliably fix up the previous events. As a result the events for previous expire removals will remain the same however events of this nature going forward will be correctly represented.
31 lines
1,011 B
Ruby
31 lines
1,011 B
Ruby
require 'spec_helper'
|
|
|
|
describe Expirable do
|
|
describe 'ProjectMember' do
|
|
let(:no_expire) { create(:project_member) }
|
|
let(:expire_later) { create(:project_member, expires_at: Time.current + 6.days) }
|
|
let(:expired) { create(:project_member, expires_at: Time.current - 6.days) }
|
|
|
|
describe '.expired' do
|
|
it { expect(ProjectMember.expired).to match_array([expired]) }
|
|
end
|
|
|
|
describe '#expired?' do
|
|
it { expect(no_expire.expired?).to eq(false) }
|
|
it { expect(expire_later.expired?).to eq(false) }
|
|
it { expect(expired.expired?).to eq(true) }
|
|
end
|
|
|
|
describe '#expires?' do
|
|
it { expect(no_expire.expires?).to eq(false) }
|
|
it { expect(expire_later.expires?).to eq(true) }
|
|
it { expect(expired.expires?).to eq(true) }
|
|
end
|
|
|
|
describe '#expires_soon?' do
|
|
it { expect(no_expire.expires_soon?).to eq(false) }
|
|
it { expect(expire_later.expires_soon?).to eq(true) }
|
|
it { expect(expired.expires_soon?).to eq(true) }
|
|
end
|
|
end
|
|
end
|