diff options
Diffstat (limited to 'spec/models/users')
-rw-r--r-- | spec/models/users/banned_user_spec.rb | 21 | ||||
-rw-r--r-- | spec/models/users/in_product_marketing_email_spec.rb | 6 |
2 files changed, 27 insertions, 0 deletions
diff --git a/spec/models/users/banned_user_spec.rb b/spec/models/users/banned_user_spec.rb new file mode 100644 index 00000000000..b55c4821d05 --- /dev/null +++ b/spec/models/users/banned_user_spec.rb @@ -0,0 +1,21 @@ +# frozen_string_literal: true + +require 'spec_helper' + +RSpec.describe Users::BannedUser do + describe 'relationships' do + it { is_expected.to belong_to(:user) } + end + + describe 'validations' do + before do + create(:user, :banned) + end + + it { is_expected.to validate_presence_of(:user) } + + it 'validates uniqueness of banned user id' do + is_expected.to validate_uniqueness_of(:user_id).with_message("banned user already exists") + end + end +end diff --git a/spec/models/users/in_product_marketing_email_spec.rb b/spec/models/users/in_product_marketing_email_spec.rb index 772d875d69e..a9ddd86677c 100644 --- a/spec/models/users/in_product_marketing_email_spec.rb +++ b/spec/models/users/in_product_marketing_email_spec.rb @@ -19,6 +19,12 @@ RSpec.describe Users::InProductMarketingEmail, type: :model do it { is_expected.to validate_uniqueness_of(:user_id).scoped_to([:track, :series]).with_message('has already been sent') } end + describe '.tracks' do + it 'has an entry for every track' do + expect(Namespaces::InProductMarketingEmailsService::TRACKS.keys).to match_array(described_class.tracks.keys.map(&:to_sym)) + end + end + describe '.without_track_and_series' do let_it_be(:user) { create(:user) } |