|
@@ -0,0 +1,112 @@
|
|
|
+require 'spec_helper'
|
|
|
+
|
|
|
+describe Agents::DelayAgent do
|
|
|
+ let(:agent) do
|
|
|
+ _agent = Agents::DelayAgent.new(name: 'My DelayAgent')
|
|
|
+ _agent.options = _agent.default_options.merge('max_events' => 2)
|
|
|
+ _agent.user = users(:bob)
|
|
|
+ _agent.sources << agents(:bob_website_agent)
|
|
|
+ _agent.save!
|
|
|
+ _agent
|
|
|
+ end
|
|
|
+
|
|
|
+ def create_event
|
|
|
+ _event = Event.new(payload: { random: rand })
|
|
|
+ _event.agent = agents(:bob_website_agent)
|
|
|
+ _event.save!
|
|
|
+ _event
|
|
|
+ end
|
|
|
+
|
|
|
+ let(:first_event) { create_event }
|
|
|
+ let(:second_event) { create_event }
|
|
|
+ let(:third_event) { create_event }
|
|
|
+
|
|
|
+ describe "#working?" do
|
|
|
+ it "checks if events have been received within expected receive period" do
|
|
|
+ expect(agent).not_to be_working
|
|
|
+ Agents::DelayAgent.async_receive agent.id, [events(:bob_website_agent_event).id]
|
|
|
+ expect(agent.reload).to be_working
|
|
|
+ the_future = (agent.options[:expected_receive_period_in_days].to_i + 1).days.from_now
|
|
|
+ stub(Time).now { the_future }
|
|
|
+ expect(agent.reload).not_to be_working
|
|
|
+ end
|
|
|
+ end
|
|
|
+
|
|
|
+ describe "validation" do
|
|
|
+ before do
|
|
|
+ expect(agent).to be_valid
|
|
|
+ end
|
|
|
+
|
|
|
+ it "should validate max_events" do
|
|
|
+ agent.options.delete('max_events')
|
|
|
+ expect(agent).not_to be_valid
|
|
|
+ agent.options['max_events'] = ""
|
|
|
+ expect(agent).not_to be_valid
|
|
|
+ agent.options['max_events'] = "0"
|
|
|
+ expect(agent).not_to be_valid
|
|
|
+ agent.options['max_events'] = "10"
|
|
|
+ expect(agent).to be_valid
|
|
|
+ end
|
|
|
+
|
|
|
+ it "should validate presence of expected_receive_period_in_days" do
|
|
|
+ agent.options['expected_receive_period_in_days'] = ""
|
|
|
+ expect(agent).not_to be_valid
|
|
|
+ agent.options['expected_receive_period_in_days'] = 0
|
|
|
+ expect(agent).not_to be_valid
|
|
|
+ agent.options['expected_receive_period_in_days'] = -1
|
|
|
+ expect(agent).not_to be_valid
|
|
|
+ end
|
|
|
+
|
|
|
+ it "should validate keep" do
|
|
|
+ agent.options.delete('keep')
|
|
|
+ expect(agent).not_to be_valid
|
|
|
+ agent.options['keep'] = ""
|
|
|
+ expect(agent).not_to be_valid
|
|
|
+ agent.options['keep'] = 'wrong'
|
|
|
+ expect(agent).not_to be_valid
|
|
|
+ agent.options['keep'] = 'newest'
|
|
|
+ expect(agent).to be_valid
|
|
|
+ agent.options['keep'] = 'oldest'
|
|
|
+ expect(agent).to be_valid
|
|
|
+ end
|
|
|
+ end
|
|
|
+
|
|
|
+ describe "#receive" do
|
|
|
+ it "records Events" do
|
|
|
+ expect(agent.memory).to be_empty
|
|
|
+ agent.receive([first_event])
|
|
|
+ expect(agent.memory).not_to be_empty
|
|
|
+ agent.receive([second_event])
|
|
|
+ expect(agent.memory['event_ids']).to eq [first_event.id, second_event.id]
|
|
|
+ end
|
|
|
+
|
|
|
+ it "keeps the newest when 'keep' is set to 'newest'" do
|
|
|
+ expect(agent.options['keep']).to eq 'newest'
|
|
|
+ agent.receive([first_event, second_event, third_event])
|
|
|
+ expect(agent.memory['event_ids']).to eq [second_event.id, third_event.id]
|
|
|
+ end
|
|
|
+
|
|
|
+ it "keeps the oldest when 'keep' is set to 'oldest'" do
|
|
|
+ agent.options['keep'] = 'oldest'
|
|
|
+ agent.receive([first_event, second_event, third_event])
|
|
|
+ expect(agent.memory['event_ids']).to eq [first_event.id, second_event.id]
|
|
|
+ end
|
|
|
+ end
|
|
|
+
|
|
|
+ describe "#check" do
|
|
|
+ it "re-emits Events and clears the memory" do
|
|
|
+ agent.receive([first_event, second_event, third_event])
|
|
|
+ expect(agent.memory['event_ids']).to eq [second_event.id, third_event.id]
|
|
|
+
|
|
|
+ expect {
|
|
|
+ agent.check
|
|
|
+ }.to change { agent.events.count }.by(2)
|
|
|
+
|
|
|
+ events = agent.events.reorder('events.id desc')
|
|
|
+ expect(events.first.payload).to eq third_event.payload
|
|
|
+ expect(events.second.payload).to eq second_event.payload
|
|
|
+
|
|
|
+ expect(agent.memory['event_ids']).to eq []
|
|
|
+ end
|
|
|
+ end
|
|
|
+end
|