Skip to content

Commit

Permalink
Add coverage for User validations (mastodon#33028)
Browse files Browse the repository at this point in the history
  • Loading branch information
mjankowski authored Nov 25, 2024
1 parent fd90f04 commit ab9c62e
Showing 1 changed file with 38 additions and 11 deletions.
49 changes: 38 additions & 11 deletions spec/models/user_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -33,26 +33,20 @@
end
end

describe 'validations' do
describe 'Associations' do
it { is_expected.to belong_to(:account).required }
end

it 'is invalid without a valid email' do
user = Fabricate.build(:user, email: 'john@')
user.valid?
expect(user).to model_have_error_on_field(:email)
end
describe 'Validations' do
it { is_expected.to_not allow_value('john@').for(:email) }

it 'is valid with an invalid e-mail that has already been saved' do
user = Fabricate.build(:user, email: 'invalid-email')
user.save(validate: false)
expect(user.valid?).to be true
end

it 'is valid with a localhost e-mail address' do
user = Fabricate.build(:user, email: 'admin@localhost')
user.valid?
expect(user.valid?).to be true
end
it { is_expected.to allow_value('admin@localhost').for(:email) }
end

describe 'Normalizations' do
Expand Down Expand Up @@ -183,6 +177,39 @@ def within_duration_window_days
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
it 'returns true when a confirmed_at is set' do
user = Fabricate.build(:user, confirmed_at: Time.now.utc)
Expand Down

0 comments on commit ab9c62e

Please sign in to comment.