FIX: Ensure that we cancel any timeout jobs when terminating a track.

This commit is contained in:
Guo Xiang Tan 2017-06-05 16:23:25 +09:00
parent c7108e077e
commit b19bc887e8
4 changed files with 21 additions and 19 deletions

View File

@ -77,5 +77,20 @@ module DiscourseNarrativeBot
topic.pm_with_non_human_user? && topic.pm_with_non_human_user? &&
topic.topic_allowed_users.where(user_id: -2).exists? topic.topic_allowed_users.where(user_id: -2).exists?
end end
def cancel_timeout_job(user)
Jobs.cancel_scheduled_job(:narrative_timeout, user_id: user.id, klass: self.class.to_s)
end
def enqueue_timeout_job(user)
return if Rails.env.test?
cancel_timeout_job(user)
Jobs.enqueue_in(TIMEOUT_DURATION, :narrative_timeout,
user_id: user.id,
klass: self.class.to_s
)
end
end end
end end

View File

@ -163,21 +163,6 @@ module DiscourseNarrativeBot
topic_id == @data[:topic_id] topic_id == @data[:topic_id]
end end
def cancel_timeout_job(user)
Jobs.cancel_scheduled_job(:narrative_timeout, user_id: user.id, klass: self.class.to_s)
end
def enqueue_timeout_job(user)
return if Rails.env.test?
cancel_timeout_job(user)
Jobs.enqueue_in(TIMEOUT_DURATION, :narrative_timeout,
user_id: user.id,
klass: self.class.to_s
)
end
def not_implemented def not_implemented
raise 'Not implemented.' raise 'Not implemented.'
end end

View File

@ -39,7 +39,7 @@ module DiscourseNarrativeBot
klass = (data[:track] || NewUserNarrative.to_s).constantize klass = (data[:track] || NewUserNarrative.to_s).constantize
if is_reply && like_user_post if is_reply && like_user_post
Store.set(@user.id, data.merge!(state: nil, topic_id: nil)) terminate_track(data)
elsif state&.to_sym == :end && is_reply elsif state&.to_sym == :end && is_reply
bot_commands(bot_mentioned?) || generic_replies(klass.reset_trigger) bot_commands(bot_mentioned?) || generic_replies(klass.reset_trigger)
elsif is_reply elsif is_reply
@ -253,5 +253,10 @@ module DiscourseNarrativeBot
!SiteSetting.discourse_narrative_bot_disable_public_replies && !SiteSetting.discourse_narrative_bot_disable_public_replies &&
(bot_mentioned? || reply_to_bot_post?(@post)) (bot_mentioned? || reply_to_bot_post?(@post))
end end
def terminate_track(data)
Store.set(@user.id, data.merge!(state: nil, topic_id: nil))
cancel_timeout_job(@user)
end
end end
end end

View File

@ -127,9 +127,6 @@ describe DiscourseNarrativeBot::TrackSelector do
expect(post_action.post).to eq(post) expect(post_action.post).to eq(post)
expect(post_action.post_action_type_id).to eq(PostActionType.types[:like]) expect(post_action.post_action_type_id).to eq(PostActionType.types[:like])
post = Post.last
expect(Post.last).to eq(post) expect(Post.last).to eq(post)
expect(DiscourseNarrativeBot::NewUserNarrative.new.get_data(user)['state']) expect(DiscourseNarrativeBot::NewUserNarrative.new.get_data(user)['state'])