32 lines
1.2 KiB
Ruby
32 lines
1.2 KiB
Ruby
require 'spec_helper_acceptance'
|
|
require 'rspec-html-matchers'
|
|
require 'json'
|
|
|
|
describe 'Genearting module documation using yardoc action' do
|
|
def read_file_on(host, filename)
|
|
on(host, "cat #{filename}").stdout
|
|
end
|
|
|
|
before :all do
|
|
modules = JSON.parse(on(master, puppet("module", "list", "--render-as", "json")).stdout)
|
|
test_module_info = modules["modules_by_path"].values.flatten.find { |mod_info| mod_info =~ /Module test/ }
|
|
test_module_path = test_module_info.match(/\(([^)]*)\)/)[1]
|
|
|
|
on master, puppet("strings", "#{test_module_path}/**/*.{rb,pp}")
|
|
end
|
|
|
|
it "should generate documentation for manifests" do
|
|
expect(read_file_on(master, '/root/doc/test.html')).to have_tag('.docstring .discussion', :text => /This class/)
|
|
end
|
|
|
|
it "should generate documenation for 3x functions" do
|
|
on master, 'cat /root/doc/Puppet3xFunctions.html' do
|
|
expect(read_file_on(master, '/root/doc/Puppet3xFunctions.html')).to have_tag('.docstring .discussion', :text => /documentation for `function3x`/)
|
|
end
|
|
end
|
|
|
|
it "should generate documenation for 4x functions" do
|
|
expect(read_file_on(master, '/root/doc/Puppet4xFunctions.html')).to have_tag('.docstring .discussion', :text => /This is a function/)
|
|
end
|
|
end
|