mirror of
https://github.com/mastodon/mastodon.git
synced 2025-01-05 06:48:05 +00:00
Add coverage for User
validations (#33028)
This commit is contained in:
parent
fd90f04f0e
commit
ab9c62e8c7
|
@ -33,14 +33,12 @@ RSpec.describe User do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'validations' do
|
describe 'Associations' do
|
||||||
it { is_expected.to belong_to(:account).required }
|
it { is_expected.to belong_to(:account).required }
|
||||||
|
end
|
||||||
|
|
||||||
it 'is invalid without a valid email' do
|
describe 'Validations' do
|
||||||
user = Fabricate.build(:user, email: 'john@')
|
it { is_expected.to_not allow_value('john@').for(:email) }
|
||||||
user.valid?
|
|
||||||
expect(user).to model_have_error_on_field(:email)
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'is valid with an invalid e-mail that has already been saved' do
|
it 'is valid with an invalid e-mail that has already been saved' do
|
||||||
user = Fabricate.build(:user, email: 'invalid-email')
|
user = Fabricate.build(:user, email: 'invalid-email')
|
||||||
|
@ -48,11 +46,7 @@ RSpec.describe User do
|
||||||
expect(user.valid?).to be true
|
expect(user.valid?).to be true
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'is valid with a localhost e-mail address' do
|
it { is_expected.to allow_value('admin@localhost').for(:email) }
|
||||||
user = Fabricate.build(:user, email: 'admin@localhost')
|
|
||||||
user.valid?
|
|
||||||
expect(user.valid?).to be true
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'Normalizations' do
|
describe 'Normalizations' do
|
||||||
|
@ -183,6 +177,39 @@ RSpec.describe User do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe '#update_sign_in!' do
|
||||||
|
context 'with an existing user' do
|
||||||
|
let!(:user) { Fabricate :user, last_sign_in_at: 10.days.ago, current_sign_in_at: 1.hour.ago, sign_in_count: 123 }
|
||||||
|
|
||||||
|
context 'with new sign in false' do
|
||||||
|
it 'updates timestamps but not counts' do
|
||||||
|
expect { user.update_sign_in!(new_sign_in: false) }
|
||||||
|
.to change(user, :last_sign_in_at)
|
||||||
|
.and change(user, :current_sign_in_at)
|
||||||
|
.and not_change(user, :sign_in_count)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with new sign in true' do
|
||||||
|
it 'updates timestamps and counts' do
|
||||||
|
expect { user.update_sign_in!(new_sign_in: true) }
|
||||||
|
.to change(user, :last_sign_in_at)
|
||||||
|
.and change(user, :current_sign_in_at)
|
||||||
|
.and change(user, :sign_in_count).by(1)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with a new user' do
|
||||||
|
let(:user) { Fabricate.build :user }
|
||||||
|
|
||||||
|
it 'does not persist the user' do
|
||||||
|
expect { user.update_sign_in! }
|
||||||
|
.to_not change(user, :persisted?).from(false)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
describe '#confirmed?' do
|
describe '#confirmed?' do
|
||||||
it 'returns true when a confirmed_at is set' do
|
it 'returns true when a confirmed_at is set' do
|
||||||
user = Fabricate.build(:user, confirmed_at: Time.now.utc)
|
user = Fabricate.build(:user, confirmed_at: Time.now.utc)
|
||||||
|
|
Loading…
Reference in a new issue