summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKrasimir Angelov <kangelov@gitlab.com>2019-09-11 11:54:06 +1200
committerKrasimir Angelov <kangelov@gitlab.com>2019-09-11 11:54:06 +1200
commit268c698faf03948f86ce980945521b44c9fd0483 (patch)
treede49eab0abdcf993f295c13d9b930ef73b726696
parent676675dc0b95194be72dfa13829b5ba06e0d1844 (diff)
downloadgitlab-ce-268c698faf03948f86ce980945521b44c9fd0483.tar.gz
Add tests for Pages::VirtualDomain
-rw-r--r--spec/models/pages/virtual_domain_spec.rb43
1 files changed, 43 insertions, 0 deletions
diff --git a/spec/models/pages/virtual_domain_spec.rb b/spec/models/pages/virtual_domain_spec.rb
new file mode 100644
index 00000000000..eaa57b7acd6
--- /dev/null
+++ b/spec/models/pages/virtual_domain_spec.rb
@@ -0,0 +1,43 @@
+# frozen_string_literal: true
+
+require 'spec_helper'
+
+describe Pages::VirtualDomain do
+ describe '#certificate and #key pair' do
+ let(:domain) { nil }
+ let(:project) { instance_double(Project) }
+
+ subject(:virtual_domain) { described_class.new([project], domain: domain) }
+
+ it 'returns nil if there is no domain provided' do
+ expect(virtual_domain.certificate).to be_nil
+ expect(virtual_domain.key).to be_nil
+ end
+
+ context 'when Pages domain is provided' do
+ let(:domain) { instance_double(PagesDomain, certificate: 'certificate', key: 'key') }
+
+ it 'returns certificate and key from the provided domain' do
+ expect(virtual_domain.certificate).to eq('certificate')
+ expect(virtual_domain.key).to eq('key')
+ end
+ end
+ end
+
+ describe '#lookup_paths' do
+ let(:domain) { instance_double(PagesDomain) }
+ let(:project_a) { instance_double(Project) }
+ let(:project_z) { instance_double(Project) }
+ let(:pages_lookup_path_a) { instance_double(Pages::LookupPath, prefix: 'aaa') }
+ let(:pages_lookup_path_z) { instance_double(Pages::LookupPath, prefix: 'zzz') }
+
+ subject(:virtual_domain) { described_class.new([project_a, project_z], domain: domain) }
+
+ it 'returns collection of projects pages lookup paths sorted by prefix in reverse' do
+ expect(project_a).to receive(:pages_lookup_path).with(domain: domain).and_return(pages_lookup_path_a)
+ expect(project_z).to receive(:pages_lookup_path).with(domain: domain).and_return(pages_lookup_path_z)
+
+ expect(virtual_domain.lookup_paths).to eq([pages_lookup_path_z, pages_lookup_path_a])
+ end
+ end
+end