From 28a528686f148beee06af3a2c864604c23085b99 Mon Sep 17 00:00:00 2001 From: Nate McCurdy Date: Mon, 13 Feb 2017 13:00:51 -0800 Subject: [PATCH] Rubocop auto fixes preview_report.rb --- preview_report.rb | 523 ++++++++++++++++++++++------------------------ 1 file changed, 255 insertions(+), 268 deletions(-) diff --git a/preview_report.rb b/preview_report.rb index 9ba0820..7a19c84 100755 --- a/preview_report.rb +++ b/preview_report.rb @@ -4,9 +4,9 @@ require 'uri' require 'getoptlong' -UNKNOWN_FILE_PATH = 'unknown location' +UNKNOWN_FILE_PATH = 'unknown location'.freeze -PUPPET_LOGO = '' +PUPPET_LOGO = ''.freeze opts = GetoptLong.new( ['--format_json', '-f', GetoptLong::REQUIRED_ARGUMENT], @@ -15,7 +15,7 @@ ['--help', '-h', GetoptLong::NO_ARGUMENT] ) -def show_usage() +def show_usage puts <<-EOF preview_report.rb [OPTIONS] -h, --help @@ -43,9 +43,7 @@ def show_usage() end end -if (@overview_json.nil? or @html_file.nil?) - show_usage -end +show_usage if @overview_json.nil? || @html_file.nil? def load_json(filename) JSON.parse(IO.read(filename)) @@ -67,11 +65,11 @@ def find_diffs(diff_path) mab = Markaby::Builder.new mab.html do def make_error_readable(error) - h5.entryTitle "Information about this issue" + h5.entryTitle 'Information about this issue' case error # MIGRATE4_REVIEW_IN_EXPRESSION when 'MIGRATE4_REVIEW_IN_EXPRESSION' - tag! :body, :id => "overview_#{error}_#{rand()}" do + tag! :body, id: "overview_#{error}_#{rand}" do <<-eos In Puppet 3, the #{tag! :code, 'in'} operator was not well specified and there were several undefined behaviors. This relates to, but is not limited to: eos @@ -85,26 +83,26 @@ def make_error_readable(error) br body 'To fix, review the expectations against the Puppet language specification.' br - body "For a detailed description of this issue, see " - a 'PUP-4130', :href => 'https://tickets.puppetlabs.com/browse/PUP-4130' + body 'For a detailed description of this issue, see ' + a 'PUP-4130', href: 'https://tickets.puppetlabs.com/browse/PUP-4130' else - tag! :body, :id => "overview_#{error}_#{rand()}" do - a :href => "https://forge.puppet.com/puppetlabs/catalog_preview#%s" % error.downcase , :class => 'tooltip', :title => error do - tag! :i, "No information defined for this error click here for more information" + tag! :body, id: "overview_#{error}_#{rand}" do + a href: 'https://forge.puppet.com/puppetlabs/catalog_preview#%s' % error.downcase, class: 'tooltip', title: error do + tag! :i, 'No information defined for this error click here for more information' end end end end def normalize_name(name) - URI.escape(name).gsub(/[\-\[\] :\/\.]/,'_').to_s + URI.escape(name).gsub(%r{[\-\[\] :\/\.]}, '_').to_s end - def read_code_off_disk(header,manifest,line_number) + def read_code_off_disk(header, manifest, line_number) line_number = (line_number.to_i + 1) # Read the file off disk to find the code question. # Catch if the file is not on disk - return body "#{manifest} does not exist: no line preview available" unless File.exists?(manifest) + return body "#{manifest} does not exist: no line preview available" unless File.exist?(manifest) file = File.readlines(manifest) #### Manifests Code Block css = [ @@ -116,22 +114,22 @@ def read_code_off_disk(header,manifest,line_number) 'border-left-width: 4px', 'border-style: dotted solid', 'border-color: rgb(221, 221, 221);', - 'padding-bottom: 10px;', + 'padding-bottom: 10px;' ] - div :style=>css.join(';') do - tag! :code, :id => "manifest_#{header}_#{manifest}_#{line_number}_#{rand()}" do + div style: css.join(';') do + tag! :code, id: "manifest_#{header}_#{manifest}_#{line_number}_#{rand}" do ((line_number - 1)..(line_number + 1)).each do |nu| div.entryContent do if nu == line_number - 1 - div :style=> "background-color:rgb(248,238,199)" do - tag! :font, :color => 'black' do - "#{tag! :b, nu}:#{file[(nu - 1)]}" + div style: 'background-color:rgb(248,238,199)' do + tag! :font, color: 'black' do + "#{tag! :b, nu}:#{file[(nu - 1)]}" end end - else - div :style=> "background-color:white" do - tag! :font, :color => 'black' do - "#{nu}:#{file[(nu - 1)]}" + else + div style: 'background-color:white' do + tag! :font, color: 'black' do + "#{nu}:#{file[(nu - 1)]}" end end end @@ -141,20 +139,20 @@ def read_code_off_disk(header,manifest,line_number) end end - def node_break_down(nodes, resource =nil) + def node_break_down(nodes, resource = nil) ul do # Only show 10 nodes body "This issue occured on #{nodes.length} nodes" ul do nodes[0..10].each do |node| - div :style=>"font-size: 1.0rem;" do - tag! :font, :color => 'black' do + div style: 'font-size: 1.0rem;' do + tag! :font, color: 'black' do # LINK 2 or LINK 3 li do if resource.nil? - a node, :href => '#%s' % normalize_name(node) + a node, href: '#%s' % normalize_name(node) else - a node, :href => '#%s' % normalize_name("#{node}_#{resource}") + a node, href: '#%s' % normalize_name("#{node}_#{resource}") end end end @@ -164,20 +162,20 @@ def node_break_down(nodes, resource =nil) end end - def process_breakdown(header,type,detail) + def process_breakdown(header, type, detail) h3 "Detected #{header} #{type} resources" - detail.each do |title,breakdown| + detail.each do |title, breakdown| ul do li do - div :style=>"font-size: 1.3rem;" do + div style: 'font-size: 1.3rem;' do # LINK 01 - a :name => normalize_name("#{header}_#{type}_#{title}") do + a name: normalize_name("#{header}_#{type}_#{title}") do "#{type}[#{title}] is #{header}" end end end - breakdown.each do |path,nodes| - #### Example nodes + breakdown.each do |path, nodes| + #### Example nodes css = [ 'color: black', 'border-radius: 10px', @@ -188,21 +186,21 @@ def process_breakdown(header,type,detail) 'border-bottom-color: rgb(221, 221, 221);', 'padding-bottom: 20px;' ] - div :style=>css.join(';') do + div style: css.join(';') do + ul do ul do - ul do - # Path for classes is unknown - unless path == UNKNOWN_FILE_PATH - file_path,line_number = path.split(':') - h5.entryTitle "#{header.capitalize} resource ending on line #{line_number} (view node report for details)" - p path - read_code_off_disk(header,file_path,line_number) - br - end - end - # N number of example nodes - node_break_down(nodes,"#{type}[#{title}]") + # Path for classes is unknown + unless path == UNKNOWN_FILE_PATH + file_path, line_number = path.split(':') + h5.entryTitle "#{header.capitalize} resource ending on line #{line_number} (view node report for details)" + p path + read_code_off_disk(header, file_path, line_number) br + end + end + # N number of example nodes + node_break_down(nodes, "#{type}[#{title}]") + br end end end @@ -220,7 +218,7 @@ def pie_chart(catalog_diff) 'conflicting_resource_count' => 'blue' } table do - graph.each do |key,color| + graph.each do |key, color| next if catalog_diff[key].nil? next if catalog_diff[key].zero? css = [ @@ -231,14 +229,14 @@ def pie_chart(catalog_diff) "width: #{(catalog_diff[key])}px", "line-height: #{(catalog_diff[key])}px", 'border-radius: 50%', - 'text-align: center', + 'text-align: center' ] td do - div :style => css.join(';') do + div style: css.join(';') do body catalog_diff[key] end - div :style => 'font-size: smaller;color: black;' do - tag! :b, key.capitalize.gsub('_',' ') + div style: 'font-size: smaller;color: black;' do + tag! :b, key.capitalize.tr('_', ' ') end end end @@ -257,19 +255,17 @@ def compilation_errors_breakdown(section) error['errors'].each do |e| h4.entryTitle "#{e['message']} on line #{e['line']}" # Find file path in error if we don't have a file path from preview - match = /(\S*(\/\S*\.pp|\.erb))/.match(e['message'].to_s) - if error['manifest'].nil? and match - error['manifest'] = match[1] - end + match = %r{(\S*(\/\S*\.pp|\.erb))}.match(e['message'].to_s) + error['manifest'] = match[1] if error['manifest'].nil? && match # Extract line number from error message when manifest is null - if e['line'].nil? and match - line_number = match[3] - else - line_number = e['line'] - end + line_number = if e['line'].nil? && match + match[3] + else + e['line'] + end if error['manifest'] # Read the file off disk to find the code question - read_code_off_disk('failed',error['manifest'],line_number) + read_code_off_disk('failed', error['manifest'], line_number) end #### Example nodes node_break_down(error['nodes']) @@ -287,7 +283,7 @@ def compilation_errors_baseline_breakdown(section) # Matching the message to the node by index here as they are positionally related. div.entry do #### Error by line breakdown - error['errors'].each_with_index do |e,index| + error['errors'].each_with_index do |e, index| li do "#{tag! :b, error['nodes'][index]} failed to compile the baseline catalog" end @@ -295,19 +291,17 @@ def compilation_errors_baseline_breakdown(section) li do h4.entryTitle "#{e['message']} on line #{e['line']}" # Find file path in error if we don't have a file path from preview - match = /(\S*(\/\S*\.pp|\.erb)):?([0-9]+)/.match(e['message'].to_s) - if error['manifest'].nil? and match - error['manifest'] = match[1] - end + match = %r{(\S*(\/\S*\.pp|\.erb)):?([0-9]+)}.match(e['message'].to_s) + error['manifest'] = match[1] if error['manifest'].nil? && match # Extract line number from error message when manifest is null - if e['line'].nil? and match - line_number = match[3] - else - line_number = e['line'] - end + line_number = if e['line'].nil? && match + match[3] + else + e['line'] + end if error['manifest'] # Read the file off disk to find the code question - read_code_off_disk('failed',error['manifest'],line_number) + read_code_off_disk('failed', error['manifest'], line_number) end #### Example nodes node_break_down(Array[error['nodes'][index]]) @@ -324,17 +318,15 @@ def process_issues(preview_log) preview_log.each do |issue| li do # Find file path in error if we don't have a file path from preview - match = /(\S*(\/\S*\.pp|\.erb))/.match(issue['message'].to_s) - if issue['file'].nil? and match - issue['file'] = match[1] - end + match = %r{(\S*(\/\S*\.pp|\.erb))}.match(issue['message'].to_s) + issue['file'] = match[1] if issue['file'].nil? && match # Catch errors without a file and set the Error as the file issue['file'] = issue['message'] if issue['file'].nil? # Work around the fact overview doesn't have human readable messages # we store them here and then use them in the breakdown below @error_message[issue['issue_code']] = issue['message'] - a :href => "#%s" % normalize_name(issue['file']), :class => 'tooltip', :title => issue['issue_code'] do - "#{tag! :b,issue['level'].capitalize}: #{issue['file']}:#{issue['line']}" + a href: '#%s' % normalize_name(issue['file']), class: 'tooltip', title: issue['issue_code'] do + "#{tag! :b, issue['level'].capitalize}: #{issue['file']}:#{issue['line']}" end end end @@ -354,9 +346,9 @@ def header1(title) 'margin: 0', 'font-family: "Helvetica Neue",Helvetica,Arial,sans-serif";' ] - div :style=>css.join(';') do + div style: css.join(';') do h1 do - a title, :name => normalize_name(title) + a title, name: normalize_name(title) end end end @@ -374,7 +366,7 @@ def header2(title) 'margin: 0', 'font-family: "Helvetica Neue",Helvetica,Arial,sans-serif";' ] - div :style=>css.join(';') do + div style: css.join(';') do h2 title end end @@ -392,15 +384,15 @@ def header4(title) 'margin: 0', 'font-family: "Helvetica Neue",Helvetica,Arial,sans-serif";' ] - div :style=>css.join(';') do + div style: css.join(';') do h4 title end end head do - title "Diff Overview" - meta :name => "keywords", :content => "puppet, diff, preview" - style :type => "text/css" do + title 'Diff Overview' + meta name: 'keywords', content: 'puppet, diff, preview' + style type: 'text/css' do %[ body { font: 20px/120% "Helvetica Neue",Helvetica,Arial, sans-serif } .tooltip{ @@ -433,10 +425,10 @@ def header4(title) ] end end - body :bgcolor => '#ffffff' do + body bgcolor: '#ffffff' do css = [ 'color: white', - #'background-color: #f9f9f9', + # 'background-color: #f9f9f9', 'background-color: #1a1a1a', 'line-height: 20px', 'display: block', @@ -450,88 +442,87 @@ def header4(title) 'font-family: "Helvetica Neue",Helvetica,Arial,sans-serif"', 'font-size: 2.0rem', 'margin-left: 60px;', - 'float: left', + 'float: left' ] - div :style=>css.join(';') do - img :src => PUPPET_LOGO + div style: css.join(';') do + img src: PUPPET_LOGO end - @error_message = Hash.new + @error_message = {} # TOC - header1 "Catalog Preview Report" + header1 'Catalog Preview Report' ul do [ - "Top 10 nodes with issues", - "Catalog Compliation Known Issues", - "Resource Breakdown", - "Node breakdown", + 'Top 10 nodes with issues', + 'Catalog Compliation Known Issues', + 'Resource Breakdown', + 'Node breakdown' ].each do |title| li do - a title, :href => "#%s" % normalize_name(title) + a title, href: '#%s' % normalize_name(title) end end end # TOP TEN - header1 "Top 10 nodes with issues" + header1 'Top 10 nodes with issues' hr - body "The following nodes had the most issues including missing or conflicting catalogs." + body 'The following nodes had the most issues including missing or conflicting catalogs.' br - body "These nodes are likely the best for testing the breakdown issue list below." + body 'These nodes are likely the best for testing the breakdown issue list below.' ul do # PRE-101 Format changes removed this (beta) key , this raise will catch someone trying to generate an old report - if overview['top_ten'] - top_ten = overview['top_ten'] - else - top_ten = overview['all_nodes'][0..9] - end + top_ten = if overview['top_ten'] + overview['top_ten'] + else + overview['all_nodes'][0..9] + end top_ten.each do |node| preview_log = load_json("/var/opt/lib/pe-puppet/preview/#{node['name']}/preview_log.json") # PRE-103 Compatibility with old format issue_count = (node['error_count'] + node['warning_count']) || node['issue_count'] li do - a :href => '#%s' % normalize_name(node['name']), :title => "#{node['error_count']} Errors and #{node['warning_count']} Warnings", :class => 'tooltip' do + a href: '#%s' % normalize_name(node['name']), title: "#{node['error_count']} Errors and #{node['warning_count']} Warnings", class: 'tooltip' do css = [ 'color: black', 'text-decoration: none', - 'font-size: 1.2rem', + 'font-size: 1.2rem' ] - div :style=>css.join(';') do - "#{tag! :b,issue_count} issues on #{tag! :b, node['name']}" + div style: css.join(';') do + "#{tag! :b, issue_count} issues on #{tag! :b, node['name']}" end end end - unless preview_log.empty? - errors = preview_log.select{ |h| h['level'] == 'error' } - process_issues(errors) unless errors.empty? + next if preview_log.empty? + errors = preview_log.select { |h| h['level'] == 'error' } + process_issues(errors) unless errors.empty? - warnings = preview_log.select{ |h| h['level'] == 'warning' } - process_issues(warnings) unless warnings.empty? - end + warnings = preview_log.select { |h| h['level'] == 'warning' } + process_issues(warnings) unless warnings.empty? end end total_failures = stats['failures']['total'] || 0 # FAILURES - unless total_failures == 0 and baseline.nil? || baseline['compilation_errors'].nil? - header1 "Catalog Compliation Failures" - div.failure_overview! { + unless total_failures.zero? && baseline.nil? || baseline['compilation_errors'].nil? + header1 'Catalog Compliation Failures' + div.failure_overview! do # 0 out X summary # Top level failures key does not show baseline failure or percentage - failures = baseline['compilation_errors'].map{|h| h['nodes']}.flatten.size if total_failures == 0 + failures = baseline['compilation_errors'].map { |h| h['nodes'] }.flatten.size if total_failures.zero? percent = stats['failures']['percent'] || (failures.to_f / stats['node_count'].to_f) * 100.0 <<-eos - #{tag! :strong,failures} out of #{stats['node_count']} nodes failed to compile their catalog. + #{tag! :strong, failures} out of #{stats['node_count']} nodes failed to compile their catalog. This is #{tag! :strong, percent.round(2)}% failure rate across your infrastructure eos - } + end # Compliation Errors Breakdown unless baseline.nil? - header1 "Baseline compilation failures" + header1 'Baseline compilation failures' ul do compilation_errors_baseline_breakdown(baseline) end end unless preview.nil? - header1 "Preview compilation failures" + header1 'Preview compilation failures' ul do compilation_errors_breakdown(preview) end @@ -539,7 +530,7 @@ def header4(title) end # CONFLICTS (KNOWN ISSUES) if stats['conflicting'] - header1 "Catalog Compliation Known Issues" + header1 'Catalog Compliation Known Issues' hr total_conflicts = stats['conflicting']['total'] || 0 css = [ @@ -551,35 +542,35 @@ def header4(title) 'padding-top: 15px', 'padding-right: 15px', 'padding-bottom: 15px', - 'padding-left: 15px', + 'padding-left: 15px' ] - div :style=>css.join(';') do + div style: css.join(';') do # 0 out X summary <<-eos - #{tag! :strong,total_conflicts} out of #{stats['node_count']} nodes have conflicts/differences in their catalog. + #{tag! :strong, total_conflicts} out of #{stats['node_count']} nodes have conflicts/differences in their catalog. This is #{tag! :strong, stats['conflicting']['percent']}% conflict rate across your infrastructure eos end preview['warning_count_by_issue_code'].each do |issue| css = [ 'color: black', - 'font-family: "Helvetica Neue",Helvetica,Arial,sans-serif";', + 'font-family: "Helvetica Neue",Helvetica,Arial,sans-serif";' ] - div :style=>css.join(';') do + div style: css.join(';') do ul do - issue['manifests'].each do |manifest,lines| + issue['manifests'].each do |manifest, lines| if lines.empty? - body "" + body '' next end li do - a :name => normalize_name(manifest) do + a name: normalize_name(manifest) do css = [ 'color: black', 'text-decoration: none', - 'font-size: 1.2rem', + 'font-size: 1.2rem' ] - div :style=>css.join(';') do + div style: css.join(';') do tag! :b, manifest end end @@ -591,14 +582,14 @@ def header4(title) # Use the preview message human readable and fallback to issue code when not present h4.entryTitle do css = [ - 'color: #666', + 'color: #666' ] - div :style=>css.join(';') do + div style: css.join(';') do "Line #{line_number}: #{@error_message[issue['issue_code']] || issue['issue_code']}" end end - read_code_off_disk('warning',manifest,line_number) + read_code_off_disk('warning', manifest, line_number) br # Show human reable error or link @@ -611,36 +602,36 @@ def header4(title) end # CHANGES if overview['changes'] - header1 "Resource Breakdown" + header1 'Resource Breakdown' hr - overview['changes']['resource_type_changes'].each do |type,details| + overview['changes']['resource_type_changes'].each do |type, details| ul do # Type i.e. Class,File header2 type hr if details['missing_resources'] - process_breakdown('missing',type,details['missing_resources']) + process_breakdown('missing', type, details['missing_resources']) end if details['conflicting_resources'] - process_breakdown('conflicting',type,details['conflicting_resources']) + process_breakdown('conflicting', type, details['conflicting_resources']) end end end end # NODES - header1 "Node breakdown" + header1 'Node breakdown' ul do # PRE-101 changes to formating - if overview['top_ten'] - diffs = find_diffs('/var/opt/lib/pe-puppet/preview/') - else - # PRE-103 As the top ten list is sorted by issues, sort the node breakdown by catalog changes - # This is actually the default if the nodes have no issues, but if all nodes have at least - # 1 known issue, then this sorting is skewed in favor of that, thus we always sort explicitly - diffs = overview['all_nodes'].sort_by{ |h| h['added_resource_count'] + h['missing_resource_count'] + h['conflicting_resource_count'] }.map{ |node| "/var/opt/lib/pe-puppet/preview/#{node['name']}/catalog_diff.json" } - end + diffs = if overview['top_ten'] + find_diffs('/var/opt/lib/pe-puppet/preview/') + else + # PRE-103 As the top ten list is sorted by issues, sort the node breakdown by catalog changes + # This is actually the default if the nodes have no issues, but if all nodes have at least + # 1 known issue, then this sorting is skewed in favor of that, thus we always sort explicitly + overview['all_nodes'].sort_by { |h| h['added_resource_count'] + h['missing_resource_count'] + h['conflicting_resource_count'] }.map { |node| "/var/opt/lib/pe-puppet/preview/#{node['name']}/catalog_diff.json" } + end diffs.each do |catalog_diff_file| - #puts catalog_diff_file + # puts catalog_diff_file if File.zero?(catalog_diff_file) body "Diff file empty on disk: #{catalog_diff_file}" next @@ -648,141 +639,137 @@ def header4(title) catalog_diff = load_json(catalog_diff_file) li do h3 do - a catalog_diff['node_name'], :name => normalize_name(catalog_diff['node_name']) + a catalog_diff['node_name'], name: normalize_name(catalog_diff['node_name']) end end # Node stats table ul do - table do - if @pie_chart - pie_chart(catalog_diff) - end - end - table do - count = 0 - catalog_diff.each do |key,value| - next if ['added_resources','missing_resources','conflicting_resources','missing_edges','produced_by','timestamp','node_name'].include?(key) - next if value.nil? - if value.kind_of?(Array) then next if value.empty? end - next if value == 0 - count += 1 - if count.even? - color = 'white' - else - color = '#f5f5f5' - end + table do + pie_chart(catalog_diff) if @pie_chart + end + table do + count = 0 + catalog_diff.each do |key, value| + next if %w(added_resources missing_resources conflicting_resources missing_edges produced_by timestamp node_name).include?(key) + next if value.nil? + if value.is_a?(Array) then next if value.empty? end + next if value == '0' + count += 1 + color = if count.even? + 'white' + else + '#f5f5f5' + end - css = [ - 'color: black', - 'font-family: Helvetica, Arial, sans-serif', - 'border-collapse: collapse', - 'border-style: solid', - 'border-spacing: 1px', - 'border-width: 1px', - 'padding-bottom: 1px', - 'background-clip: padding-box', - "background-color: #{color}", - 'border-color: #dcdcdc', - 'width: 768px', - ] - div :style=>css.join(';') do - table do - th_css = [ - 'background: grey', - 'font-weight: bold', - ] - div :style=>th_css.join(';') do - th "#{key.capitalize.gsub(/_/,' ')}:" - end - td_css = [ - 'background: #FAFAFA', - 'text-align: center', - ] - div :style=>td_css.join(';') do - td value - end + css = [ + 'color: black', + 'font-family: Helvetica, Arial, sans-serif', + 'border-collapse: collapse', + 'border-style: solid', + 'border-spacing: 1px', + 'border-width: 1px', + 'padding-bottom: 1px', + 'background-clip: padding-box', + "background-color: #{color}", + 'border-color: #dcdcdc', + 'width: 768px' + ] + div style: css.join(';') do + table do + th_css = [ + 'background: grey', + 'font-weight: bold' + ] + div style: th_css.join(';') do + th "#{key.capitalize.tr('_', ' ')}:" + end + td_css = [ + 'background: #FAFAFA', + 'text-align: center' + ] + div style: td_css.join(';') do + td value end end end end - tag! :i, "Last compiled: #{catalog_diff['timestamp']} with #{catalog_diff['produced_by']}" end - # NODE Level Conflicts - if catalog_diff['missing_resources'] - header4 "Missing Resources on #{catalog_diff['node_name']}" unless catalog_diff['missing_resource_count'].zero? - catalog_diff['missing_resources'].sort_by{ |h| h['type']}.each do |missing| - ul do - li do - # LINK 01 - a :href => normalize_name("#missing_#{missing['type']}_#{missing['title']}") do - '%s[%s]' % [missing['type'],missing['title']] - end - end + tag! :i, "Last compiled: #{catalog_diff['timestamp']} with #{catalog_diff['produced_by']}" + end + # NODE Level Conflicts + if catalog_diff['missing_resources'] + header4 "Missing Resources on #{catalog_diff['node_name']}" unless catalog_diff['missing_resource_count'].zero? + catalog_diff['missing_resources'].sort_by { |h| h['type'] }.each do |missing| + ul do + li do + # LINK 01 + a href: normalize_name("#missing_#{missing['type']}_#{missing['title']}") do + '%s[%s]' % [missing['type'], missing['title']] + end end end end - if catalog_diff['added_resources'] - header4 "Added Resources on #{catalog_diff['node_name']}" unless catalog_diff['added_resource_count'].zero? - catalog_diff['added_resources'].sort_by{ |h| h['type']}.each do |added| - ul do - li do - # LINK 01 - a :href => normalize_name("#added_#{added['type']}_#{added['title']}") do - '%s[%s]' % [added['type'],added['title']] - end - end + end + if catalog_diff['added_resources'] + header4 "Added Resources on #{catalog_diff['node_name']}" unless catalog_diff['added_resource_count'].zero? + catalog_diff['added_resources'].sort_by { |h| h['type'] }.each do |added| + ul do + li do + # LINK 01 + a href: normalize_name("#added_#{added['type']}_#{added['title']}") do + '%s[%s]' % [added['type'], added['title']] + end end end end - if catalog_diff['conflicting_resources'] && ! catalog_diff['conflicting_resources'].empty? - header4 "Conflicting Resources on #{catalog_diff['node_name']}" + end + next unless catalog_diff['conflicting_resources'] && !catalog_diff['conflicting_resources'].empty? + header4 "Conflicting Resources on #{catalog_diff['node_name']}" + ul do + catalog_diff['conflicting_resources'].each do |conflict| + li do + a href: '#%s' % normalize_name("conflicting_#{conflict['type']}_#{conflict['title']}"), name: normalize_name("#{catalog_diff['node_name']}_#{conflict['type']}[#{conflict['title']}]") do + "#{conflict['type']}[#{conflict['title']}]" + end + end ul do - catalog_diff['conflicting_resources'].each do |conflict| - li do - a :href => '#%s' % normalize_name("conflicting_#{conflict['type']}_#{conflict['title']}"),:name => normalize_name("#{catalog_diff['node_name']}_#{conflict['type']}[#{conflict['title']}]") do - "#{conflict['type']}[#{conflict['title']}]" - end - end - ul do - ul do - conflict['conflicting_attributes'].each do |attribute| - css = [ - 'color: black', - 'background-color: white', - 'border-width: 1px', - 'border-bottom-width: 1px;', - 'border-bottom-style: dotted', - 'border-style: dotted solid', - 'border-color: rgb(221, 221, 221);', - 'padding-top: 15px', - 'padding-right: 15px', - 'padding-bottom: 15px', - 'padding-left: 15px', - 'border-left-width: 4px', - 'width: 768', - ] - div :style=>css.join(';') do - ['%s{ \'%s\':' % [conflict['type'].downcase,conflict['title'].downcase], - '- %s => %s' % [attribute['name'],attribute['baseline_value'].inspect], - '+ %s => %s' % [attribute['name'],attribute['preview_value'].inspect], - '}', - ].each do |line| - tag! :code do - if line =~ /^\-.*/ - div :style=> "background-color:#ffecec" do - tag! :font, :color => '#bd2c00' do + ul do + conflict['conflicting_attributes'].each do |attribute| + css = [ + 'color: black', + 'background-color: white', + 'border-width: 1px', + 'border-bottom-width: 1px;', + 'border-bottom-style: dotted', + 'border-style: dotted solid', + 'border-color: rgb(221, 221, 221);', + 'padding-top: 15px', + 'padding-right: 15px', + 'padding-bottom: 15px', + 'padding-left: 15px', + 'border-left-width: 4px', + 'width: 768' + ] + div style: css.join(';') do + ['%s{ \'%s\':' % [conflict['type'].downcase, conflict['title'].downcase], + '- %s => %s' % [attribute['name'], attribute['baseline_value'].inspect], + '+ %s => %s' % [attribute['name'], attribute['preview_value'].inspect], + '}'].each do |line| + tag! :code do + if line =~ %r{^\-.*} + div style: 'background-color:#ffecec' do + tag! :font, color: '#bd2c00' do "#{line} " - end end - elsif line =~/^\+.*/ - div :style=> "background-color:#eaffea" do - tag! :font, :color => '#55a532' do + end + elsif line =~ %r{^\+.*} + div style: 'background-color:#eaffea' do + tag! :font, color: '#55a532' do "#{line} " - end end - else - line end + else + line end end end