File: branch.rb

package info (click to toggle)
ruby-simplecov 0.22.0-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,512 kB
  • sloc: ruby: 5,550; makefile: 10
file content (84 lines) | stat: -rw-r--r-- 2,009 bytes parent folder | download | duplicates (4)
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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
# frozen_string_literal: true

module SimpleCov
  class SourceFile
    #
    # Representing single branch that has been detected in coverage report.
    # Give us support methods that handle needed calculations.
    class Branch
      attr_reader :start_line, :end_line, :coverage, :type

      # rubocop:disable Metrics/ParameterLists
      def initialize(start_line:, end_line:, coverage:, inline:, type:)
        @start_line = start_line
        @end_line   = end_line
        @coverage   = coverage
        @inline     = inline
        @type       = type
        @skipped    = false
      end
      # rubocop:enable Metrics/ParameterLists

      def inline?
        @inline
      end

      #
      # Return true if there is relevant count defined > 0
      #
      # @return [Boolean]
      #
      def covered?
        !skipped? && coverage.positive?
      end

      #
      # Check if branche missed or not
      #
      # @return [Boolean]
      #
      def missed?
        !skipped? && coverage.zero?
      end

      # The line on which we want to report the coverage
      #
      # Usually we choose the line above the start of the branch (so that it shows up
      # at if/else) because that
      # * highlights the condition
      # * makes it distinguishable if the first line of the branch is an inline branch
      #   (see the nested_branches fixture)
      #
      def report_line
        if inline?
          start_line
        else
          start_line - 1
        end
      end

      # Flags the branch as skipped
      def skipped!
        @skipped = true
      end

      # Returns true if the branch was marked skipped by virtue of nocov comments.
      def skipped?
        @skipped
      end

      def overlaps_with?(line_range)
        start_line <= line_range.end && end_line >= line_range.begin
      end

      #
      # Return array with coverage count and badge
      #
      # @return [Array]
      #
      def report
        [type, coverage]
      end
    end
  end
end