123456789101112131415161718192021222324252627282930313233343536373839404142434445464748 |
- require 'spec_helper'
- describe Agents::UserLocationAgent do
- before do
- @agent = Agent.build_for_type('Agents::UserLocationAgent', users(:bob), :name => 'something', :options => { :secret => 'my_secret' })
- @agent.save!
- end
- it 'receives an event' do
- event = Event.new
- event.agent = agents(:bob_weather_agent)
- event.created_at = Time.now
- event.payload = { 'longitude' => 123, 'latitude' => 45, 'something' => 'else' }
- expect {
- @agent.receive([event])
- }.to change { @agent.events.count }.by(1)
- expect(@agent.events.last.payload).to eq({ 'longitude' => 123, 'latitude' => 45, 'something' => 'else' })
- expect(@agent.events.last.lat).to eq(45)
- expect(@agent.events.last.lng).to eq(123)
- end
- it 'does not accept a web request that is not POST' do
- %w[get put delete patch].each { |method|
- content, status, content_type = @agent.receive_web_request({ 'secret' => 'my_secret' }, method, 'application/json')
- expect(status).to eq(404)
- }
- end
- it 'requires a valid secret for a web request' do
- content, status, content_type = @agent.receive_web_request({ 'secret' => 'fake' }, 'post', 'application/json')
- expect(status).to eq(401)
- content, status, content_type = @agent.receive_web_request({ 'secret' => 'my_secret' }, 'post', 'application/json')
- expect(status).to eq(200)
- end
- it 'creates an event on a web request' do
- expect {
- @agent.receive_web_request({ 'secret' => 'my_secret', 'longitude' => 123, 'latitude' => 45, 'something' => 'else' }, 'post', 'application/json')
- }.to change { @agent.events.count }.by(1)
- expect(@agent.events.last.payload).to eq({ 'longitude' => 123, 'latitude' => 45, 'something' => 'else' })
- expect(@agent.events.last.lat).to eq(45)
- expect(@agent.events.last.lng).to eq(123)
- end
- end
|