File: logger.rb

package info (click to toggle)
ruby-mocha 3.1.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 2,656 kB
  • sloc: ruby: 12,304; javascript: 499; makefile: 14
file content (26 lines) | stat: -rw-r--r-- 582 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
# frozen_string_literal: true

require 'mocha/backtrace_filter'

module Mocha
  class Logger
    class << self
      attr_writer :logger

      def warning(*args, **kwargs)
        logger.warning(*args, **kwargs)
      end

      def logger
        @logger ||= new
      end
    end

    def warning(message, category: nil)
      filter = BacktraceFilter.new
      location = filter.filtered_locations(caller_locations)[0]
      prefix = ['Mocha', category, 'warning'].compact.join(' ')
      warn("#{prefix}: #{message} (at #{location.path}:#{location.lineno})")
    end
  end
end