Class: Inspec::RunnerRspec

Inherits:
Object
  • Object
show all
Defined in:
lib/inspec/runner_rspec.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(conf) ⇒ RunnerRspec

Returns a new instance of RunnerRspec.



15
16
17
18
19
# File 'lib/inspec/runner_rspec.rb', line 15

def initialize(conf)
  @conf = conf
  @formatter = nil
  reset
end

Instance Attribute Details

#formatterObject

Returns the value of attribute formatter.



13
14
15
# File 'lib/inspec/runner_rspec.rb', line 13

def formatter
  @formatter
end

Instance Method Details

#add_profile(profile) ⇒ nil

Add a full profile to the runner. Only pulls in metadata

Parameters:

Returns:

  • (nil)


39
40
41
42
43
# File 'lib/inspec/runner_rspec.rb', line 39

def add_profile(profile)
  formatters.each do |fmt|
    fmt.add_profile(profile)
  end
end

#add_test(example, rule) ⇒ nil

Add an example group to the list of registered tests.

Parameters:

  • example (RSpecExampleGroup)

    test

  • rule_id (String)

    the ID associated with this check

Returns:

  • (nil)


64
65
66
67
# File 'lib/inspec/runner_rspec.rb', line 64

def add_test(example, rule)
  set_rspec_ids(example, rule)
  @tests.example_groups.push(example)
end

#backendObject



45
46
47
# File 'lib/inspec/runner_rspec.rb', line 45

def backend
  formatters.first.backend
end

#backend=(backend) ⇒ nil

Configure the backend of the runner.

Parameters:

Returns:

  • (nil)


53
54
55
56
57
# File 'lib/inspec/runner_rspec.rb', line 53

def backend=(backend)
  formatters.each do |fmt|
    fmt.backend = backend
  end
end

#example_group(*args, &block) ⇒ RSpecExampleGroup

Create a new RSpec example group from arguments and block.

Parameters:

  • *args (Type)

    list of arguments for this example

  • &block (Type)

    the block associated with this example group

Returns:

  • (RSpecExampleGroup)


26
27
28
29
# File 'lib/inspec/runner_rspec.rb', line 26

def example_group(*args, &block)
  # NOTE: this RUNS immediately
  RSpec::Core::ExampleGroup.describe(*args, &block)
end

#exit_codeint

Return a proper exit code to the runner

Returns:

  • (int)

    exit code



89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
# File 'lib/inspec/runner_rspec.rb', line 89

def exit_code
  return @rspec_exit_code if @formatter.results.empty?

  stats = @formatter.results[:statistics][:controls]
  load_failures = @formatter.results[:profiles]&.select { |p| p[:status] == "failed" }&.any?
  skipped = @formatter.results.dig(:profiles, 0, :status) == "skipped"
  if stats[:failed][:total] == 0 && stats[:skipped][:total] == 0 && !skipped && !load_failures
    0
  elsif load_failures
    @conf["distinct_exit"] ? 102 : 1
  elsif stats[:failed][:total] > 0
    @conf["distinct_exit"] ? 100 : 1
  elsif stats[:skipped][:total] > 0 || skipped
    @conf["distinct_exit"] ? 101 : 0
  else
    @rspec_exit_code
  end
end

#formattersObject



31
32
33
# File 'lib/inspec/runner_rspec.rb', line 31

def formatters
  RSpec.configuration.formatters.grep(Inspec::Formatters::Base)
end

#resetnil

Empty the list of registered tests.

Returns:

  • (nil)


111
112
113
114
115
116
# File 'lib/inspec/runner_rspec.rb', line 111

def reset
  @tests = RSpec::Core::World.new
  # resets "pending examples" in reporter
  RSpec.configuration.reset
  configure_output
end

#run(with = nil) ⇒ int

Run all registered tests with an optional test runner.

Parameters:

  • with (RSpecRunner) (defaults to: nil)

    is an optional RSpecRunner

Returns:

  • (int)

    0 if all went well; otherwise nonzero



80
81
82
83
84
# File 'lib/inspec/runner_rspec.rb', line 80

def run(with = nil)
  with ||= RSpec::Core::Runner.new(nil)
  @rspec_exit_code = with.run_specs(tests)
  @formatter.results
end

#testsArray

Retrieve the list of tests that have been added.

Returns:

  • (Array)

    full list of tests



72
73
74
# File 'lib/inspec/runner_rspec.rb', line 72

def tests
  @tests.ordered_example_groups
end