Sha256: e0aaf3206f4b9e65c6e34c741dd4aa23de2b3546d2df3d0a22e9ceef9eab7933

Contents?: true

Size: 1.88 KB

Versions: 4

Compression:

Stored size: 1.88 KB

Contents

module InspecPlugins::Parallelism
  class StreamingReporter < Inspec.plugin(2, :streaming_reporter)
    # Registering these methods with RSpec::Core::Formatters class is mandatory
    RSpec::Core::Formatters.register self, :example_passed, :example_failed, :example_pending, :close

    def initialize(output)
      @status_mapping = {}
      @control_counter = 0
      initialize_streaming_reporter
    end

    def example_passed(notification)
      set_example(notification, "passed")
    end

    def example_failed(notification)
      set_example(notification, "failed")
    end

    def example_pending(notification)
      set_example(notification, "skipped")
    end

    def close(notification)
      # HACK: if we've reached the end of the execution, send a special marker, to ease EOF detection on Windows
      puts "EOF_MARKER"
    end

    private

    def set_example(notification, status)
      control_id = notification.example.metadata[:id]
      title = notification.example.metadata[:title]
      set_status_mapping(control_id, status)
      output_status(control_id, title) if control_ended?(notification, control_id)
    end

    def output_status(control_id, title)
      @control_counter += 1
      stat = @status_mapping[control_id]
      stat = if stat.include?("failed")
               "F"
             else
               if stat.include?("skipped")
                 "S"
               else
                 stat.include?("passed") ? "P" : "E"
               end
             end
      display_name = title.gsub(/\n*\s+/, " ").to_s.force_encoding(Encoding::UTF_8) if title
      display_name = control_id.to_s.lstrip.force_encoding(Encoding::UTF_8) unless title

      puts "#{@control_counter}/#{stat}/#{controls_count}/#{display_name}"
    end

    def set_status_mapping(control_id, status)
      @status_mapping[control_id] ||= []
      @status_mapping[control_id].push(status)
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
inspec-core-6.8.24 lib/plugins/inspec-parallel/lib/inspec-parallel/child_status_reporter.rb
inspec-core-6.8.11 lib/plugins/inspec-parallel/lib/inspec-parallel/child_status_reporter.rb
inspec-core-6.8.1 lib/plugins/inspec-parallel/lib/inspec-parallel/child_status_reporter.rb
inspec-core-6.6.0 lib/plugins/inspec-parallel/lib/inspec-parallel/child_status_reporter.rb