Commit a6fb4bb1 authored by Kamil Trzciński's avatar Kamil Trzciński

Merge branch '300615-stop-removing-pages-from-disk-if-feature-flag-is-disabled' into 'master'

Mark pages as not deployed and remove domains synchrounsly

See merge request gitlab-org/gitlab!53137
parents 9da4bd72 82efa0fc
...@@ -117,7 +117,7 @@ class Project < ApplicationRecord ...@@ -117,7 +117,7 @@ class Project < ApplicationRecord
use_fast_destroy :build_trace_chunks use_fast_destroy :build_trace_chunks
after_destroy -> { run_after_commit { remove_pages } } after_destroy -> { run_after_commit { legacy_remove_pages } }
after_destroy :remove_exports after_destroy :remove_exports
after_validation :check_pending_delete after_validation :check_pending_delete
...@@ -1788,16 +1788,16 @@ class Project < ApplicationRecord ...@@ -1788,16 +1788,16 @@ class Project < ApplicationRecord
.delete_all .delete_all
end end
# TODO: what to do here when not using Legacy Storage? Do we still need to rename and delay removal? # TODO: remove this method https://gitlab.com/gitlab-org/gitlab/-/issues/320775
# rubocop: disable CodeReuse/ServiceClass # rubocop: disable CodeReuse/ServiceClass
def remove_pages def legacy_remove_pages
return unless Feature.enabled?(:pages_update_legacy_storage, default_enabled: true)
# Projects with a missing namespace cannot have their pages removed # Projects with a missing namespace cannot have their pages removed
return unless namespace return unless namespace
mark_pages_as_not_deployed unless destroyed? mark_pages_as_not_deployed unless destroyed?
DestroyPagesDeploymentsWorker.perform_async(id)
# 1. We rename pages to temporary directory # 1. We rename pages to temporary directory
# 2. We wait 5 minutes, due to NFS caching # 2. We wait 5 minutes, due to NFS caching
# 3. We asynchronously remove pages with force # 3. We asynchronously remove pages with force
......
...@@ -3,7 +3,13 @@ ...@@ -3,7 +3,13 @@
module Pages module Pages
class DeleteService < BaseService class DeleteService < BaseService
def execute def execute
PagesRemoveWorker.perform_async(project.id) project.mark_pages_as_not_deployed # prevents domain from updating config when deleted
project.pages_domains.delete_all
DestroyPagesDeploymentsWorker.perform_async(project.id)
# TODO: remove this call https://gitlab.com/gitlab-org/gitlab/-/issues/320775
PagesRemoveWorker.perform_async(project.id) if Feature.enabled?(:pages_update_legacy_storage, default_enabled: true)
end end
end end
end end
# frozen_string_literal: true # frozen_string_literal: true
# TODO: remove this worker https://gitlab.com/gitlab-org/gitlab/-/issues/320775
class PagesRemoveWorker # rubocop:disable Scalability/IdempotentWorker class PagesRemoveWorker # rubocop:disable Scalability/IdempotentWorker
include ApplicationWorker include ApplicationWorker
...@@ -11,7 +12,6 @@ class PagesRemoveWorker # rubocop:disable Scalability/IdempotentWorker ...@@ -11,7 +12,6 @@ class PagesRemoveWorker # rubocop:disable Scalability/IdempotentWorker
project = Project.find_by_id(project_id) project = Project.find_by_id(project_id)
return unless project return unless project
project.remove_pages project.legacy_remove_pages
project.pages_domains.delete_all
end end
end end
...@@ -4117,7 +4117,7 @@ RSpec.describe Project, factory_default: :keep do ...@@ -4117,7 +4117,7 @@ RSpec.describe Project, factory_default: :keep do
end end
end end
describe '#remove_pages' do describe '#legacy_remove_pages' do
let(:project) { create(:project).tap { |project| project.mark_pages_as_deployed } } let(:project) { create(:project).tap { |project| project.mark_pages_as_deployed } }
let(:pages_metadatum) { project.pages_metadatum } let(:pages_metadatum) { project.pages_metadatum }
let(:namespace) { project.namespace } let(:namespace) { project.namespace }
...@@ -4136,34 +4136,22 @@ RSpec.describe Project, factory_default: :keep do ...@@ -4136,34 +4136,22 @@ RSpec.describe Project, factory_default: :keep do
expect_any_instance_of(Gitlab::PagesTransfer).to receive(:rename_project).and_return(true) expect_any_instance_of(Gitlab::PagesTransfer).to receive(:rename_project).and_return(true)
expect(PagesWorker).to receive(:perform_in).with(5.minutes, :remove, namespace.full_path, anything) expect(PagesWorker).to receive(:perform_in).with(5.minutes, :remove, namespace.full_path, anything)
expect { project.remove_pages }.to change { pages_metadatum.reload.deployed }.from(true).to(false) expect { project.legacy_remove_pages }.to change { pages_metadatum.reload.deployed }.from(true).to(false)
end end
it 'is run when the project is destroyed' do it 'does nothing if updates on legacy storage are disabled' do
expect(project).to receive(:remove_pages).and_call_original stub_feature_flags(pages_update_legacy_storage: false)
expect { project.destroy }.not_to raise_error
end
context 'when there is an old pages deployment' do
let!(:old_deployment_from_another_project) { create(:pages_deployment) }
let!(:old_deployment) { create(:pages_deployment, project: project) }
it 'schedules a destruction of pages deployments' do expect(Gitlab::PagesTransfer).not_to receive(:new)
expect(DestroyPagesDeploymentsWorker).to( expect(PagesWorker).not_to receive(:perform_in)
receive(:perform_async).with(project.id)
)
project.remove_pages project.legacy_remove_pages
end end
it 'removes pages deployments', :sidekiq_inline do it 'is run when the project is destroyed' do
expect do expect(project).to receive(:legacy_remove_pages).and_call_original
project.remove_pages
end.to change { PagesDeployment.count }.by(-1)
expect(PagesDeployment.find_by_id(old_deployment.id)).to be_nil expect { project.destroy }.not_to raise_error
end
end end
end end
......
...@@ -3,35 +3,74 @@ ...@@ -3,35 +3,74 @@
require 'spec_helper' require 'spec_helper'
RSpec.describe Pages::DeleteService do RSpec.describe Pages::DeleteService do
shared_examples 'remove pages' do
let_it_be(:project) { create(:project, path: "my.project")}
let_it_be(:admin) { create(:admin) } let_it_be(:admin) { create(:admin) }
let_it_be(:domain) { create(:pages_domain, project: project) }
let_it_be(:service) { described_class.new(project, admin)}
it 'deletes published pages' do let(:project) { create(:project, path: "my.project")}
let!(:domain) { create(:pages_domain, project: project) }
let(:service) { described_class.new(project, admin)}
before do
project.mark_pages_as_deployed
end
it 'deletes published pages', :sidekiq_inline do
expect(project.pages_deployed?).to be(true)
expect_any_instance_of(Gitlab::PagesTransfer).to receive(:rename_project).and_return true expect_any_instance_of(Gitlab::PagesTransfer).to receive(:rename_project).and_return true
expect(PagesWorker).to receive(:perform_in).with(5.minutes, :remove, project.namespace.full_path, anything) expect(PagesWorker).to receive(:perform_in).with(5.minutes, :remove, project.namespace.full_path, anything)
Sidekiq::Testing.inline! { service.execute } service.execute
expect(project.pages_deployed?).to be(false)
end
it "doesn't remove anything from the legacy storage if updates on it are disabled", :sidekiq_inline do
stub_feature_flags(pages_update_legacy_storage: false)
expect(project.pages_deployed?).to be(true)
expect(PagesWorker).not_to receive(:perform_in)
expect(project.reload.pages_metadatum.deployed?).to be(false) service.execute
expect(project.pages_deployed?).to be(false)
end end
it 'deletes all domains' do it 'deletes all domains', :sidekiq_inline do
expect(project.pages_domains.count).to be 1 expect(project.pages_domains.count).to eq(1)
Sidekiq::Testing.inline! { service.execute } service.execute
expect(project.reload.pages_domains.count).to be 0 expect(project.reload.pages_domains.count).to eq(0)
end end
it 'schedules a destruction of pages deployments' do
expect(DestroyPagesDeploymentsWorker).to(
receive(:perform_async).with(project.id)
)
service.execute
end end
context 'with feature flag enabled' do it 'removes pages deployments', :sidekiq_inline do
before do create(:pages_deployment, project: project)
expect(PagesRemoveWorker).to receive(:perform_async).and_call_original
expect do
service.execute
end.to change { PagesDeployment.count }.by(-1)
end end
it_behaves_like 'remove pages' it 'marks pages as not deployed, deletes domains and schedules worker to remove pages from disk' do
expect(project.pages_deployed?).to eq(true)
expect(project.pages_domains.count).to eq(1)
service.execute
expect(project.pages_deployed?).to eq(false)
expect(project.pages_domains.count).to eq(0)
expect_any_instance_of(Gitlab::PagesTransfer).to receive(:rename_project).and_return true
Sidekiq::Worker.drain_all
end end
end end
...@@ -16,7 +16,7 @@ RSpec.describe Projects::UpdatePagesService do ...@@ -16,7 +16,7 @@ RSpec.describe Projects::UpdatePagesService do
subject { described_class.new(project, build) } subject { described_class.new(project, build) }
before do before do
project.remove_pages project.legacy_remove_pages
end end
context '::TMP_EXTRACT_PATH' do context '::TMP_EXTRACT_PATH' do
......
...@@ -49,7 +49,7 @@ RSpec.describe NamespacelessProjectDestroyWorker do ...@@ -49,7 +49,7 @@ RSpec.describe NamespacelessProjectDestroyWorker do
subject.perform(project.id) subject.perform(project.id)
end end
it 'does not do anything in Project#remove_pages method' do it 'does not do anything in Project#legacy_remove_pages method' do
expect(Gitlab::PagesTransfer).not_to receive(:new) expect(Gitlab::PagesTransfer).not_to receive(:new)
subject.perform(project.id) subject.perform(project.id)
......
...@@ -3,24 +3,23 @@ ...@@ -3,24 +3,23 @@
require 'spec_helper' require 'spec_helper'
RSpec.describe PagesRemoveWorker do RSpec.describe PagesRemoveWorker do
let_it_be(:project) { create(:project, path: "my.project")} let(:project) { create(:project, path: "my.project")}
let_it_be(:domain) { create(:pages_domain, project: project) } let!(:domain) { create(:pages_domain, project: project) }
subject { described_class.new.perform(project.id) } subject { described_class.new.perform(project.id) }
before do
project.mark_pages_as_deployed
end
it 'deletes published pages' do it 'deletes published pages' do
expect(project.pages_deployed?).to be(true)
expect_any_instance_of(Gitlab::PagesTransfer).to receive(:rename_project).and_return true expect_any_instance_of(Gitlab::PagesTransfer).to receive(:rename_project).and_return true
expect(PagesWorker).to receive(:perform_in).with(5.minutes, :remove, project.namespace.full_path, anything) expect(PagesWorker).to receive(:perform_in).with(5.minutes, :remove, project.namespace.full_path, anything)
subject subject
expect(project.reload.pages_metadatum.deployed?).to be(false) expect(project.reload.pages_deployed?).to be(false)
end
it 'deletes all domains' do
expect(project.pages_domains.count).to be 1
subject
expect(project.reload.pages_domains.count).to be 0
end end
end end
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