debian-mirror-gitlab/spec/lib/gitlab/email/service_desk_email_spec.rb

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

54 lines
1.4 KiB
Ruby
Raw Normal View History

2020-07-28 23:09:34 +05:30
# frozen_string_literal: true
2023-01-13 00:05:48 +05:30
require 'spec_helper'
2020-07-28 23:09:34 +05:30
2023-06-20 00:43:36 +05:30
RSpec.describe Gitlab::Email::ServiceDeskEmail, feature_category: :service_desk do
2023-01-13 00:05:48 +05:30
let(:setting_name) { :service_desk_email }
2020-07-28 23:09:34 +05:30
2023-01-13 00:05:48 +05:30
it_behaves_like 'common email methods'
2020-07-28 23:09:34 +05:30
describe '.key_from_address' do
context 'when service desk address is set' do
before do
stub_service_desk_email_setting(address: 'address+%{key}@example.com')
end
it 'returns key' do
expect(described_class.key_from_address('address+key@example.com')).to eq('key')
end
end
context 'when service desk address is not set' do
before do
stub_service_desk_email_setting(address: nil)
end
it 'returns nil' do
expect(described_class.key_from_address('address+key@example.com')).to be_nil
end
end
end
2020-10-24 23:57:45 +05:30
describe '.address_for_key' do
context 'when service desk address is set' do
before do
stub_service_desk_email_setting(address: 'address+%{key}@example.com')
end
it 'returns address' do
expect(described_class.address_for_key('foo')).to eq('address+foo@example.com')
end
end
context 'when service desk address is not set' do
before do
stub_service_desk_email_setting(address: nil)
end
it 'returns nil' do
expect(described_class.key_from_address('foo')).to be_nil
end
end
end
2020-07-28 23:09:34 +05:30
end