debian-mirror-gitlab/spec/models/application_setting/term_spec.rb

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

58 lines
1.5 KiB
Ruby
Raw Normal View History

2019-07-07 11:18:12 +05:30
# frozen_string_literal: true
2018-10-15 14:42:47 +05:30
require 'spec_helper'
2020-07-28 23:09:34 +05:30
RSpec.describe ApplicationSetting::Term do
2021-09-30 23:02:18 +05:30
it { is_expected.to validate_presence_of(:terms) }
2018-10-15 14:42:47 +05:30
describe '.latest' do
it 'finds the latest terms' do
terms = create(:term)
expect(described_class.latest).to eq(terms)
end
end
2018-11-08 19:23:39 +05:30
describe '#accepted_by_user?' do
let(:user) { create(:user) }
2021-01-03 14:25:43 +05:30
let(:project_bot) { create(:user, :project_bot) }
2018-11-08 19:23:39 +05:30
let(:term) { create(:term) }
it 'is true when the user accepted the terms' do
accept_terms(term, user)
expect(term.accepted_by_user?(user)).to be(true)
end
2021-01-03 14:25:43 +05:30
it 'is true when user is a bot' do
expect(term.accepted_by_user?(project_bot)).to be(true)
end
2018-11-08 19:23:39 +05:30
it 'is false when the user declined the terms' do
decline_terms(term, user)
expect(term.accepted_by_user?(user)).to be(false)
end
it 'does not cause a query when the user accepted the current terms' do
accept_terms(term, user)
expect { term.accepted_by_user?(user) }.not_to exceed_query_limit(0)
end
it 'returns false if the currently accepted terms are different' do
accept_terms(create(:term), user)
expect(term.accepted_by_user?(user)).to be(false)
end
def accept_terms(term, user)
Users::RespondToTermsService.new(user, term).execute(accepted: true)
end
def decline_terms(term, user)
Users::RespondToTermsService.new(user, term).execute(accepted: false)
end
end
2018-10-15 14:42:47 +05:30
end