sentry-delayed_job/example/app.rb
# frozen_string_literal: true
require "active_job"
require "active_record"
require "delayed_job"
require "delayed_job_active_record"
require "sentry-delayed_job"
# require "logger"
# This connection will do for database-independent bug reports.
ActiveRecord::Base.establish_connection(adapter: "sqlite3", database: ":memory:")
# ActiveRecord::Base.logger = Logger.new(STDOUT)
ActiveRecord::Schema.define do
create_table :delayed_jobs do |table|
table.integer :priority, default: 0, null: false # Allows some jobs to jump to the front of the queue
table.integer :attempts, default: 0, null: false # Provides for retries, but still fail eventually.
table.text :handler, null: false # YAML-encoded string of the object that will do work
table.text :last_error # reason for last failure (See Note below)
table.datetime :run_at # When to run. Could be Time.zone.now for immediately, or sometime in the future.
table.datetime :locked_at # Set when a client is working on this object
table.datetime :failed_at # Set when all retries have failed (actually, by default, the record is deleted instead)
table.string :locked_by # Who is working on this object (if locked)
table.string :queue # The name of the queue this job is in
table.timestamps null: true
end
end
Sentry.init do |config|
config.breadcrumbs_logger = [:sentry_logger]
# replace it with your sentry dsn
config.dsn = 'https://2fb45f003d054a7ea47feb45898f7649@o447951.ingest.sentry.io/5434472'
end
class MyJob < ActiveJob::Base
self.queue_adapter = :delayed_job
def perform
raise "foo"
end
end
MyJob.perform_later
enqueued_job = Delayed::Backend::ActiveRecord::Job.last
begin
enqueued_job.invoke_job
rescue => e
puts("active job failed because of \"#{e.message}\"")
end
class Foo
def bar
1 / 0
end
end
Foo.new.delay.bar
enqueued_job = Delayed::Backend::ActiveRecord::Job.last
begin
enqueued_job.invoke_job
rescue => e
puts("inline job failed because of \"#{e.message}\"")
end