mirror of
https://github.com/inspec/inspec
synced 2024-11-30 08:30:39 +00:00
6c3ab70dd1
* json resource (et. al.): allow inspec check to succeed when using command When using the `json` resource (or any of the resources that subclass JsonConfig), `inspec check` would fail if the content was supplied with the `command` option. This is because the `command` resource is mocked and an empty string would be returned for `stdout`. That content would be blindly passed to the `parse` method would which raise an exception and cause `inspec check` to fail. This change refactors JsonConfig to be a bit cleaner and use some helper methods. Additionally, we use the new Exceptions to properly raise errors which are naturally caught by Inspec::Profile, etc. Signed-off-by: Adam Leff <adam@leff.co> * Make `resource_base_name` method private Signed-off-by: Adam Leff <adam@leff.co>
32 lines
785 B
Ruby
32 lines
785 B
Ruby
# encoding: utf-8
|
|
# author: Nolan Davidson
|
|
|
|
require 'tomlrb'
|
|
|
|
module Inspec::Resources
|
|
class TomlConfig < JsonConfig
|
|
name 'toml'
|
|
desc 'Use the toml InSpec resource to test configuration data in a TOML file'
|
|
example "
|
|
describe toml('default.toml') do
|
|
its('key') { should eq('value') }
|
|
its (['arr', 1]) { should eq 2 }
|
|
its (['mytable', 'key1']) { should eq 'value1' }
|
|
end
|
|
"
|
|
|
|
def parse(content)
|
|
Tomlrb.parse(content)
|
|
rescue => e
|
|
raise Inspec::Exceptions::ResourceFailed, "Unable to parse TOML: #{e.message}"
|
|
end
|
|
|
|
private
|
|
|
|
# used by JsonConfig to build up a full to_s method
|
|
# based on whether a file path, content, or command was supplied.
|
|
def resource_base_name
|
|
'TOML'
|
|
end
|
|
end
|
|
end
|