Class: Inspec::RunnerRspec

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

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 Method Details

#add_profile(profile) ⇒ nil

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

Parameters:

Returns:

  • (nil)


34
35
36
37
38
39
40
# File 'lib/inspec/runner_rspec.rb', line 34

def add_profile(profile)
  RSpec.configuration.formatters
       .find_all { |c| c.is_a?(Inspec::Formatters::Base) }
       .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)


59
60
61
62
# File 'lib/inspec/runner_rspec.rb', line 59

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

#backend=(backend) ⇒ nil

Configure the backend of the runner.

Parameters:

Returns:

  • (nil)


46
47
48
49
50
51
52
# File 'lib/inspec/runner_rspec.rb', line 46

def backend=(backend)
  RSpec.configuration.formatters
       .find_all { |c| c.is_a?(Inspec::Formatters::Base) }
       .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
# File 'lib/inspec/runner_rspec.rb', line 26

def example_group(*args, &block)
  RSpec::Core::ExampleGroup.describe(*args, &block)
end

#exit_codeint

Return a proper exit code to the runner

Returns:

  • (int)

    exit code



84
85
86
87
88
89
90
91
92
93
94
95
96
97
# File 'lib/inspec/runner_rspec.rb', line 84

def exit_code
  return @rspec_exit_code if @formatter.results.empty?
  stats = @formatter.results[:statistics][:controls]
  skipped = @formatter.results&.fetch(:profiles, nil)&.first&.fetch(:status, nil) == 'skipped'
  if stats[:failed][:total] == 0 && stats[:skipped][:total] == 0 && !skipped
    0
  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

#resetnil

Empty the list of registered tests.

Returns:

  • (nil)


102
103
104
105
106
107
# File 'lib/inspec/runner_rspec.rb', line 102

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



75
76
77
78
79
# File 'lib/inspec/runner_rspec.rb', line 75

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



67
68
69
# File 'lib/inspec/runner_rspec.rb', line 67

def tests
  @tests.ordered_example_groups
end