Sha256: 136793f04e8b7b88e68854e06ec5e0b63b5c644359c3acc86041bf3110b9bde1

Contents?: true

Size: 1.5 KB

Versions: 3

Compression:

Stored size: 1.5 KB

Contents

require_relative '../test_helper'

# Unit Test for SemanticLogger::Appender::Bugsnag
module Appender
  class HoneybadgerTest < Minitest::Test
    describe SemanticLogger::Appender::Honeybadger do
      before do
        @appender = SemanticLogger::Appender::Honeybadger.new(:trace)
        @message  = 'AppenderHoneybadgerTest log message'
        SemanticLogger.backtrace_level = :error
      end

      SemanticLogger::LEVELS.each do |level|
        it "sends #{level} message" do
          hash = nil
          Honeybadger.stub(:notify, -> h { hash = h }) do
            @appender.send(level, @message)
          end
          assert_equal @message, hash[:error_message]
          assert_equal 'SemanticLogger::Appender::Honeybadger', hash[:error_class]

          if [:error, :fatal].include?(level)
            assert hash.has_key?(:backtrace)
          else
            refute hash.has_key?(:backtrace)
          end
          assert_equal true, hash.has_key?(:context)
          assert_equal level, hash[:context][:level]
        end

        it "sends #{level} exceptions" do
          error     = RuntimeError.new('Oh no, Error.')
          exception = hash = nil
          Honeybadger.stub(:notify, -> exc, h { exception = exc; hash = h }) do
            @appender.send(level, @message, error)
          end

          assert_equal error.class.to_s, exception.class.to_s
          assert_equal error.message, exception.message
          assert_equal @message, hash[:message], hash
        end
      end

    end
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
semantic_logger-3.4.1 test/appender/honeybadger_test.rb
semantic_logger-3.4.0 test/appender/honeybadger_test.rb
semantic_logger-3.3.0 test/appender/honeybadger_test.rb