debian-mirror-gitlab/spec/lib/service_ping/service_ping_settings_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

48 lines
1.3 KiB
Ruby
Raw Normal View History

2021-10-27 15:23:28 +05:30
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe ServicePing::ServicePingSettings do
using RSpec::Parameterized::TableSyntax
describe '#product_intelligence_enabled?' do
where(:usage_ping_enabled, :requires_usage_stats_consent, :expected_product_intelligence_enabled) do
# Usage ping enabled
true | false | true
true | true | false
# Usage ping disabled
false | false | false
false | true | false
end
with_them do
before do
2022-07-16 23:28:13 +05:30
allow(User).to receive(:single_user)
.and_return(instance_double(User, :user, requires_usage_stats_consent?: requires_usage_stats_consent))
2021-10-27 15:23:28 +05:30
stub_config_setting(usage_ping_enabled: usage_ping_enabled)
end
it 'has the correct product_intelligence_enabled?' do
expect(described_class.product_intelligence_enabled?).to eq(expected_product_intelligence_enabled)
end
end
end
describe '#enabled?' do
describe 'has the correct enabled' do
it 'when false' do
stub_config_setting(usage_ping_enabled: false)
expect(described_class.enabled?).to eq(false)
end
it 'when true' do
stub_config_setting(usage_ping_enabled: true)
expect(described_class.enabled?).to eq(true)
end
end
end
end