puppet-strings/spec/acceptance/running_strings_yardoc.rb

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