1
0
Fork 0
This repository has been archived on 2023-03-27. You can view files and clone it, but cannot push or open issues or pull requests.
lpr-partynest/spec/models/account_spec.rb

354 lines
8.1 KiB
Ruby
Raw Normal View History

2018-12-01 21:03:19 -05:00
# frozen_string_literal: true
require 'rails_helper'
RSpec.describe Account do
2018-12-09 22:36:09 -05:00
subject { create :personal_account }
2019-07-20 06:07:02 -04:00
pending '.guests'
pending '#guest?'
pending '#can_access_sidekiq_web_interface?'
2018-12-01 21:03:19 -05:00
2019-07-20 06:07:02 -04:00
describe '#to_param' do
specify do
expect(subject.to_param).to eq subject.nickname
end
end
2019-06-26 20:21:37 -04:00
2019-07-20 06:07:02 -04:00
describe '#account_roles' do
it do
is_expected.to \
have_many(:account_roles)
.inverse_of(:account)
.dependent(:restrict_with_exception)
end
2018-12-01 21:50:10 -05:00
end
2019-07-20 06:07:02 -04:00
describe '#roles' do
it do
is_expected.to \
have_many(:roles)
.through(:account_roles)
end
2019-02-01 22:48:23 -05:00
end
2019-07-20 06:07:02 -04:00
describe '#user' do
it do
is_expected.to \
have_one(:user)
.dependent(:restrict_with_exception)
end
it { is_expected.not_to validate_presence_of :user }
2019-02-01 22:48:23 -05:00
end
2019-07-20 06:07:02 -04:00
describe '#person' do
it { is_expected.to belong_to(:person).optional }
2018-12-04 20:49:26 -05:00
2019-07-20 06:07:02 -04:00
it { is_expected.not_to validate_presence_of :person }
end
2019-06-26 20:43:27 -04:00
describe '#contacts_list' do
def allow_value(*)
super.for :contacts_list
end
2019-07-20 06:10:52 -04:00
xit { is_expected.to belong_to(:contacts_list).required }
2019-06-26 20:43:27 -04:00
context 'for usual account' do
subject { create :usual_account }
it { is_expected.to allow_value create :empty_contacts_list }
2019-06-26 20:43:27 -04:00
end
context 'for personal account' do
subject { create :personal_account }
it { is_expected.not_to allow_value create :empty_contacts_list }
2019-06-26 20:43:27 -04:00
it { is_expected.to allow_value subject.person.contacts_list }
specify do
expect(subject.contacts_list).to eq subject.person.contacts_list
end
end
end
2019-03-24 15:27:06 -04:00
describe '#nickname' do
2019-01-31 19:47:44 -05:00
def allow_value(*)
2019-03-24 15:27:06 -04:00
super.for :nickname
2019-01-31 19:47:44 -05:00
end
2019-03-24 15:27:06 -04:00
it { is_expected.to validate_presence_of :nickname }
2019-01-31 19:47:44 -05:00
it do
2019-03-24 15:27:06 -04:00
is_expected.to validate_length_of(:nickname).is_at_least(3).is_at_most(36)
2019-01-31 19:47:44 -05:00
end
2019-03-24 15:27:06 -04:00
it { is_expected.to validate_uniqueness_of(:nickname).case_insensitive }
2019-01-31 19:47:44 -05:00
it { is_expected.not_to allow_value nil }
it { is_expected.not_to allow_value '' }
it { is_expected.not_to allow_value ' ' * 3 }
it { is_expected.to allow_value Faker::Internet.username(3..36, %w[_]) }
it { is_expected.to allow_value 'foo_bar' }
it { is_expected.to allow_value 'foo123' }
it do
is_expected.not_to \
allow_value Faker::Internet.username(3..36, %w[_]).upcase
end
2019-01-31 19:47:44 -05:00
it { is_expected.not_to allow_value Faker::Internet.email }
it { is_expected.not_to allow_value '_foo' }
it { is_expected.not_to allow_value 'bar_' }
it { is_expected.not_to allow_value '1foo' }
end
2019-02-01 16:46:57 -05:00
describe '#public_name' do
def allow_value(*)
super.for :public_name
end
it { is_expected.to allow_value nil }
it { is_expected.to allow_value '' }
it { is_expected.to allow_value ' ' }
2019-02-01 16:46:57 -05:00
it { is_expected.to allow_value Faker::Name.name }
it { is_expected.to allow_value Faker::Name.first_name }
it { is_expected.to allow_value 'Foo Bar' }
2019-07-22 17:06:59 -04:00
it { is_expected.to validate_length_of(:public_name).is_at_most(255) }
context 'when it was set to blank value' do
subject { create :personal_account, public_name: ' ' * rand(100) }
specify do
expect(subject.public_name).to eq nil
end
end
2019-03-24 10:42:33 -04:00
context 'when it was set to value with leading and trailing spaces' do
subject { create :personal_account, public_name: public_name }
let :public_name do
"#{' ' * rand(4)}#{Faker::Name.name}#{' ' * rand(4)}"
end
specify do
expect(subject.public_name).to eq public_name.strip
end
end
2019-02-01 16:46:57 -05:00
end
2019-01-31 23:02:51 -05:00
describe '#biography' do
def allow_value(*)
super.for :biography
end
it { is_expected.to allow_value nil }
it { is_expected.to allow_value '' }
it { is_expected.to allow_value ' ' }
it { is_expected.to allow_value Faker::Lorem.sentence }
2019-07-22 17:06:59 -04:00
it { is_expected.to validate_length_of(:biography).is_at_most(10_000) }
context 'when it was set to blank value' do
subject { create :personal_account, biography: ' ' * rand(100) }
specify do
expect(subject.biography).to eq nil
end
end
2019-03-24 10:42:33 -04:00
context 'when it was set to value with leading and trailing spaces' do
subject { create :personal_account, biography: biography }
let :biography do
"#{' ' * rand(4)}#{Faker::Lorem.sentence}#{' ' * rand(4)}"
end
specify do
expect(subject.biography).to eq biography.strip
end
end
2019-01-31 23:02:51 -05:00
end
2019-07-08 09:13:54 -04:00
describe '#roles' do
subject { create :usual_account }
let(:role) { subject.add_role :superuser }
context 'when role is added twice' do
before do
AccountRole.create! account: subject, role: role
end
specify do
expect(subject.roles).to eq [role]
end
end
end
2019-02-01 23:24:12 -05:00
describe '#has_role?' do
subject { create :usual_account }
let(:role) { subject.add_role :superuser }
let!(:account_role) { role.account_roles.last }
let(:result) { subject.has_role? :superuser }
specify do
expect(result).to eq true
end
context 'after role is removed' do
before do
subject.remove_role :superuser
end
specify do
expect(result).to eq false
end
end
2019-02-08 01:42:32 -05:00
context 'before role expires' do
before do
account_role.update! expires_at: 2.seconds.from_now
end
specify do
expect(result).to eq true
end
end
context 'before role expires' do
before do
account_role.update! expires_at: Faker::Time.forward
end
specify do
expect(result).to eq true
end
end
context 'after role expires' do
before do
account_role.update! expires_at: 1.second.ago
end
specify do
expect(result).to eq false
end
end
context 'after role expires' do
before do
account_role.update! expires_at: Faker::Time.backward
end
specify do
expect(result).to eq false
end
end
2019-02-01 23:24:12 -05:00
end
describe '#add_role' do
2019-02-08 02:01:34 -05:00
subject { create :usual_account }
let(:result) { subject.add_role :superuser }
let(:account_role) { result; AccountRole.last }
specify do
expect { result }.to change { subject.roles.reload.count }.by(1)
end
specify do
expect { result }.to change { subject.account_roles.reload.count }.by(1)
end
specify do
expect { result }.to change { Role.count }.by(1)
end
specify do
expect { result }.to change { AccountRole.count }.by(1)
end
specify do
expect(account_role.account).to eq subject
end
specify do
expect(account_role.role).to eq result
end
context 'to guest account' do
subject { create :guest_account }
specify do
expect { result }.to \
raise_error RuntimeError, 'can not add role to guest account'
end
specify do
expect { result rescue nil }.not_to(
change { subject.roles.reload.count },
)
end
end
end
2019-02-01 23:04:58 -05:00
describe '#remove_role' do
subject { create :usual_account }
2019-02-01 23:18:22 -05:00
let(:role) { subject.add_role :superuser }
let!(:account_role) { role.account_roles.last }
2019-02-01 23:04:58 -05:00
let(:result) { subject.remove_role :superuser }
specify do
expect { result }.to change { subject.roles.reload.count }.by(-1)
end
specify do
expect { result }.to change { subject.account_roles.reload.count }.by(-1)
end
2019-02-01 23:18:22 -05:00
specify do
expect { result }.to change { role.accounts.reload.count }.by(-1)
end
specify do
expect { result }.to change { role.account_roles.reload.count }.by(-1)
end
2019-02-01 23:04:58 -05:00
specify do
2019-02-01 23:27:42 -05:00
expect { result }.not_to(change { Role.count })
2019-02-01 23:04:58 -05:00
end
specify do
2019-02-01 23:27:42 -05:00
expect { result }.not_to(change { AccountRole.count })
2019-02-01 23:18:22 -05:00
end
specify do
expect { result }.not_to \
change { account_role.reload.account }.from(subject)
end
specify do
expect { result }.not_to change { account_role.reload.role }.from(role)
end
specify do
expect { result }.to change { account_role.reload.deleted_at }.from(nil)
expect(account_role.deleted_at).to be_within(10).of(Time.zone.now)
2019-02-01 23:04:58 -05:00
end
end
2018-12-01 21:03:19 -05:00
end