2019-12-04 20:38:33 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
RSpec.describe Pages::LookupPath 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"])
|
|
|
|
stub_artifacts_object_storage
|
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-01-29 00:20:46 +05:30
|
|
|
shared_examples 'uses disk storage' do
|
|
|
|
it 'uses disk storage', :aggregate_failures do
|
|
|
|
expect(source[:type]).to eq('file')
|
|
|
|
expect(source[:path]).to eq(project.full_path + "/public/")
|
2020-11-24 15:15:51 +05:30
|
|
|
end
|
2019-12-04 20:38:33 +05:30
|
|
|
end
|
|
|
|
|
2020-11-24 15:15:51 +05:30
|
|
|
include_examples 'uses disk storage'
|
|
|
|
|
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
|
|
|
|
Timecop.freeze do
|
|
|
|
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
|
|
|
|
})
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when deployment is in the local storage' do
|
|
|
|
before do
|
|
|
|
deployment.file.migrate!(::ObjectStorage::Store::LOCAL)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'uses file protocol' do
|
|
|
|
Timecop.freeze do
|
|
|
|
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
|
|
|
|
})
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when pages_serve_with_zip_file_protocol feature flag is disabled' do
|
|
|
|
before do
|
|
|
|
stub_feature_flags(pages_serve_with_zip_file_protocol: false)
|
|
|
|
end
|
|
|
|
|
|
|
|
include_examples 'uses disk storage'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when pages_serve_from_deployments feature flag is disabled' do
|
|
|
|
before do
|
|
|
|
stub_feature_flags(pages_serve_from_deployments: false)
|
|
|
|
end
|
|
|
|
|
|
|
|
include_examples 'uses disk storage'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-11-24 15:15:51 +05:30
|
|
|
context 'when artifact_id from build job is present in pages metadata' do
|
|
|
|
let(:artifacts_archive) { create(:ci_job_artifact, :zip, :remote_store, project: project) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
project.mark_pages_as_deployed(artifacts_archive: artifacts_archive)
|
|
|
|
end
|
|
|
|
|
2021-01-29 00:20:46 +05:30
|
|
|
it 'uses artifacts object storage' do
|
2020-11-24 15:15:51 +05:30
|
|
|
Timecop.freeze do
|
2021-01-29 00:20:46 +05:30
|
|
|
expect(source).to(
|
|
|
|
eq({
|
|
|
|
type: 'zip',
|
|
|
|
path: artifacts_archive.file.url(expire_at: 1.day.from_now),
|
|
|
|
global_id: "gid://gitlab/Ci::JobArtifact/#{artifacts_archive.id}",
|
|
|
|
sha256: artifacts_archive.file_sha256,
|
|
|
|
file_size: artifacts_archive.size,
|
|
|
|
file_count: nil
|
|
|
|
})
|
|
|
|
)
|
2020-11-24 15:15:51 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when artifact is not uploaded to object storage' do
|
|
|
|
let(:artifacts_archive) { create(:ci_job_artifact, :zip) }
|
|
|
|
|
2021-01-29 00:20:46 +05:30
|
|
|
it 'uses file protocol', :aggregate_failures do
|
|
|
|
Timecop.freeze do
|
|
|
|
expect(source).to(
|
|
|
|
eq({
|
|
|
|
type: 'zip',
|
|
|
|
path: 'file://' + artifacts_archive.file.path,
|
|
|
|
global_id: "gid://gitlab/Ci::JobArtifact/#{artifacts_archive.id}",
|
|
|
|
sha256: artifacts_archive.file_sha256,
|
|
|
|
file_size: artifacts_archive.size,
|
|
|
|
file_count: nil
|
|
|
|
})
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when pages_serve_with_zip_file_protocol feature flag is disabled' do
|
|
|
|
before do
|
|
|
|
stub_feature_flags(pages_serve_with_zip_file_protocol: false)
|
|
|
|
end
|
|
|
|
|
|
|
|
include_examples 'uses disk storage'
|
|
|
|
end
|
2020-11-24 15:15:51 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
context 'when feature flag is disabled' do
|
|
|
|
before do
|
2021-01-29 00:20:46 +05:30
|
|
|
stub_feature_flags(pages_serve_from_artifacts_archive: false)
|
2020-11-24 15:15:51 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
include_examples 'uses disk storage'
|
|
|
|
end
|
2019-12-04 20:38:33 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#prefix' do
|
2019-12-21 20:55:43 +05:30
|
|
|
it 'returns "/" for pages group root projects' do
|
|
|
|
project = instance_double(Project, pages_group_root?: true)
|
|
|
|
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
|
|
|
|
project = instance_double(Project, pages_group_root?: false, full_path: 'mygroup/myproject')
|
|
|
|
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
|
|
|
|
end
|