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
|
# File 'lib/sidekiq/results/middleware.rb', line 8
def call(worker, msg, queue)
data = {
queue: queue,
status: 'busy',
started_at: Time.now.utc.to_f,
processor: identity,
}
start = msg.merge(data).freeze
save_result(start)
yield
rescue => e
data.merge!(
status: 'failed',
error_class: e.class.name,
error_message: e.message,
error_backtrace: e.backtrace,
)
raise e
else
data.merge!(
status: 'processed',
)
ensure
data.merge!(
finished_at: Time.now.utc.to_f,
)
finish = msg.merge(data).freeze
remove_result(start)
save_result(finish)
end
|