Commit caa2bfa0 authored by Igor Drozdov's avatar Igor Drozdov

Merge branch 'sh-exclude-existing-lfs-oids' into 'master'

Skip already downloaded LFS objects in mirror updates

See merge request gitlab-org/gitlab!66340
parents 46222ee4 36ad365c
...@@ -31,7 +31,7 @@ module Projects ...@@ -31,7 +31,7 @@ module Projects
# #
LfsDownloadLinkListService LfsDownloadLinkListService
.new(project, remote_uri: current_endpoint_uri) .new(project, remote_uri: current_endpoint_uri)
.execute(lfs_pointers_in_repository) .execute(missing_lfs_files)
rescue LfsDownloadLinkListService::DownloadLinksError => e rescue LfsDownloadLinkListService::DownloadLinksError => e
raise LfsObjectDownloadListError, "The LFS objects download list couldn't be imported. Error: #{e.message}" raise LfsObjectDownloadListError, "The LFS objects download list couldn't be imported. Error: #{e.message}"
end end
...@@ -53,6 +53,22 @@ module Projects ...@@ -53,6 +53,22 @@ module Projects
@lfs_pointers_in_repository ||= LfsListService.new(project).execute @lfs_pointers_in_repository ||= LfsListService.new(project).execute
end end
def existing_lfs_objects
project.lfs_objects
end
def existing_lfs_objects_hash
{}.tap do |hash|
existing_lfs_objects.find_each do |lfs_object|
hash[lfs_object.oid] = lfs_object.size
end
end
end
def missing_lfs_files
lfs_pointers_in_repository.except(*existing_lfs_objects_hash.keys)
end
def lfsconfig_endpoint_uri def lfsconfig_endpoint_uri
strong_memoize(:lfsconfig_endpoint_uri) do strong_memoize(:lfsconfig_endpoint_uri) do
# Retrieveing the blob data from the .lfsconfig file # Retrieveing the blob data from the .lfsconfig file
......
...@@ -34,10 +34,24 @@ RSpec.describe Projects::LfsPointers::LfsObjectDownloadListService do ...@@ -34,10 +34,24 @@ RSpec.describe Projects::LfsPointers::LfsObjectDownloadListService do
subject.execute subject.execute
end end
it 'retrieves the download links of non existent objects' do context 'when no LFS objects exist' do
expect_any_instance_of(Projects::LfsPointers::LfsDownloadLinkListService).to receive(:execute).with(all_oids) before do
project.lfs_objects.delete_all
end
subject.execute it 'retrieves all LFS objects' do
expect_any_instance_of(Projects::LfsPointers::LfsDownloadLinkListService).to receive(:execute).with(all_oids)
subject.execute
end
end
context 'when some LFS objects already exist' do
it 'retrieves the download links of non-existent objects' do
expect_any_instance_of(Projects::LfsPointers::LfsDownloadLinkListService).to receive(:execute).with(oids)
subject.execute
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