Commit dfe79b3f authored by GitLab Bot's avatar GitLab Bot

Automatic merge of gitlab-org/gitlab-ce master

parents 3f2dbe0e 0ab50681
...@@ -5,7 +5,6 @@ module Projects ...@@ -5,7 +5,6 @@ module Projects
class RepositoryController < Projects::ApplicationController class RepositoryController < Projects::ApplicationController
before_action :authorize_admin_project! before_action :authorize_admin_project!
before_action :remote_mirror, only: [:show] before_action :remote_mirror, only: [:show]
before_action :check_cleanup_feature_flag!, only: :cleanup
prepend ::EE::Projects::Settings::RepositoryController prepend ::EE::Projects::Settings::RepositoryController
...@@ -39,10 +38,6 @@ module Projects ...@@ -39,10 +38,6 @@ module Projects
private private
def check_cleanup_feature_flag!
render_404 unless ::Feature.enabled?(:project_cleanup, project)
end
def render_show def render_show
@deploy_keys = DeployKeysPresenter.new(@project, current_user: current_user) @deploy_keys = DeployKeysPresenter.new(@project, current_user: current_user)
@deploy_tokens = @project.deploy_tokens.active @deploy_tokens = @project.deploy_tokens.active
......
- return unless Feature.enabled?(:project_cleanup, @project)
- expanded = Rails.env.test? - expanded = Rails.env.test?
%section.settings.no-animate#cleanup{ class: ('expanded' if expanded) } %section.settings.no-animate#cleanup{ class: ('expanded' if expanded) }
......
...@@ -20,6 +20,7 @@ module Gitlab ...@@ -20,6 +20,7 @@ module Gitlab
while data = io.read(RepositoryService::MAX_MSG_SIZE) while data = io.read(RepositoryService::MAX_MSG_SIZE)
y.yield Gitaly::ApplyBfgObjectMapRequest.new(object_map: data) y.yield Gitaly::ApplyBfgObjectMapRequest.new(object_map: data)
break if io&.eof?
end end
end end
......
...@@ -19,35 +19,15 @@ describe Projects::Settings::RepositoryController do ...@@ -19,35 +19,15 @@ describe Projects::Settings::RepositoryController do
end end
describe 'PUT cleanup' do describe 'PUT cleanup' do
before do let(:object_map) { fixture_file_upload('spec/fixtures/bfg_object_map.txt') }
allow(RepositoryCleanupWorker).to receive(:perform_async)
end
def do_put! it 'enqueues a RepositoryCleanupWorker' do
object_map = fixture_file_upload('spec/fixtures/bfg_object_map.txt') allow(RepositoryCleanupWorker).to receive(:perform_async)
put :cleanup, namespace_id: project.namespace, project_id: project, project: { object_map: object_map } put :cleanup, namespace_id: project.namespace, project_id: project, project: { object_map: object_map }
end
context 'feature enabled' do
it 'enqueues a RepositoryCleanupWorker' do
stub_feature_flags(project_cleanup: true)
do_put!
expect(response).to redirect_to project_settings_repository_path(project)
expect(RepositoryCleanupWorker).to have_received(:perform_async).once
end
end
context 'feature disabled' do
it 'shows a 404 error' do
stub_feature_flags(project_cleanup: false)
do_put!
expect(response).to have_gitlab_http_status(404) expect(response).to redirect_to project_settings_repository_path(project)
end expect(RepositoryCleanupWorker).to have_received(:perform_async).once
end end
end end
end end
...@@ -200,35 +200,21 @@ describe 'Projects > Settings > Repository settings' do ...@@ -200,35 +200,21 @@ describe 'Projects > Settings > Repository settings' do
context 'repository cleanup settings' do context 'repository cleanup settings' do
let(:object_map_file) { Rails.root.join('spec', 'fixtures', 'bfg_object_map.txt') } let(:object_map_file) { Rails.root.join('spec', 'fixtures', 'bfg_object_map.txt') }
context 'feature enabled' do it 'uploads an object map file', :js do
it 'uploads an object map file', :js do visit project_settings_repository_path(project)
stub_feature_flags(project_cleanup: true)
visit project_settings_repository_path(project)
expect(page).to have_content('Repository cleanup') expect(page).to have_content('Repository cleanup')
page.within('#cleanup') do page.within('#cleanup') do
attach_file('project[bfg_object_map]', object_map_file, visible: false) attach_file('project[bfg_object_map]', object_map_file, visible: false)
Sidekiq::Testing.fake! do Sidekiq::Testing.fake! do
click_button 'Start cleanup' click_button 'Start cleanup'
end
end end
expect(page).to have_content('Repository cleanup has started')
expect(RepositoryCleanupWorker.jobs.count).to eq(1)
end end
end
context 'feature disabled' do expect(page).to have_content('Repository cleanup has started')
it 'does not show the settings' do expect(RepositoryCleanupWorker.jobs.count).to eq(1)
stub_feature_flags(project_cleanup: false)
visit project_settings_repository_path(project)
expect(page).not_to have_content('Repository cleanup')
end
end end
end end
end end
......
require 'spec_helper' require 'spec_helper'
describe Gitlab::Git::RepositoryCleaner do describe Gitlab::Git::RepositoryCleaner do
include HttpIOHelpers
let(:project) { create(:project, :repository) } let(:project) { create(:project, :repository) }
let(:repository) { project.repository } let(:repository) { project.repository }
let(:head_sha) { repository.head_commit.id } let(:head_sha) { repository.head_commit.id }
let(:object_map_data) { "#{head_sha} #{'0' * 40}" }
let(:object_map) { StringIO.new("#{head_sha} #{'0' * 40}") }
subject(:cleaner) { described_class.new(repository.raw) } subject(:cleaner) { described_class.new(repository.raw) }
describe '#apply_bfg_object_map' do describe '#apply_bfg_object_map' do
it 'removes internal references pointing at SHAs in the object map' do let(:clean_refs) { %W[refs/environments/1 refs/merge-requests/1 refs/keep-around/#{head_sha}] }
# Create some refs we expect to be removed let(:keep_refs) { %w[refs/heads/_keep refs/tags/_keep] }
repository.keep_around(head_sha)
repository.create_ref(head_sha, 'refs/environments/1') before do
repository.create_ref(head_sha, 'refs/merge-requests/1') (clean_refs + keep_refs).each { |ref| repository.create_ref(head_sha, ref) }
repository.create_ref(head_sha, 'refs/heads/_keep') end
repository.create_ref(head_sha, 'refs/tags/_keep')
context 'from StringIO' do
cleaner.apply_bfg_object_map(object_map) let(:object_map) { StringIO.new(object_map_data) }
aggregate_failures do it 'removes internal references' do
expect(repository.kept_around?(head_sha)).to be_falsy cleaner.apply_bfg_object_map(object_map)
expect(repository.ref_exists?('refs/environments/1')).to be_falsy
expect(repository.ref_exists?('refs/merge-requests/1')).to be_falsy aggregate_failures do
expect(repository.ref_exists?('refs/heads/_keep')).to be_truthy clean_refs.each { |ref| expect(repository.ref_exists?(ref)).to be_falsy }
expect(repository.ref_exists?('refs/tags/_keep')).to be_truthy keep_refs.each { |ref| expect(repository.ref_exists?(ref)).to be_truthy }
end
end
end
context 'from Gitlab::HttpIO' do
let(:url) { 'http://example.com/bfg_object_map.txt' }
let(:tempfile) { Tempfile.new }
let(:object_map) { Gitlab::HttpIO.new(url, object_map_data.size) }
around do |example|
begin
tempfile.write(object_map_data)
tempfile.close
example.run
ensure
tempfile.unlink
end
end
it 'removes internal references' do
stub_remote_url_200(url, tempfile.path)
cleaner.apply_bfg_object_map(object_map)
aggregate_failures do
clean_refs.each { |ref| expect(repository.ref_exists?(ref)).to be_falsy }
keep_refs.each { |ref| expect(repository.ref_exists?(ref)).to be_truthy }
end
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