Calculate the checksum for outdated projects with less activity first

parent 70e8f831
...@@ -5,6 +5,7 @@ module Geo ...@@ -5,6 +5,7 @@ module Geo
.with_route .with_route
.joins(:repository_state) .joins(:repository_state)
.where(repository_outdated.or(wiki_outdated)) .where(repository_outdated.or(wiki_outdated))
.order(last_repository_updated_at_asc)
.limit(batch_size) .limit(batch_size)
end end
...@@ -62,5 +63,9 @@ module Geo ...@@ -62,5 +63,9 @@ module Geo
def repository_never_verified def repository_never_verified
repository_state_table[:project_id].eq(nil) repository_state_table[:project_id].eq(nil)
end end
def last_repository_updated_at_asc
Gitlab::Database.nulls_last_order('projects.last_repository_updated_at', 'ASC')
end
end end
end end
...@@ -43,6 +43,16 @@ describe Geo::RepositoryVerificationFinder, :postgresql do ...@@ -43,6 +43,16 @@ describe Geo::RepositoryVerificationFinder, :postgresql do
expect(subject.find_outdated_projects(batch_size: 10)).to be_empty expect(subject.find_outdated_projects(batch_size: 10)).to be_empty
end end
it 'returns less active projects first' do
less_active_project = create(:project)
create(:repository_state, :repository_outdated, project: project)
create(:repository_state, :repository_outdated, project: less_active_project)
project.update_column(:last_repository_updated_at, 30.minutes.ago)
less_active_project.update_column(:last_repository_updated_at, 2.days.ago)
expect(subject.find_outdated_projects(batch_size: 10)).to eq [less_active_project, project]
end
end end
describe '#find_unverified_projects' do describe '#find_unverified_projects' do
......
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