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