123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127 |
- require 'rails_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
- it "re-emits max_emitted_events and clears just them from the memory" do
- agent.options['max_emitted_events'] = 1
- 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(1)
- events = agent.events.reorder('events.id desc')
- expect(agent.memory['event_ids']).to eq [third_event.id]
- expect(events.first.payload).to eq second_event.payload
- end
- end
- end
|