Commit 4ad251d3 authored by Kamil Trzciński's avatar Kamil Trzciński

Truly create forks when seeding DB

Previously we would not run after commit hooks.
This resulted in a defunct forks.

This additionaly ensures that we generate
only on legitimate users, instead of mass
generated.
parent 4f81918a
...@@ -10,17 +10,30 @@ Sidekiq::Testing.inline! do ...@@ -10,17 +10,30 @@ Sidekiq::Testing.inline! do
# we use randomized approach (e.g. `Array#sample`). # we use randomized approach (e.g. `Array#sample`).
return unless source_project return unless source_project
fork_project = Projects::ForkService.new( Sidekiq::Worker.skipping_transaction_check do
source_project, fork_project = Projects::ForkService.new(
user, source_project,
namespace: user.namespace, user,
skip_disk_validation: true namespace: user.namespace,
).execute skip_disk_validation: true
).execute
if fork_project.valid? # Seed-Fu runs this entire fixture in a transaction, so the `after_commit`
print '.' # hook won't run until after the fixture is loaded. That is too late
else # since the Sidekiq::Testing block has already exited. Force clearing
print 'F' # the `after_commit` queue to ensure the job is run now.
fork_project.send(:_run_after_commit_queue)
fork_project.import_state.send(:_run_after_commit_queue)
# Expire repository cache after import to ensure
# valid_repo? call below returns a correct answer
fork_project.repository.expire_all_method_caches
if fork_project.valid? && fork_project.valid_repo?
print '.'
else
print 'F'
end
end end
end end
end end
......
...@@ -18,6 +18,7 @@ module Gitlab ...@@ -18,6 +18,7 @@ module Gitlab
MASS_INSERT_PROJECT_START = 'mass_insert_project_' MASS_INSERT_PROJECT_START = 'mass_insert_project_'
MASS_INSERT_USER_START = 'mass_insert_user_' MASS_INSERT_USER_START = 'mass_insert_user_'
REPORTED_USER_START = 'reported_user_'
ESTIMATED_INSERT_PER_MINUTE = 2_000_000 ESTIMATED_INSERT_PER_MINUTE = 2_000_000
MASS_INSERT_ENV = 'MASS_INSERT' MASS_INSERT_ENV = 'MASS_INSERT'
...@@ -36,7 +37,7 @@ module Gitlab ...@@ -36,7 +37,7 @@ module Gitlab
included do included do
scope :not_mass_generated, -> do scope :not_mass_generated, -> do
where.not("username LIKE '#{MASS_INSERT_USER_START}%'") where.not("username LIKE '#{MASS_INSERT_USER_START}%' OR username LIKE '#{REPORTED_USER_START}%'")
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