diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2022-05-19 10:33:21 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2022-05-19 10:33:21 +0300 |
commit | 36a59d088eca61b834191dacea009677a96c052f (patch) | |
tree | e4f33972dab5d8ef79e3944a9f403035fceea43f /spec/services/users/in_product_marketing_email_records_spec.rb | |
parent | a1761f15ec2cae7c7f7bbda39a75494add0dfd6f (diff) |
Add latest changes from gitlab-org/gitlab@15-0-stable-eev15.0.0-rc42
Diffstat (limited to 'spec/services/users/in_product_marketing_email_records_spec.rb')
-rw-r--r-- | spec/services/users/in_product_marketing_email_records_spec.rb | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/spec/services/users/in_product_marketing_email_records_spec.rb b/spec/services/users/in_product_marketing_email_records_spec.rb new file mode 100644 index 00000000000..0b9400dcd12 --- /dev/null +++ b/spec/services/users/in_product_marketing_email_records_spec.rb @@ -0,0 +1,66 @@ +# frozen_string_literal: true + +require 'spec_helper' + +RSpec.describe Users::InProductMarketingEmailRecords do + let_it_be(:user) { create :user } + + subject(:records) { described_class.new } + + it 'initializes records' do + expect(subject.records).to match_array [] + end + + describe '#save!' do + before do + allow(Users::InProductMarketingEmail).to receive(:bulk_insert!) + + records.add(user, track: :team_short, series: 0) + records.add(user, track: :create, series: 1) + records.add(user, campaign: Users::InProductMarketingEmail::BUILD_IOS_APP_GUIDE) + end + + it 'bulk inserts added records' do + expect(Users::InProductMarketingEmail).to receive(:bulk_insert!).with(records.records) + records.save! + end + + it 'resets its records' do + records.save! + expect(records.records).to match_array [] + end + end + + describe '#add' do + it 'adds a Users::InProductMarketingEmail record to its records', :aggregate_failures do + freeze_time do + records.add(user, track: :team_short, series: 0) + records.add(user, track: :create, series: 1) + records.add(user, campaign: Users::InProductMarketingEmail::BUILD_IOS_APP_GUIDE) + + first, second, third = records.records + + expect(first).to be_a Users::InProductMarketingEmail + expect(first.campaign).to be_nil + expect(first.track.to_sym).to eq :team_short + expect(first.series).to eq 0 + expect(first.created_at).to eq Time.zone.now + expect(first.updated_at).to eq Time.zone.now + + expect(second).to be_a Users::InProductMarketingEmail + expect(second.campaign).to be_nil + expect(second.track.to_sym).to eq :create + expect(second.series).to eq 1 + expect(second.created_at).to eq Time.zone.now + expect(second.updated_at).to eq Time.zone.now + + expect(third).to be_a Users::InProductMarketingEmail + expect(third.campaign).to eq Users::InProductMarketingEmail::BUILD_IOS_APP_GUIDE + expect(third.track).to be_nil + expect(third.series).to be_nil + expect(third.created_at).to eq Time.zone.now + expect(third.updated_at).to eq Time.zone.now + end + end + end +end |