119 lines
4.3 KiB
Ruby
119 lines
4.3 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe Pages::MigrateLegacyStorageToDeploymentService do
|
|
let(:project) { create(:project, :repository) }
|
|
let(:service) { described_class.new(project) }
|
|
|
|
it 'calls ::Pages::ZipDirectoryService' do
|
|
expect_next_instance_of(::Pages::ZipDirectoryService, project.pages_path, ignore_invalid_entries: true) do |zip_service|
|
|
expect(zip_service).to receive(:execute).and_call_original
|
|
end
|
|
|
|
expect(described_class.new(project, ignore_invalid_entries: true).execute[:status]).to eq(:error)
|
|
end
|
|
|
|
context 'when mark_projects_as_not_deployed is passed' do
|
|
let(:service) { described_class.new(project, mark_projects_as_not_deployed: true) }
|
|
|
|
it 'marks pages as not deployed if public directory is absent and invalid entries are ignored' do
|
|
project.mark_pages_as_deployed
|
|
expect(project.pages_metadatum.reload.deployed).to eq(true)
|
|
|
|
expect(service.execute).to(
|
|
eq(status: :success,
|
|
message: "Archive not created. Missing public directory in #{project.pages_path}? Marked project as not deployed")
|
|
)
|
|
|
|
expect(project.pages_metadatum.reload.deployed).to eq(false)
|
|
end
|
|
|
|
it 'does not mark pages as not deployed if public directory is absent but pages_deployment exists' do
|
|
deployment = create(:pages_deployment, project: project)
|
|
project.update_pages_deployment!(deployment)
|
|
project.mark_pages_as_deployed
|
|
expect(project.pages_metadatum.reload.deployed).to eq(true)
|
|
|
|
expect(service.execute).to(
|
|
eq(status: :success,
|
|
message: "Archive not created. Missing public directory in #{project.pages_path}? Marked project as not deployed")
|
|
)
|
|
|
|
expect(project.pages_metadatum.reload.deployed).to eq(true)
|
|
end
|
|
end
|
|
|
|
it 'does not mark pages as not deployed if public directory is absent but invalid entries are not ignored' do
|
|
project.mark_pages_as_deployed
|
|
|
|
expect(project.pages_metadatum.reload.deployed).to eq(true)
|
|
|
|
expect(service.execute).to(
|
|
eq(status: :error,
|
|
message: "Archive not created. Missing public directory in #{project.pages_path}")
|
|
)
|
|
|
|
expect(project.pages_metadatum.reload.deployed).to eq(true)
|
|
end
|
|
|
|
it 'removes pages archive when can not save deployment' do
|
|
archive = fixture_file_upload("spec/fixtures/pages.zip")
|
|
expect_next_instance_of(::Pages::ZipDirectoryService) do |zip_service|
|
|
expect(zip_service).to receive(:execute).and_return(status: :success,
|
|
archive_path: archive.path,
|
|
entries_count: 3)
|
|
end
|
|
|
|
expect_next_instance_of(PagesDeployment) do |deployment|
|
|
expect(deployment).to receive(:save!).and_raise("Something")
|
|
end
|
|
|
|
expect do
|
|
service.execute
|
|
end.to raise_error("Something")
|
|
|
|
expect(File.exist?(archive.path)).to eq(false)
|
|
end
|
|
|
|
context 'when pages site is deployed to legacy storage' do
|
|
before do
|
|
FileUtils.mkdir_p File.join(project.pages_path, "public")
|
|
File.open(File.join(project.pages_path, "public/index.html"), "w") do |f|
|
|
f.write("Hello!")
|
|
end
|
|
end
|
|
|
|
it 'creates pages deployment' do
|
|
expect do
|
|
expect(described_class.new(project).execute).to eq(status: :success)
|
|
end.to change { project.reload.pages_deployments.count }.by(1)
|
|
|
|
deployment = project.pages_metadatum.pages_deployment
|
|
|
|
Zip::File.open(deployment.file.path) do |zip_file|
|
|
expect(zip_file.glob("public").first.ftype).to eq(:directory)
|
|
expect(zip_file.glob("public/index.html").first.get_input_stream.read).to eq("Hello!")
|
|
end
|
|
|
|
expect(deployment.file_count).to eq(2)
|
|
expect(deployment.file_sha256).to eq(Digest::SHA256.file(deployment.file.path).hexdigest)
|
|
end
|
|
|
|
it 'removes tmp pages archive' do
|
|
described_class.new(project).execute
|
|
|
|
expect(File.exist?(File.join(project.pages_path, '@migrated.zip'))).to eq(false)
|
|
end
|
|
|
|
it 'does not change pages deployment if it is set' do
|
|
old_deployment = create(:pages_deployment, project: project)
|
|
project.update_pages_deployment!(old_deployment)
|
|
|
|
expect do
|
|
described_class.new(project).execute
|
|
end.not_to change { project.pages_metadatum.reload.pages_deployment_id }.from(old_deployment.id)
|
|
end
|
|
end
|
|
end
|