1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
|
class ReferentialCloning < ActiveRecord::Base
include AASM
belongs_to :source_referential, class_name: 'Referential'
belongs_to :target_referential, class_name: 'Referential'
after_commit :clone, on: :create
def clone
ReferentialCloningWorker.perform_async(id)
end
def clone_with_status!
run!
clone!
successful!
rescue Exception => e
Rails.logger.error "Clone failed : #{e}"
Rails.logger.error e.backtrace.join('\n')
failed!
end
def clone!
report = Benchmark.measure do
AF83::SchemaCloner
.new(source_referential.slug, target_referential.slug)
.clone_schema
end
target_referential.check_migration_count(report)
end
private
aasm column: :status do
state :new, :initial => true
state :pending
state :successful
state :failed
event :run, after: :update_started_at do
transitions :from => [:new, :failed], :to => :pending
end
event :successful, after: :update_ended_at do
after do
target_referential.update_attribute(:ready, true)
end
transitions :from => [:pending, :failed], :to => :successful
end
event :failed, after: :update_ended_at do
transitions :from => :pending, :to => :failed
end
end
def update_started_at
update_attribute(:started_at, Time.now)
end
def update_ended_at
update_attribute(:ended_at, Time.now)
end
end
|