mirror of
https://github.com/inspec/inspec
synced 2024-12-18 00:53:22 +00:00
c7e87ca3e3
* Create file-check functionality into utility file There are the similar issues as PR #2302. Almost resources return false positives when a file does not exist or is not read. * Replace to file-check functionality * Fix dh_params and x509_certificate resources If a file is empty, OpenSSL::PKey::DH and OpenSSL::X509::Certificate have raised an exception and have skipped the inspection. Thus x509_certificate and dh_params resources are not allowed to read a empty file. * to_s of shadow expects filters is not nil * Remove workaround of sshd_config Removes the workaround of sshd_config since Travis CI fails due to a bug of dev-sec/ssh-baseline and the PR #100 will fix it. * Use init block variable in methods Signed-off-by: ERAMOTO Masaya <eramoto.masaya@jp.fujitsu.com>
123 lines
4.7 KiB
Ruby
123 lines
4.7 KiB
Ruby
# encoding: utf-8
|
|
# author: Christoph Hartmann
|
|
require 'functional/helper'
|
|
require 'tmpdir'
|
|
|
|
describe 'example inheritance profile' do
|
|
include FunctionalHelper
|
|
let(:inheritance_path) { File.join(examples_path, 'inheritance') }
|
|
let(:meta_path) { File.join(examples_path, 'meta-profile') }
|
|
|
|
it 'can vendor profile dependencies' do
|
|
prepare_examples('inheritance') do |dir|
|
|
out = inspec('vendor ' + dir + ' --overwrite')
|
|
out.stderr.must_equal ''
|
|
out.stdout.must_include "Dependencies for profile #{dir} successfully vendored to #{dir}/vendor"
|
|
out.exit_status.must_equal 0
|
|
|
|
File.exist?(File.join(dir, 'vendor')).must_equal true
|
|
File.exist?(File.join(dir, 'inspec.lock')).must_equal true
|
|
end
|
|
end
|
|
|
|
it 'can vendor profile dependencies from the profile path' do
|
|
prepare_examples('inheritance') do |dir|
|
|
out = inspec('vendor --overwrite', "cd #{dir} &&")
|
|
out.stderr.must_equal ''
|
|
out.exit_status.must_equal 0
|
|
# this fixes the osx /var symlink to /private/var causing this test to fail
|
|
out.stdout.gsub!('/private/var', '/var')
|
|
out.stdout.must_include "Dependencies for profile #{dir} successfully vendored to #{dir}/vendor"
|
|
|
|
File.exist?(File.join(dir, 'vendor')).must_equal true
|
|
File.exist?(File.join(dir, 'inspec.lock')).must_equal true
|
|
end
|
|
end
|
|
|
|
it 'ensure nothing is loaded from external source if vendored profile is used' do
|
|
prepare_examples('meta-profile') do |dir|
|
|
out = inspec('vendor ' + dir + ' --overwrite')
|
|
out.stderr.must_equal ''
|
|
out.exit_status.must_equal 0
|
|
|
|
File.exist?(File.join(dir, 'vendor')).must_equal true
|
|
File.exist?(File.join(dir, 'inspec.lock')).must_equal true
|
|
|
|
out = inspec('exec ' + dir + ' -l debug --no-create-lockfile')
|
|
out.stderr.must_equal ''
|
|
out.stdout.must_include 'Using cached dependency for {:url=>"https://github.com/dev-sec/ssh-baseline/archive/master.tar.gz"'
|
|
out.stdout.must_include 'Using cached dependency for {:url=>"https://github.com/dev-sec/ssl-baseline/archive/master.tar.gz"'
|
|
out.stdout.must_include 'Using cached dependency for {:url=>"https://github.com/chris-rock/windows-patch-benchmark/archive/master.tar.gz"'
|
|
out.stdout.wont_include 'Fetching URL:'
|
|
out.stdout.wont_include 'Fetched archive moved to:'
|
|
end
|
|
end
|
|
|
|
it 'ensure json/check command do not fetch remote profiles if vendored' do
|
|
prepare_examples('meta-profile') do |dir|
|
|
out = inspec('vendor ' + dir + ' --overwrite')
|
|
out.stderr.must_equal ''
|
|
out.exit_status.must_equal 0
|
|
|
|
out = inspec('json ' + dir + ' --output ' + dst.path)
|
|
out.stderr.must_equal ''
|
|
out.exit_status.must_equal 0
|
|
|
|
hm = JSON.load(File.read(dst.path))
|
|
hm['name'].must_equal 'meta-profile'
|
|
hm['controls'].length.must_be :>=, 78
|
|
|
|
# out.stdout.scan(/Copy .* to cache directory/).length.must_equal 3
|
|
# out.stdout.scan(/Dependency does not exist in the cache/).length.must_equal 1
|
|
out.stdout.scan(/Fetching URL:/).length.must_equal 0
|
|
|
|
# execute check command
|
|
out = inspec('check ' + dir + ' -l debug')
|
|
# stderr may have warnings included; only test if something went wrong
|
|
out.stderr.must_equal('') if out.exit_status != 0
|
|
out.exit_status.must_equal 0
|
|
|
|
out.stdout.scan(/Fetching URL:/).length.must_equal 0
|
|
end
|
|
end
|
|
|
|
it 'use lockfile in tarball' do
|
|
prepare_examples('meta-profile') do |dir|
|
|
# ensure the profile is vendored and packaged as tar
|
|
out = inspec('vendor ' + dir + ' --overwrite')
|
|
out.stderr.must_equal ''
|
|
out.exit_status.must_equal 0
|
|
|
|
out = inspec('archive ' + dir + ' --overwrite')
|
|
out.stderr.must_equal ''
|
|
out.exit_status.must_equal 0
|
|
|
|
# execute json command
|
|
out = inspec('json meta-profile-0.2.0.tar.gz -l debug')
|
|
# stderr may have warnings included; only test if something went wrong
|
|
out.stderr.must_equal('') if out.exit_status != 0
|
|
out.exit_status.must_equal 0
|
|
|
|
out.stdout.scan(/Fetching URL:/).length.must_equal 0
|
|
end
|
|
end
|
|
|
|
it 'can move vendor files into custom vendor cache' do
|
|
prepare_examples('meta-profile') do |dir|
|
|
out = inspec('vendor ' + dir + ' --overwrite')
|
|
out.stderr.must_equal ''
|
|
out.exit_status.must_equal 0
|
|
|
|
File.exist?(File.join(dir, 'vendor')).must_equal true
|
|
File.exist?(File.join(dir, 'inspec.lock')).must_equal true
|
|
File.exist?(File.join(dir, 'vendor_cache')).must_equal false
|
|
|
|
exec_out = inspec('exec ' + dir + ' --vendor-cache ' + dir + '/vendor_cache')
|
|
|
|
File.exist?(File.join(dir, 'vendor_cache')).must_equal true
|
|
vendor_files = Dir.entries("#{dir}/vendor/")
|
|
vendor_cache_files = Dir.entries("#{dir}/vendor_cache/")
|
|
vendor_files.must_equal vendor_cache_files
|
|
end
|
|
end
|
|
end
|