Time-setting / parsing failure
coffeeaddict opened this issue · 2 comments
I am not particular sure where to file this one, so I will just file it here, in the ruote 'core'.
I have a Rails application with Ruote and a ruote-mon storage. In my process, a reminder is sent x-days after some participant in the flow has done her job.
The short version of the pdef looks something like:
define workflow
my_participant
sequence
wait until: '${f:reminder}'
send_mail mail: 'reminder_mail'
and my first-stab-at-a participant looked like:
class MyParticipant < Ruote::Participant
def on_workitem
# ...
workitem.fields['reminder'] = 20.days.from_now
end
end
This fails because I use ruote-mon. BSON does not play nice with the ActiveSupport::TimeWithZone, and only accepts 20.days.from_now.utc
. That is fine by me, I do not expect the storage layer of ruote to handle with such detail.
When using the time as .utc, the final string in the reminder field turns into: '2013-02-08T17:36:10Z' - which raises
ArgumentError: cannot parse '2013-02-08T17:36:10Z'
from /.../ruby/1.9.1/gems/rufus-scheduler-2.0.17/lib/rufus/sc/rtime.rb:139:in `parse_time_string'
from /.../ruby/1.9.1/gems/ruote-2.3.0.2/lib/ruote/util/time.rb:78:in `s_to_at'
from /.../ruby/1.9.1/gems/ruote-2.3.0.2/lib/ruote/storage/base.rb:343:in `prepare_schedule_doc'
from /.../ruby/1.9.1/gems/ruote-2.3.0.2/lib/ruote/storage/base.rb:198:in `put_schedule'
... etc. etc ...
(tell me if you need more)
I believe that this notation is a viable, parsable string representation of a time that ruote (or rufus) should parse
As a work-around I am now using strftime;
workitem.fields['reminder'] = 20.days.from_now.strftime("%F %T")
Many thanks!
👍 for the quick fix