Commit cedc0974 authored by Douwe Maan's avatar Douwe Maan

Don't always create a new import_state record from project factory

parent 53d04fa3
...@@ -69,78 +69,44 @@ FactoryBot.define do ...@@ -69,78 +69,44 @@ FactoryBot.define do
end end
trait :import_none do trait :import_none do
transient do import_status :none
status :none
end
before(:create) do |project, evaluator|
project.create_import_state(:status, evaluator.status)
end
end end
trait :import_scheduled do trait :import_scheduled do
transient do import_status :scheduled
status :scheduled
last_update_scheduled_at Time.now
end
before(:create) do |project, evaluator| after(:create) do |project, _|
project.create_import_state(status: evaluator.status, project.import_state&.update_attributes(last_update_scheduled_at: Time.now)
last_update_scheduled_at: evaluator.last_update_scheduled_at)
end end
end end
trait :import_started do trait :import_started do
transient do import_status :started
status :started
last_update_started_at Time.now
end
before(:create) do |project, evaluator| after(:create) do |project, _|
project.create_import_state(status: evaluator.status, project.import_state&.update_attributes(last_update_started_at: Time.now)
last_update_started_at: evaluator.last_update_started_at)
end end
end end
trait :import_finished do trait :import_finished do
transient do
timestamp = Time.now timestamp = Time.now
status :finished import_status :finished
last_update_at timestamp mirror_last_update_at timestamp
last_successful_update_at timestamp mirror_last_successful_update_at timestamp
end
before(:create) do |project, evaluator|
project.create_import_state(status: evaluator.status,
last_update_at: evaluator.last_update_at,
last_successful_update_at: evaluator.last_successful_update_at)
end
end end
trait :import_failed do trait :import_failed do
transient do import_status :failed
status :failed mirror_last_update_at { Time.now }
last_update_at { Time.now }
end
before(:create) do |project, evaluator|
project.create_import_state(status: evaluator.status,
last_update_at: evaluator.last_update_at)
end
end end
trait :import_hard_failed do trait :import_hard_failed do
transient do import_status :failed
status :failed mirror_last_update_at { Time.now - 1.minute }
retry_count Gitlab::Mirror::MAX_RETRY + 1
last_update_at Time.now - 1.minute
end
before(:create) do |project, evaluator| after(:create) do |project|
project.create_import_state(status: evaluator.status, project.import_state&.update_attributes(retry_count: Gitlab::Mirror::MAX_RETRY + 1)
retry_count: evaluator.retry_count,
last_update_at: evaluator.last_update_at)
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