Tratando de cola un trabajo con delayed_job de la siguiente manera:excepción extraña con delayed_job
Delayed::Job.enqueue(BackgroundProcess.new(current_user, object))
current_user y el objeto no son nulas al imprimirlo a cabo. ¡Lo extraño es que a veces refrescar la página o ejecutar el comando otra vez funciona!
Aquí es la traza excepción:
Delayed::Backend::ActiveRecord::Job Columns (44.8ms) SHOW FIELDS FROM `delayed_jobs`
TypeError (wrong argument type nil (expected Data)):
/Users/.rvm/rubies/ruby-1.9.1-p378/lib/ruby/1.9.1/yaml.rb:391:in `emit'
/Users/.rvm/rubies/ruby-1.9.1-p378/lib/ruby/1.9.1/yaml.rb:391:in `quick_emit'
/Users/.rvm/rubies/ruby-1.9.1-p378/lib/ruby/1.9.1/yaml/rubytypes.rb:86:in `to_yaml'
vendor/plugins/delayed_job/lib/delayed/backend/base.rb:65:in `payload_object='
activerecord (2.3.9) lib/active_record/base.rb:2918:in `block in assign_attributes'
activerecord (2.3.9) lib/active_record/base.rb:2914:in `each'
activerecord (2.3.9) lib/active_record/base.rb:2914:in `assign_attributes'
activerecord (2.3.9) lib/active_record/base.rb:2787:in `attributes='
activerecord (2.3.9) lib/active_record/base.rb:2477:in `initialize'
activerecord (2.3.9) lib/active_record/base.rb:725:in `new'
activerecord (2.3.9) lib/active_record/base.rb:725:in `create'
vendor/plugins/delayed_job/lib/delayed/backend/base.rb:21:in `enqueue'
Muchas gracias, esto solucionó mi problema – Tam
Serializar el objeto original no es algo terrible de hacer. Uno siempre debe retirar una copia nueva mientras está en el trabajo; sin embargo, le da la opción de ver una copia previa del registro si es necesario. – Nick