123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109 |
- require 'rails_helper'
- describe DryRunnable do
- class Agents::SandboxedAgent < Agent
- default_schedule "3pm"
- can_dry_run!
- def check
- perform
- end
- def receive(events)
- events.each do |event|
- perform(event.payload['prefix'])
- end
- end
- private
- def perform(prefix = nil)
- log "Logging"
- create_event payload: { 'test' => "#{prefix}foo" }
- error "Recording error"
- create_event payload: { 'test' => "#{prefix}bar" }
- self.memory = { 'last_status' => 'ok', 'dry_run' => dry_run? }
- save!
- end
- end
- before do
- allow(Agents::SandboxedAgent).to receive(:valid_type?).with("Agents::SandboxedAgent") { true }
- @agent = Agents::SandboxedAgent.create(name: "some agent") { |agent|
- agent.user = users(:bob)
- }
- end
- def counts
- [users(:bob).agents.count, users(:bob).events.count, users(:bob).logs.count]
- end
- it "does not affect normal run, with dry_run? returning false" do
- before = counts
- after = before.zip([0, 2, 2]).map { |x, d| x + d }
- expect {
- @agent.check
- @agent.reload
- }.to change { counts }.from(before).to(after)
- expect(@agent.memory).to eq({ 'last_status' => 'ok', 'dry_run' => false })
- payloads = @agent.events.reorder(:id).last(2).map(&:payload)
- expect(payloads).to eq([{ 'test' => 'foo' }, { 'test' => 'bar' }])
- messages = @agent.logs.reorder(:id).last(2).map(&:message)
- expect(messages).to eq(['Logging', 'Recording error'])
- end
- it "does not perform dry-run if Agent does not support dry-run" do
- allow(@agent).to receive(:can_dry_run?) { false }
- results = nil
- expect {
- results = @agent.dry_run!
- @agent.reload
- }.not_to change {
- [@agent.memory, counts]
- }
- expect(results[:log]).to match(/\A\[\d\d:\d\d:\d\d\] INFO -- : Dry Run failed\n\[\d\d:\d\d:\d\d\] ERROR -- : Exception during dry-run. SandboxedAgent does not support dry-run: /)
- expect(results[:events]).to eq([])
- expect(results[:memory]).to eq({})
- end
- describe "dry_run!" do
- it "traps any destructive operations during a run" do
- results = nil
- expect {
- results = @agent.dry_run!
- @agent.reload
- }.not_to change {
- [@agent.memory, counts]
- }
- expect(results[:log]).to match(/\A\[\d\d:\d\d:\d\d\] INFO -- : Dry Run started\n\[\d\d:\d\d:\d\d\] INFO -- : Logging\n\[\d\d:\d\d:\d\d\] ERROR -- : Recording error\n/)
- expect(results[:events]).to eq([{ 'test' => 'foo' }, { 'test' => 'bar' }])
- expect(results[:memory]).to eq({ 'last_status' => 'ok', 'dry_run' => true })
- end
- it "traps any destructive operations during a run when an event is given" do
- results = nil
- expect {
- results = @agent.dry_run!(Event.new(payload: { 'prefix' => 'super' }))
- @agent.reload
- }.not_to change {
- [@agent.memory, counts]
- }
- expect(results[:log]).to match(/\A\[\d\d:\d\d:\d\d\] INFO -- : Dry Run started\n\[\d\d:\d\d:\d\d\] INFO -- : Logging\n\[\d\d:\d\d:\d\d\] ERROR -- : Recording error\n/)
- expect(results[:events]).to eq([{ 'test' => 'superfoo' }, { 'test' => 'superbar' }])
- expect(results[:memory]).to eq({ 'last_status' => 'ok', 'dry_run' => true })
- end
- end
- end
|