File: logging.rb

package info (click to toggle)
ruby-test-prof 1.5.2%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 660 kB
  • sloc: ruby: 6,064; makefile: 4
file content (32 lines) | stat: -rw-r--r-- 677 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
# frozen_string_literal: true

module TestProf
  # Helper for output printing
  module Logging
    COLORS = {
      INFO: "\e[34m", # blue
      WARN: "\e[33m", # yellow
      ERROR: "\e[31m" # red
    }.freeze

    class Formatter
      def call(severity, _time, progname, msg)
        colorize(severity.to_sym, "[#{progname} #{severity}] #{msg}") + "\n"
      end

      private

      def colorize(level, msg)
        return msg unless TestProf.config.color?

        return msg unless COLORS.key?(level)

        "#{COLORS[level]}#{msg}\e[0m"
      end
    end

    def log(level, msg)
      TestProf.config.logger.public_send(level, "TEST PROF") { msg }
    end
  end
end