danmayer/coverband

View on GitHub
lib/coverband/utils/lines_classifier.rb

Summary

Maintainability
A
0 mins
Test Coverage
# frozen_string_literal: true

####
#
# NOTE: with Ruby 2.6.0 and beyond we can replace this classifier with
# ::Coverage.line_stub
# https://ruby-doc.org/stdlib-2.6.1/libdoc/coverage/rdoc/Coverage.html#method-c-line_stub
#
# Thanks for all the help SimpleCov https://github.com/colszowka/simplecov-html
# initial version pulled into Coverband from Simplecov 12/04/2018
#
# Classifies whether lines are relevant for code coverage analysis.
# Comments & whitespace lines, and :nocov: token blocks, are considered not relevant.
####
module Coverband
  module Utils
    class LinesClassifier
      RELEVANT = 0
      NOT_RELEVANT = nil

      WHITESPACE_LINE = /^\s*$/
      COMMENT_LINE = /^\s*#/
      WHITESPACE_OR_COMMENT_LINE = Regexp.union(WHITESPACE_LINE, COMMENT_LINE)

      def self.no_cov_line
        /^(\s*)#(\s*)(\:nocov\:)/o
      end

      def self.no_cov_line?(line)
        line =~ no_cov_line
      rescue ArgumentError
        # E.g., line contains an invalid byte sequence in UTF-8
        false
      end

      def self.whitespace_line?(line)
        line =~ WHITESPACE_OR_COMMENT_LINE
      rescue ArgumentError
        # E.g., line contains an invalid byte sequence in UTF-8
        false
      end

      def classify(lines)
        skipping = false

        lines.map do |line|
          if self.class.no_cov_line?(line)
            skipping = !skipping
            NOT_RELEVANT
          elsif skipping || self.class.whitespace_line?(line)
            NOT_RELEVANT
          else
            RELEVANT
          end
        end
      end
    end
  end
end