Sha256: 002edab687436a167e82b164ff0a466531021451bdd61f30a24c25e1b0e58244

Contents?: true

Size: 1.55 KB

Versions: 4

Compression:

Stored size: 1.55 KB

Contents

module Specs
  class << self
    def log
      # Setup ENV variable handling with sane defaults
      @log ||= Nenv("celluloid_specs_log") do |env|
        env.create_method(:file) { |f| f || "log/default.log" }
        env.create_method(:sync?) { |s| s || !Nenv.ci? }

        env.create_method(:strategy) do |strategy|
          strategy || default_strategy
        end

        env.create_method(:level) { |level| default_level_for(env, level) }
      end
    end

    def split_logs?
      log.strategy == "split"
    end

    def logger
      @logger ||= default_logger.tap { |logger| logger.level = log.level }
    end

    attr_writer :logger

    private

    def default_logger
      case log.strategy
      when "stderr"
        Logger.new(STDERR)
      when "single"
        Logger.new(open_logfile(log.file, log.sync?))
      when "split"
        # Use Celluloid in case there's logging in a before/after handle
        # (is that a bug in rspec-log_split?)
        Celluloid.logger
      else
        fail "Unknown logger strategy: #{strategy.inspect}."\
          " Expected 'split', 'single' or 'stderr'."
      end
    end

    def open_logfile(rel_path, sync)
      root = Pathname(__FILE__).dirname.dirname.dirname
      log_path = root + rel_path
      logfile = File.open(log_path.to_s, "a")
      logfile.sync if sync
      logfile
    end

    def default_strategy
      (Nenv.ci? ? "stderr" : "split")
    end

    def default_level_for(env, level)
      Integer(level)
    rescue
      env.strategy == "stderr" ? Logger::WARN : Logger::DEBUG
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
celluloid-0.17.1.2 spec/support/logging.rb
celluloid-0.17.1.1 spec/support/logging.rb
celluloid-0.17.1 spec/support/logging.rb
celluloid-0.17.0 spec/support/logging.rb