inspec/test/unit/dsl/control_test.rb

110 lines
3.1 KiB
Ruby
Raw Normal View History

require "helper"
require "inspec/config"
require "inspec/profile"
require "inspec/runner_mock"
require "inspec/fetchers/mock"
2016-03-17 22:07:42 +00:00
describe "controls" do
2016-03-17 22:07:42 +00:00
def load(content)
data = {
"inspec.yml" => "name: mock",
"controls/mock.rb" => "control '1' do\n#{content}\nend\n",
2016-03-17 22:07:42 +00:00
}
opts = {
test_collector: Inspec::RunnerMock.new,
backend: Inspec::Backend.create(Inspec::Config.mock),
}
2016-03-17 22:07:42 +00:00
Inspec::Profile.for_target(data, opts)
.params[:controls]["1"]
2016-03-17 22:07:42 +00:00
end
let(:rand_string) { rand.to_s }
it "adds a title" do
_(load("title #{rand_string.inspect}")[:title]).must_equal rand_string
end
it "adds a description" do
_(load("desc #{rand_string.inspect}")[:descriptions][:default]).must_equal rand_string
end
it "allows multiple desc with keys and values" do
lines = <<-DESC_EXAMPLES
desc 'this is default'
desc 'example', 'this is foo'
desc 'a space', 'this label has a space'
desc 'newline', 'this value has
a newline'
desc 'heredoc', <<-EOF
This is a heredoc
EOF
DESC_EXAMPLES
result = load(lines)
_(result[:descriptions][:default]).must_equal("this is default")
_(result[:descriptions][:example]).must_equal("this is foo")
_(result[:descriptions][:'a space']).must_equal("this label has a space")
_(result[:descriptions][:newline]).must_match(/this value has\n\s*a newline/)
_(result[:descriptions][:heredoc]).must_equal("This is a heredoc")
end
it "adds a multiline description" do
t = rand_string + "\n" + rand_string
_(load("desc #{t.inspect}")[:descriptions][:default]).must_equal t
end
it "strips empty lines and spaces in description at start and end" do
t = " \n" + rand_string + "\n "
_(load("desc #{t.inspect}")[:descriptions][:default]).must_equal rand_string
end
it "unindents properly" do
t = "\n #{rand_string}\n \n\t\t #{rand_string}\n "
_(load("desc #{t.inspect}")[:descriptions][:default]).must_equal "#{rand_string}\n \n #{rand_string}"
end
it "works with empty refs" do
_(load("ref")[:refs]).must_be :empty?
2016-03-17 22:07:42 +00:00
end
it "defines a simple ref" do
2016-03-17 22:07:42 +00:00
s = rand.to_s
_(load("ref #{s.inspect}")[:refs]).must_equal [{ ref: s }]
2016-03-17 22:07:42 +00:00
end
it "defines a ref with url" do
2016-03-17 22:07:42 +00:00
s = rand.to_s
u = rand.to_s
_(load("ref #{s.inspect}, url: #{u.inspect}")[:refs]).must_equal [{ ref: s, url: u }]
2016-03-17 22:07:42 +00:00
end
it "defines a ref without content but with url" do
2016-03-17 22:07:42 +00:00
u = rand.to_s
_(load("ref url: #{u.inspect}")[:refs]).must_equal [{ url: u }]
2016-03-17 22:07:42 +00:00
end
it "works with empty tags" do
_(load("tag")[:tags]).must_be :empty?
2016-03-17 22:07:42 +00:00
end
it "defines a simple tag" do
2016-03-17 22:07:42 +00:00
s = rand.to_s
_(load("tag #{s.inspect}")[:tags]).must_equal({ s => nil })
2016-03-17 22:07:42 +00:00
end
it "define multiple tags" do
2016-03-17 22:07:42 +00:00
a, b, c = rand.to_s, rand.to_s, rand.to_s
_(load("tag #{a.inspect}, #{b.inspect}, #{c.inspect}")[:tags]).must_equal(
{ a => nil, b => nil, c => nil }
)
2016-03-17 22:07:42 +00:00
end
it "tag by key=value" do
2016-03-17 22:07:42 +00:00
a, b = rand.to_s, rand.to_s
_(load("tag #{a.inspect} => #{b.inspect}")[:tags]).must_equal(
{ a => b }
)
2016-03-17 22:07:42 +00:00
end
end