mirror of
https://github.com/inspec/inspec
synced 2024-11-11 07:34:15 +00:00
f1f5b27237
Signed-off-by: Clinton Wolfe <clintoncwolfe@gmail.com>
100 lines
2.8 KiB
Ruby
100 lines
2.8 KiB
Ruby
# encoding: utf-8
|
|
# copyright: 2017, Chef Software Inc.
|
|
|
|
require 'helper'
|
|
require 'thor'
|
|
|
|
describe 'BaseCLI' do
|
|
let(:cli) { Inspec::BaseCLI.new }
|
|
|
|
describe 'detect command' do
|
|
it 'verify platform detect' do
|
|
hash = { name: 'test-os', families: 'aws, cloud', release: 'aws-sdk-v1' }
|
|
expect = <<EOF
|
|
Name: \e[1m\e[35mtest-os\e[0m
|
|
Families: \e[1m\e[35maws, cloud\e[0m
|
|
Release: \e[1m\e[35maws-sdk-v1\e[0m
|
|
EOF
|
|
_(Inspec::BaseCLI.format_platform_info(params: hash, indent: 2, color: 35)).must_equal expect
|
|
end
|
|
end
|
|
|
|
|
|
describe 'configure_logger' do
|
|
let(:options) do
|
|
o = {
|
|
'log_location' => STDERR,
|
|
'log_level' => 'debug',
|
|
'reporter' => {
|
|
'json' => {
|
|
'stdout' => true,
|
|
},
|
|
},
|
|
}
|
|
Thor::CoreExt::HashWithIndifferentAccess.new(o)
|
|
end
|
|
let(:format) do
|
|
device = options[:logger].instance_variable_get(:"@logdev")
|
|
device.instance_variable_get(:"@dev")
|
|
end
|
|
|
|
it 'sets to stderr for log_location' do
|
|
cli.send(:configure_logger, options)
|
|
format.must_equal STDERR
|
|
end
|
|
|
|
it 'sets to stderr for json' do
|
|
options.delete('log_location')
|
|
options.delete('log_level')
|
|
cli.send(:configure_logger, options)
|
|
format.must_equal STDERR
|
|
end
|
|
|
|
it 'sets defaults to stdout for everything else' do
|
|
options.delete('log_location')
|
|
options.delete('log_level')
|
|
options.delete('reporter')
|
|
|
|
cli.send(:configure_logger, options)
|
|
format.must_equal STDOUT
|
|
end
|
|
end
|
|
|
|
|
|
describe 'suppress_log_output?' do
|
|
it 'suppresses json' do
|
|
opts = { 'reporter' => { 'json' => { 'stdout' => true }}}
|
|
cli.send(:suppress_log_output?, opts).must_equal true
|
|
end
|
|
|
|
it 'do not suppresses json-min when going to file' do
|
|
opts = { 'reporter' => { 'json-min' => { 'file' => '/tmp/json' }}}
|
|
cli.send(:suppress_log_output?, opts).must_equal false
|
|
end
|
|
|
|
it 'suppresses json-rspec' do
|
|
opts = { 'reporter' => { 'json-rspec' => { 'stdout' => true }}}
|
|
cli.send(:suppress_log_output?, opts).must_equal true
|
|
end
|
|
|
|
it 'suppresses json-automate' do
|
|
opts = { 'reporter' => { 'json-automate' => { 'stdout' => true }}}
|
|
cli.send(:suppress_log_output?, opts).must_equal true
|
|
end
|
|
|
|
it 'suppresses junit' do
|
|
opts = { 'reporter' => { 'junit' => { 'stdout' => true }}}
|
|
cli.send(:suppress_log_output?, opts).must_equal true
|
|
end
|
|
|
|
it 'do not suppresses cli' do
|
|
opts = { 'reporter' => { 'cli' => nil } }
|
|
cli.send(:suppress_log_output?, opts).must_equal false
|
|
end
|
|
|
|
it 'do not suppresses cli' do
|
|
opts = { 'reporter' => { 'cli' => nil, 'json' => {'file' => '/tmp/json' }}}
|
|
cli.send(:suppress_log_output?, opts).must_equal false
|
|
end
|
|
end
|
|
end
|