2019-07-07 11:18:12 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2019-12-04 20:38:33 +05:30
|
|
|
require 'spec_helper'
|
2018-03-17 18:26:18 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
RSpec.describe UserCallout do
|
2018-03-17 18:26:18 +05:30
|
|
|
let!(:callout) { create(:user_callout) }
|
|
|
|
|
2019-02-15 15:39:39 +05:30
|
|
|
it_behaves_like 'having unique enum values'
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
describe 'relationships' do
|
|
|
|
it { is_expected.to belong_to(:user) }
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'validations' do
|
|
|
|
it { is_expected.to validate_presence_of(:user) }
|
|
|
|
|
|
|
|
it { is_expected.to validate_presence_of(:feature_name) }
|
|
|
|
it { is_expected.to validate_uniqueness_of(:feature_name).scoped_to(:user_id).ignoring_case_sensitivity }
|
|
|
|
end
|
2020-03-13 15:44:24 +05:30
|
|
|
|
2021-04-29 21:17:54 +05:30
|
|
|
describe '#dismissed_after?' do
|
|
|
|
let(:some_feature_name) { described_class.feature_names.keys.second }
|
|
|
|
let(:callout_dismissed_month_ago) { create(:user_callout, feature_name: some_feature_name, dismissed_at: 1.month.ago )}
|
|
|
|
let(:callout_dismissed_day_ago) { create(:user_callout, feature_name: some_feature_name, dismissed_at: 1.day.ago )}
|
|
|
|
|
|
|
|
it 'returns whether a callout dismissed after specified date' do
|
|
|
|
expect(callout_dismissed_month_ago.dismissed_after?(15.days.ago)).to eq(false)
|
|
|
|
expect(callout_dismissed_day_ago.dismissed_after?(15.days.ago)).to eq(true)
|
2020-03-13 15:44:24 +05:30
|
|
|
end
|
|
|
|
end
|
2018-03-17 18:26:18 +05:30
|
|
|
end
|