Commit 7e79752a authored by Vladimir Shushlin's avatar Vladimir Shushlin

Save artifacts_archive in pages metadatum

We'll use it to test new zip pages serving
https://gitlab.com/groups/gitlab-org/-/epics/3904
parent 41de26fa
...@@ -1828,12 +1828,12 @@ class Project < ApplicationRecord ...@@ -1828,12 +1828,12 @@ class Project < ApplicationRecord
end end
# rubocop: enable CodeReuse/ServiceClass # rubocop: enable CodeReuse/ServiceClass
def mark_pages_as_deployed def mark_pages_as_deployed(artifacts_archive: nil)
ensure_pages_metadatum.update!(deployed: true) ensure_pages_metadatum.update!(deployed: true, artifacts_archive: artifacts_archive)
end end
def mark_pages_as_not_deployed def mark_pages_as_not_deployed
ensure_pages_metadatum.update!(deployed: false) ensure_pages_metadatum.update!(deployed: false, artifacts_archive: nil)
end end
def write_repository_config(gl_full_path: full_path) def write_repository_config(gl_full_path: full_path)
......
...@@ -4,6 +4,7 @@ class ProjectPagesMetadatum < ApplicationRecord ...@@ -4,6 +4,7 @@ class ProjectPagesMetadatum < ApplicationRecord
self.primary_key = :project_id self.primary_key = :project_id
belongs_to :project, inverse_of: :pages_metadatum belongs_to :project, inverse_of: :pages_metadatum
belongs_to :artifacts_archive, class_name: 'Ci::JobArtifact'
scope :deployed, -> { where(deployed: true) } scope :deployed, -> { where(deployed: true) }
end end
...@@ -52,7 +52,7 @@ module Projects ...@@ -52,7 +52,7 @@ module Projects
def success def success
@status.success @status.success
@project.mark_pages_as_deployed @project.mark_pages_as_deployed(artifacts_archive: build.job_artifacts_archive)
super super
end end
......
---
title: Save pages build artifact id in pages metadata
merge_request: 40592
author:
type: added
# frozen_string_literal: true
class AddCiJobArtifactIdToPagesMetadata < ActiveRecord::Migration[6.0]
DOWNTIME = false
def change
add_column(:project_pages_metadata, :artifacts_archive_id, :bigint)
end
end
# frozen_string_literal: true
class AddForeignKeyToArtifactsArchiveIdInPagesMetadata < ActiveRecord::Migration[6.0]
include Gitlab::Database::MigrationHelpers
DOWNTIME = false
INDEX_NAME = "index_project_pages_metadata_on_artifacts_archive_id"
disable_ddl_transaction!
def up
add_concurrent_index(:project_pages_metadata, :artifacts_archive_id, name: INDEX_NAME)
add_concurrent_foreign_key(:project_pages_metadata, :ci_job_artifacts, column: :artifacts_archive_id, on_delete: :nullify)
end
def down
remove_foreign_key_if_exists(:project_pages_metadata, :ci_job_artifacts, column: :artifacts_archive_id)
remove_concurrent_index_by_name(:project_pages_metadata, INDEX_NAME)
end
end
d38ef8ccd627e70adf0dd9ac8161235e21afccbc59f1e8d95f379f66eb84630e
\ No newline at end of file
99d95dea0dbb10bcaca5515c144c7fcd1e365e69be5eded223379bf61df69bc3
\ No newline at end of file
...@@ -14508,7 +14508,8 @@ ALTER SEQUENCE public.project_mirror_data_id_seq OWNED BY public.project_mirror_ ...@@ -14508,7 +14508,8 @@ ALTER SEQUENCE public.project_mirror_data_id_seq OWNED BY public.project_mirror_
CREATE TABLE public.project_pages_metadata ( CREATE TABLE public.project_pages_metadata (
project_id bigint NOT NULL, project_id bigint NOT NULL,
deployed boolean DEFAULT false NOT NULL deployed boolean DEFAULT false NOT NULL,
artifacts_archive_id bigint
); );
CREATE TABLE public.project_repositories ( CREATE TABLE public.project_repositories (
...@@ -20464,6 +20465,8 @@ CREATE UNIQUE INDEX index_project_mirror_data_on_project_id ON public.project_mi ...@@ -20464,6 +20465,8 @@ CREATE UNIQUE INDEX index_project_mirror_data_on_project_id ON public.project_mi
CREATE INDEX index_project_mirror_data_on_status ON public.project_mirror_data USING btree (status); CREATE INDEX index_project_mirror_data_on_status ON public.project_mirror_data USING btree (status);
CREATE INDEX index_project_pages_metadata_on_artifacts_archive_id ON public.project_pages_metadata USING btree (artifacts_archive_id);
CREATE UNIQUE INDEX index_project_pages_metadata_on_project_id ON public.project_pages_metadata USING btree (project_id); CREATE UNIQUE INDEX index_project_pages_metadata_on_project_id ON public.project_pages_metadata USING btree (project_id);
CREATE INDEX index_project_pages_metadata_on_project_id_and_deployed_is_true ON public.project_pages_metadata USING btree (project_id) WHERE (deployed = true); CREATE INDEX index_project_pages_metadata_on_project_id_and_deployed_is_true ON public.project_pages_metadata USING btree (project_id) WHERE (deployed = true);
...@@ -21659,6 +21662,9 @@ ALTER TABLE ONLY public.merge_requests ...@@ -21659,6 +21662,9 @@ ALTER TABLE ONLY public.merge_requests
ALTER TABLE ONLY public.ci_builds ALTER TABLE ONLY public.ci_builds
ADD CONSTRAINT fk_6661f4f0e8 FOREIGN KEY (resource_group_id) REFERENCES public.ci_resource_groups(id) ON DELETE SET NULL; ADD CONSTRAINT fk_6661f4f0e8 FOREIGN KEY (resource_group_id) REFERENCES public.ci_resource_groups(id) ON DELETE SET NULL;
ALTER TABLE ONLY public.project_pages_metadata
ADD CONSTRAINT fk_69366a119e FOREIGN KEY (artifacts_archive_id) REFERENCES public.ci_job_artifacts(id) ON DELETE SET NULL;
ALTER TABLE ONLY public.application_settings ALTER TABLE ONLY public.application_settings
ADD CONSTRAINT fk_693b8795e4 FOREIGN KEY (push_rule_id) REFERENCES public.push_rules(id) ON DELETE SET NULL; ADD CONSTRAINT fk_693b8795e4 FOREIGN KEY (push_rule_id) REFERENCES public.push_rules(id) ON DELETE SET NULL;
......
...@@ -5831,32 +5831,57 @@ RSpec.describe Project do ...@@ -5831,32 +5831,57 @@ RSpec.describe Project do
end end
end end
context 'pages deployed' do describe '#mark_pages_as_deployed' do
let(:project) { create(:project) } let(:project) { create(:project) }
let(:artifacts_archive) { create(:ci_job_artifact, project: project) }
{ it "works when artifacts_archive is missing" do
mark_pages_as_deployed: true, project.mark_pages_as_deployed
mark_pages_as_not_deployed: false
}.each do |method_name, flag|
describe method_name do
it "creates new record and sets deployed to #{flag} if none exists yet" do
project.pages_metadatum.destroy!
project.reload
project.send(method_name) expect(project.pages_metadatum.reload.deployed).to eq(true)
end
expect(project.pages_metadatum.reload.deployed).to eq(flag) it "creates new record and sets deployed to true if none exists yet" do
end project.pages_metadatum.destroy!
project.reload
it "updates the existing record and sets deployed to #{flag}" do project.mark_pages_as_deployed(artifacts_archive: artifacts_archive)
pages_metadatum = project.pages_metadatum
pages_metadatum.update!(deployed: !flag)
expect { project.send(method_name) }.to change { expect(project.pages_metadatum.reload.deployed).to eq(true)
pages_metadatum.reload.deployed end
}.from(!flag).to(flag)
end it "updates the existing record and sets deployed to true and records artifact archive" do
end pages_metadatum = project.pages_metadatum
pages_metadatum.update!(deployed: false)
expect do
project.mark_pages_as_deployed(artifacts_archive: artifacts_archive)
end.to change { pages_metadatum.reload.deployed }.from(false).to(true)
.and change { pages_metadatum.reload.artifacts_archive }.from(nil).to(artifacts_archive)
end
end
describe '#mark_pages_as_not_deployed' do
let(:project) { create(:project) }
let(:artifacts_archive) { create(:ci_job_artifact, project: project) }
it "creates new record and sets deployed to false if none exists yet" do
project.pages_metadatum.destroy!
project.reload
project.mark_pages_as_not_deployed
expect(project.pages_metadatum.reload.deployed).to eq(false)
end
it "updates the existing record and sets deployed to false and clears artifacts_archive" do
pages_metadatum = project.pages_metadatum
pages_metadatum.update!(deployed: true, artifacts_archive: artifacts_archive)
expect do
project.mark_pages_as_not_deployed
end.to change { pages_metadatum.reload.deployed }.from(true).to(false)
.and change { pages_metadatum.reload.artifacts_archive }.from(artifacts_archive).to(nil)
end end
end end
......
...@@ -29,8 +29,9 @@ RSpec.describe Projects::UpdatePagesService do ...@@ -29,8 +29,9 @@ RSpec.describe Projects::UpdatePagesService do
context 'for new artifacts' do context 'for new artifacts' do
context "for a valid job" do context "for a valid job" do
let!(:artifacts_archive) { create(:ci_job_artifact, file: file, job: build) }
before do before do
create(:ci_job_artifact, file: file, job: build)
create(:ci_job_artifact, file_type: :metadata, file_format: :gzip, file: metadata, job: build) create(:ci_job_artifact, file_type: :metadata, file_format: :gzip, file: metadata, job: build)
build.reload build.reload
...@@ -49,6 +50,7 @@ RSpec.describe Projects::UpdatePagesService do ...@@ -49,6 +50,7 @@ RSpec.describe Projects::UpdatePagesService do
expect(project.pages_deployed?).to be_falsey expect(project.pages_deployed?).to be_falsey
expect(execute).to eq(:success) expect(execute).to eq(:success)
expect(project.pages_metadatum).to be_deployed expect(project.pages_metadatum).to be_deployed
expect(project.pages_metadatum.artifacts_archive).to eq(artifacts_archive)
expect(project.pages_deployed?).to be_truthy expect(project.pages_deployed?).to be_truthy
# Check that all expected files are extracted # Check that all expected files are extracted
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment