Commit dd6611fa authored by Lee Tickett's avatar Lee Tickett Committed by Douglas Barbosa Alexandre

Remove `skip_hashed_storage_upgrade` feature flag

parent ba234544
...@@ -124,8 +124,7 @@ module Projects ...@@ -124,8 +124,7 @@ module Projects
def migrate_to_hashed_storage? def migrate_to_hashed_storage?
Gitlab::CurrentSettings.hashed_storage_enabled? && Gitlab::CurrentSettings.hashed_storage_enabled? &&
project.storage_upgradable? && project.storage_upgradable?
Feature.disabled?(:skip_hashed_storage_upgrade)
end end
def send_move_instructions? def send_move_instructions?
......
---
title: Remove skip_hased_storage_upgrade feature flag
merge_request: 29364
author: Lee Tickett
type: other
...@@ -568,25 +568,42 @@ RSpec.describe ProjectsController do ...@@ -568,25 +568,42 @@ RSpec.describe ProjectsController do
end end
context 'when only renaming a project path' do context 'when only renaming a project path' do
it "sets the repository to the right path after a rename" do it "doesnt change the disk_path when using hashed storage" do
skip unless project.hashed_storage?(:repository)
hashed_storage_path = ::Storage::Hashed.new(project).disk_path
original_repository_path = Gitlab::GitalyClient::StorageSettings.allow_disk_access do original_repository_path = Gitlab::GitalyClient::StorageSettings.allow_disk_access do
project.repository.path project.repository.path
end end
expect { update_project path: 'renamed_path' } expect { update_project path: 'renamed_path' }.to change { project.reload.path }
.to change { project.reload.path }
expect(project.path).to include 'renamed_path' expect(project.path).to include 'renamed_path'
assign_repository_path = Gitlab::GitalyClient::StorageSettings.allow_disk_access do assign_repository_path = Gitlab::GitalyClient::StorageSettings.allow_disk_access do
assigns(:repository).path assigns(:repository).path
end end
if project.hashed_storage?(:repository) expect(original_repository_path).to include(hashed_storage_path)
expect(assign_repository_path).to eq(original_repository_path) expect(assign_repository_path).to include(hashed_storage_path)
else end
expect(assign_repository_path).to include(project.path)
it "upgrades and move project to hashed storage when project was originally legacy" do
skip if project.hashed_storage?(:repository)
hashed_storage_path = Storage::Hashed.new(project).disk_path
original_repository_path = Gitlab::GitalyClient::StorageSettings.allow_disk_access do
project.repository.path
end
expect { update_project path: 'renamed_path' }.to change { project.reload.path }
expect(project.path).to include 'renamed_path'
assign_repository_path = Gitlab::GitalyClient::StorageSettings.allow_disk_access do
assigns(:repository).path
end end
expect(original_repository_path).not_to include(hashed_storage_path)
expect(assign_repository_path).to include(hashed_storage_path)
expect(response).to have_gitlab_http_status(:found) expect(response).to have_gitlab_http_status(:found)
end end
end end
......
...@@ -22,7 +22,6 @@ RSpec.describe Projects::AfterRenameService do ...@@ -22,7 +22,6 @@ RSpec.describe Projects::AfterRenameService do
# call. This makes testing a bit easier. # call. This makes testing a bit easier.
allow(project).to receive(:gitlab_shell).and_return(gitlab_shell) allow(project).to receive(:gitlab_shell).and_return(gitlab_shell)
stub_feature_flags(skip_hashed_storage_upgrade: false)
stub_application_setting(hashed_storage_enabled: false) stub_application_setting(hashed_storage_enabled: false)
end end
...@@ -136,7 +135,6 @@ RSpec.describe Projects::AfterRenameService do ...@@ -136,7 +135,6 @@ RSpec.describe Projects::AfterRenameService do
# call. This makes testing a bit easier. # call. This makes testing a bit easier.
allow(project).to receive(:gitlab_shell).and_return(gitlab_shell) allow(project).to receive(:gitlab_shell).and_return(gitlab_shell)
stub_feature_flags(skip_hashed_storage_upgrade: false)
stub_application_setting(hashed_storage_enabled: true) stub_application_setting(hashed_storage_enabled: true)
end end
......
...@@ -325,20 +325,9 @@ RSpec.describe Projects::UpdateService do ...@@ -325,20 +325,9 @@ RSpec.describe Projects::UpdateService do
expect(project.errors.messages[:base]).to include('There is already a repository with that name on disk') expect(project.errors.messages[:base]).to include('There is already a repository with that name on disk')
end end
it 'renames the project without upgrading it' do
result = update_project(project, admin, path: 'new-path')
expect(result).not_to include(status: :error)
expect(project).to be_valid
expect(project.errors).to be_empty
expect(project.disk_path).to include('new-path')
expect(project.reload.hashed_storage?(:repository)).to be_falsey
end
context 'when hashed storage is enabled' do context 'when hashed storage is enabled' do
before do before do
stub_application_setting(hashed_storage_enabled: true) stub_application_setting(hashed_storage_enabled: true)
stub_feature_flags(skip_hashed_storage_upgrade: false)
end end
it 'migrates project to a hashed storage instead of renaming the repo to another legacy name' do it 'migrates project to a hashed storage instead of renaming the repo to another legacy name' do
...@@ -349,22 +338,6 @@ RSpec.describe Projects::UpdateService do ...@@ -349,22 +338,6 @@ RSpec.describe Projects::UpdateService do
expect(project.errors).to be_empty expect(project.errors).to be_empty
expect(project.reload.hashed_storage?(:repository)).to be_truthy expect(project.reload.hashed_storage?(:repository)).to be_truthy
end end
context 'when skip_hashed_storage_upgrade feature flag is enabled' do
before do
stub_feature_flags(skip_hashed_storage_upgrade: true)
end
it 'renames the project without upgrading it' do
result = update_project(project, admin, path: 'new-path')
expect(result).not_to include(status: :error)
expect(project).to be_valid
expect(project.errors).to be_empty
expect(project.disk_path).to include('new-path')
expect(project.reload.hashed_storage?(:repository)).to be_falsey
end
end
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