Sha256: 0db851950e660820a68cd4f4bcbaaab31f43f2427cb441a5119fa92494c88b22

Contents?: true

Size: 1.97 KB

Versions: 7299

Compression:

Stored size: 1.97 KB

Contents

module RSpec
  module Core
    # @private
    class BacktraceFormatter
      # @private
      attr_accessor :exclusion_patterns, :inclusion_patterns

      def initialize
        @full_backtrace = false

        patterns = %w[ /lib\d*/ruby/ bin/ exe/rspec /lib/bundler/ /exe/bundle: ]
        patterns << "org/jruby/" if RUBY_PLATFORM == 'java'
        patterns.map! { |s| Regexp.new(s.gsub("/", File::SEPARATOR)) }

        @exclusion_patterns = [Regexp.union(RSpec::CallerFilter::IGNORE_REGEX, *patterns)]
        @inclusion_patterns = []

        return unless matches?(@exclusion_patterns, File.join(Dir.getwd, "lib", "foo.rb:13"))
        inclusion_patterns << Regexp.new(Dir.getwd)
      end

      attr_writer :full_backtrace

      def full_backtrace?
        @full_backtrace || exclusion_patterns.empty?
      end

      def filter_gem(gem_name)
        sep = File::SEPARATOR
        exclusion_patterns << /#{sep}#{gem_name}(-[^#{sep}]+)?#{sep}/
      end

      def format_backtrace(backtrace, options={})
        return [] unless backtrace
        return backtrace if options[:full_backtrace] || backtrace.empty?

        backtrace.map { |l| backtrace_line(l) }.compact.
          tap do |filtered|
            if filtered.empty?
              filtered.concat backtrace
              filtered << ""
              filtered << "  Showing full backtrace because every line was filtered out."
              filtered << "  See docs for RSpec::Configuration#backtrace_exclusion_patterns and"
              filtered << "  RSpec::Configuration#backtrace_inclusion_patterns for more information."
            end
          end
      end

      def backtrace_line(line)
        Metadata.relative_path(line) unless exclude?(line)
      end

      def exclude?(line)
        return false if @full_backtrace
        matches?(exclusion_patterns, line) && !matches?(inclusion_patterns, line)
      end

    private

      def matches?(patterns, line)
        patterns.any? { |p| line =~ p }
      end
    end
  end
end

Version data entries

7,299 entries across 7,218 versions & 113 rubygems

Version Path
rspec-core-3.6.0.beta2 lib/rspec/core/backtrace_formatter.rb
gameboard-3.1.0 vendor/bundle/ruby/2.3.0/gems/rspec-core-3.5.4/lib/rspec/core/backtrace_formatter.rb
gameboard-3.0.0 vendor/bundle/ruby/2.3.0/gems/rspec-core-3.5.4/lib/rspec/core/backtrace_formatter.rb
rspec-core-3.6.0.beta1 lib/rspec/core/backtrace_formatter.rb
rspec-core-3.5.4 lib/rspec/core/backtrace_formatter.rb
tdiary-5.0.2 vendor/bundle/gems/rspec-core-3.5.2/lib/rspec/core/backtrace_formatter.rb
logstash-filter-delta-1.1.0 vendor/bundle/jruby/2.2.0/gems/rspec-core-3.5.3/lib/rspec/core/backtrace_formatter.rb
logstash-filter-delta-1.0.1 vendor/bundle/jruby/2.2.0/gems/rspec-core-3.5.3/lib/rspec/core/backtrace_formatter.rb
logstash-filter-base64-1.0.4 vendor/bundle/jruby/2.2.0/gems/rspec-core-3.5.3/lib/rspec/core/backtrace_formatter.rb
logstash-filter-base64-1.0.3 vendor/bundle/jruby/2.2.0/gems/rspec-core-3.5.3/lib/rspec/core/backtrace_formatter.rb
logstash-filter-delta-1.0.0 vendor/bundle/jruby/2.2.0/gems/rspec-core-3.5.3/lib/rspec/core/backtrace_formatter.rb
logstash-filter-base64-1.0.2 vendor/bundle/jruby/2.3.0/gems/rspec-core-3.5.3/lib/rspec/core/backtrace_formatter.rb
logstash-filter-base64-1.0.1 vendor/bundle/jruby/2.3.0/gems/rspec-core-3.5.3/lib/rspec/core/backtrace_formatter.rb
logstash-filter-base64-1.0.0 vendor/bundle/jruby/2.3.0/gems/rspec-core-3.5.3/lib/rspec/core/backtrace_formatter.rb
rspec-core-3.5.3 lib/rspec/core/backtrace_formatter.rb
rspec-core-3.5.2 lib/rspec/core/backtrace_formatter.rb
rspec-core-3.5.1 lib/rspec/core/backtrace_formatter.rb
rspec-core-3.5.0 lib/rspec/core/backtrace_formatter.rb
rspec-core-3.5.0.beta4 lib/rspec/core/backtrace_formatter.rb