Sha256: 2eabddb9884d6ad72d436bd4c873a4c017a41c8323f6fcc2b2bfd8ee3069d6a4

Contents?: true

Size: 1.67 KB

Versions: 9

Compression:

Stored size: 1.67 KB

Contents

# Allow test to be run in-place without requiring a gem install
$LOAD_PATH.unshift File.dirname(__FILE__) + '/../lib'

require 'rubygems'
require 'test/unit'
require 'shoulda'
require 'logger'
require 'semantic_logger'
require 'stringio'

class TestAttribute
  include SemanticLogger::Loggable
end


# Unit Test for SemanticLogger::Appender::File
#
class AppenderFileTest < Test::Unit::TestCase
  context SemanticLogger::Loggable do
    setup do
      @time = Time.new
      @io = StringIO.new
      @appender = SemanticLogger::Appender::File.new(@io)
      SemanticLogger.default_level = :trace
      SemanticLogger.add_appender(@appender)
      @hash = { :session_id => 'HSSKLEU@JDK767', :tracking_number => 12345 }
      @hash_str = @hash.inspect.sub("{", "\\{").sub("}", "\\}")
      @thread_name = Thread.current.name
    end

    teardown do
      SemanticLogger.remove_appender(@appender)
    end

    context "for each log level" do
      # Ensure that any log level can be logged
      SemanticLogger::LEVELS.each do |level|
        should "log #{level} information with class attribute" do
          TestAttribute.logger.send(level, "hello #{level}", @hash)
          SemanticLogger.flush
          assert_match /\d+-\d+-\d+ \d+:\d+:\d+.\d+ \w \[\d+:#{@thread_name}\] TestAttribute -- hello #{level} -- #{@hash_str}\n/, @io.string
        end
        should "log #{level} information with instance attribute" do
          TestAttribute.new.logger.send(level, "hello #{level}", @hash)
          SemanticLogger.flush
          assert_match /\d+-\d+-\d+ \d+:\d+:\d+.\d+ \w \[\d+:#{@thread_name}\] TestAttribute -- hello #{level} -- #{@hash_str}\n/, @io.string
        end
      end
    end

  end
end

Version data entries

9 entries across 9 versions & 1 rubygems

Version Path
semantic_logger-2.10.0 test/loggable_test.rb
semantic_logger-2.9.2 test/loggable_test.rb
semantic_logger-2.9.1 test/loggable_test.rb
semantic_logger-2.9.0 test/loggable_test.rb
semantic_logger-2.8.0 test/loggable_test.rb
semantic_logger-2.7.0 test/loggable_test.rb
semantic_logger-2.6.1 test/loggable_test.rb
semantic_logger-2.6.0 test/loggable_test.rb
semantic_logger-2.5.0 test/loggable_test.rb