debian-mirror-gitlab/spec/models/pages/lookup_path_spec.rb

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

185 lines
5.3 KiB
Ruby
Raw Permalink Normal View History

2019-12-04 20:38:33 +05:30
# frozen_string_literal: true
require 'spec_helper'
2023-03-17 16:20:25 +05:30
RSpec.describe Pages::LookupPath, feature_category: :pages do
2021-01-29 00:20:46 +05:30
let(:project) { create(:project, :pages_private, pages_https_only: true) }
2019-12-04 20:38:33 +05:30
subject(:lookup_path) { described_class.new(project) }
2020-11-24 15:15:51 +05:30
before do
stub_pages_setting(access_control: true, external_https: ["1.1.1.1:443"])
2021-01-29 00:20:46 +05:30
stub_pages_object_storage(::Pages::DeploymentUploader)
2020-11-24 15:15:51 +05:30
end
2019-12-04 20:38:33 +05:30
describe '#project_id' do
it 'delegates to Project#id' do
2020-11-24 15:15:51 +05:30
expect(lookup_path.project_id).to eq(project.id)
2019-12-04 20:38:33 +05:30
end
end
describe '#access_control' do
it 'delegates to Project#private_pages?' do
expect(lookup_path.access_control).to eq(true)
end
end
describe '#https_only' do
subject(:lookup_path) { described_class.new(project, domain: domain) }
context 'when no domain provided' do
let(:domain) { nil }
it 'delegates to Project#pages_https_only?' do
expect(lookup_path.https_only).to eq(true)
end
end
context 'when there is domain provided' do
let(:domain) { instance_double(PagesDomain, https?: false) }
it 'takes into account the https setting of the domain' do
expect(lookup_path.https_only).to eq(false)
end
end
end
describe '#source' do
2021-01-29 00:20:46 +05:30
let(:source) { lookup_path.source }
2020-11-24 15:15:51 +05:30
2021-09-04 01:27:46 +05:30
it 'returns nil' do
2021-03-11 19:13:27 +05:30
expect(source).to eq(nil)
end
2021-01-29 00:20:46 +05:30
context 'when there is pages deployment' do
let(:deployment) { create(:pages_deployment, project: project) }
before do
project.mark_pages_as_deployed
project.pages_metadatum.update!(pages_deployment: deployment)
end
it 'uses deployment from object storage' do
2021-02-22 17:27:13 +05:30
freeze_time do
2023-05-27 22:25:52 +05:30
expect(source).to eq(
type: 'zip',
path: deployment.file.url(expire_at: 1.day.from_now),
global_id: "gid://gitlab/PagesDeployment/#{deployment.id}",
sha256: deployment.file_sha256,
file_size: deployment.size,
file_count: deployment.file_count
2021-01-29 00:20:46 +05:30
)
end
end
2023-03-04 22:38:38 +05:30
it 'does not recreate source hash' do
expect(deployment.file).to receive(:url_or_file_path).once
2.times { lookup_path.source }
end
2021-01-29 00:20:46 +05:30
context 'when deployment is in the local storage' do
before do
deployment.file.migrate!(::ObjectStorage::Store::LOCAL)
end
it 'uses file protocol' do
2021-02-22 17:27:13 +05:30
freeze_time do
2023-05-27 22:25:52 +05:30
expect(source).to eq(
type: 'zip',
path: "file://#{deployment.file.path}",
global_id: "gid://gitlab/PagesDeployment/#{deployment.id}",
sha256: deployment.file_sha256,
file_size: deployment.size,
file_count: deployment.file_count
2021-01-29 00:20:46 +05:30
)
end
end
end
2021-03-11 19:13:27 +05:30
context 'when deployment were created during migration' do
before do
allow(deployment).to receive(:migrated?).and_return(true)
end
it 'uses deployment from object storage' do
freeze_time do
2023-05-27 22:25:52 +05:30
expect(source).to eq(
type: 'zip',
path: deployment.file.url(expire_at: 1.day.from_now),
global_id: "gid://gitlab/PagesDeployment/#{deployment.id}",
sha256: deployment.file_sha256,
file_size: deployment.size,
file_count: deployment.file_count
2021-03-11 19:13:27 +05:30
)
end
end
end
2021-01-29 00:20:46 +05:30
end
2019-12-04 20:38:33 +05:30
end
describe '#prefix' do
2019-12-21 20:55:43 +05:30
it 'returns "/" for pages group root projects' do
2023-03-17 16:20:25 +05:30
project = instance_double(Project, pages_namespace_url: "namespace.test", pages_url: "namespace.test")
2019-12-21 20:55:43 +05:30
lookup_path = described_class.new(project, trim_prefix: 'mygroup')
2019-12-04 20:38:33 +05:30
expect(lookup_path.prefix).to eq('/')
end
2019-12-21 20:55:43 +05:30
it 'returns the project full path with the provided prefix removed' do
2023-03-17 16:20:25 +05:30
project = instance_double(
Project,
pages_namespace_url: "namespace.test",
pages_url: "namespace.other",
full_path: 'mygroup/myproject')
2019-12-21 20:55:43 +05:30
lookup_path = described_class.new(project, trim_prefix: 'mygroup')
expect(lookup_path.prefix).to eq('/myproject/')
end
2019-12-04 20:38:33 +05:30
end
2023-05-27 22:25:52 +05:30
2023-06-20 00:43:36 +05:30
describe '#unique_host' do
2023-05-27 22:25:52 +05:30
let(:project) { build(:project) }
context 'when unique domain is disabled' do
it 'returns nil' do
project.project_setting.pages_unique_domain_enabled = false
2023-06-20 00:43:36 +05:30
expect(lookup_path.unique_host).to be_nil
2023-05-27 22:25:52 +05:30
end
end
context 'when unique domain is enabled' do
it 'returns the project unique domain' do
project.project_setting.pages_unique_domain_enabled = true
project.project_setting.pages_unique_domain = 'unique-domain'
2023-06-20 00:43:36 +05:30
expect(lookup_path.unique_host).to eq('unique-domain.example.com')
end
end
end
describe '#root_directory' do
subject(:lookup_path) { described_class.new(project) }
context 'when there is no deployment' do
it 'returns nil' do
expect(lookup_path.root_directory).to be_nil
end
end
context 'when there is a deployment' do
let(:deployment) { create(:pages_deployment, project: project, root_directory: 'foo') }
before do
project.mark_pages_as_deployed
project.pages_metadatum.update!(pages_deployment: deployment)
end
it 'returns the deployment\'s root_directory' do
expect(lookup_path.root_directory).to eq('foo')
2023-05-27 22:25:52 +05:30
end
end
end
2019-12-04 20:38:33 +05:30
end