Sha256: be5aaaa6146febccb85687f3ab622cf9c5b8e5b2a751ac7afd699b27e237f7c0

Contents?: true

Size: 1.45 KB

Versions: 14

Compression:

Stored size: 1.45 KB

Contents

# encoding: utf-8
# This file is distributed under New Relic's license terms.
# See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.

require File.expand_path(File.join(File.dirname(__FILE__),'..','..','test_helper'))
require 'new_relic/rack/agent_hooks'

class AgentHooksTest < Minitest::Test

  def setup
    @app = stub_everything
    @hooks = NewRelic::Rack::AgentHooks.new(@app)
    @env = {:env => "env"}
  end

  def test_before_call
    NewRelic::Agent.instance.events.expects(:notify).with(:start_transaction)
    NewRelic::Agent.instance.events.expects(:notify).with(:before_call, @env)
    NewRelic::Agent.instance.events.stubs(:notify).with(:after_call, anything, anything)
    NewRelic::Agent.instance.events.expects(:notify).with(:transaction_finished, anything)

    @hooks.call(@env)
  end

  def test_after_call
    result = [stub, stub, stub]
    @app.stubs(:call).returns(result)

    NewRelic::Agent.instance.events.expects(:notify).with(:start_transaction)
    NewRelic::Agent.instance.events.stubs(:notify).with(:before_call, anything)
    NewRelic::Agent.instance.events.expects(:notify).with(:after_call, @env, result)
    NewRelic::Agent.instance.events.expects(:notify).with(:transaction_finished, anything)

    @hooks.call(@env)
  end

  def test_nested_agent_hooks_still_fire_only_once
    nested = NewRelic::Rack::AgentHooks.new(@hooks)

    NewRelic::Agent.instance.events.expects(:notify).times(4)
    nested.call(@env)
  end

end

Version data entries

14 entries across 14 versions & 1 rubygems

Version Path
newrelic_rpm-3.13.2.302 test/new_relic/rack/agent_hooks_test.rb
newrelic_rpm-3.13.1.300 test/new_relic/rack/agent_hooks_test.rb
newrelic_rpm-3.13.0.299 test/new_relic/rack/agent_hooks_test.rb
newrelic_rpm-3.12.1.298 test/new_relic/rack/agent_hooks_test.rb
newrelic_rpm-3.12.0.288 test/new_relic/rack/agent_hooks_test.rb
newrelic_rpm-3.11.2.286 test/new_relic/rack/agent_hooks_test.rb
newrelic_rpm-3.11.1.284 test/new_relic/rack/agent_hooks_test.rb
newrelic_rpm-3.11.0.283 test/new_relic/rack/agent_hooks_test.rb
newrelic_rpm-3.10.0.279 test/new_relic/rack/agent_hooks_test.rb
newrelic_rpm-3.9.9.275 test/new_relic/rack/agent_hooks_test.rb
newrelic_rpm-3.9.8.273 test/new_relic/rack/agent_hooks_test.rb
newrelic_rpm-3.9.7.266 test/new_relic/rack/agent_hooks_test.rb
newrelic_rpm-3.9.6.257 test/new_relic/rack/agent_hooks_test.rb
newrelic_rpm-3.9.5.251 test/new_relic/rack/agent_hooks_test.rb