Class: Quality::Runner

Inherits:
Object
  • Object
show all
Extended by:
Forwardable
Includes:
Tools::Bigfiles, Tools::Brakeman, Tools::Cane, Tools::Eslint, Tools::Flay, Tools::Flog, Tools::Jscs, Tools::Pep8, Tools::Punchlist, Tools::RailsBestPractices, Tools::Reek, Tools::Rubocop
Defined in:
lib/quality/runner.rb

Overview

Knows how to run different quality tools based on a configuration already determined.

Instance Method Summary collapse

Constructor Details

#initialize(config, gem_spec: Gem::Specification, quality_checker_class: Quality::QualityChecker, count_io: IO, count_file: File, globber: Dir, which: Which.new) ⇒ Runner

Returns a new instance of Runner.



36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
# File 'lib/quality/runner.rb', line 36

def initialize(config,
               gem_spec: Gem::Specification,
               quality_checker_class: Quality::QualityChecker,
               count_io: IO,
               count_file: File,
               globber: Dir,
               which: Which.new)
  @config = config
  @gem_spec = gem_spec
  @quality_checker_class = quality_checker_class
  @count_io = count_io
  @count_file = count_file
  @globber = globber
  @which = which
end

Instance Method Details

#count_existing_violations(filename) ⇒ Object



85
86
87
88
89
# File 'lib/quality/runner.rb', line 85

def count_existing_violations(filename)
  existing_violations = @count_io.read(filename).to_i
  fail("Problem with file #{filename}") if existing_violations < 0
  existing_violations
end

#ratchet_quality_cmd(cmd, command_options, &count_violations_on_line) ⇒ Object



99
100
101
102
103
104
105
106
107
# File 'lib/quality/runner.rb', line 99

def ratchet_quality_cmd(cmd,
                        command_options,
                        &count_violations_on_line)
  quality_checker = @quality_checker_class.new(cmd,
                                               command_options,
                                               @config.output_dir,
                                               @config.verbose)
  quality_checker.execute(&count_violations_on_line)
end

#run_qualityObject



52
53
54
# File 'lib/quality/runner.rb', line 52

def run_quality
  tools.each { |tool| run_quality_with_tool(tool) }
end

#run_quality_with_tool(tool) ⇒ Object



56
57
58
59
60
61
62
63
64
65
66
# File 'lib/quality/runner.rb', line 56

def run_quality_with_tool(tool)
  suppressed = @config.skip_tools.include? tool
  installed = @gem_spec.find_all_by_name(tool).any? ||
              !@which.which(tool).nil?

  if installed && !suppressed
    method("quality_#{tool}".to_sym).call
  elsif !installed
    puts "#{tool} not installed"
  end
end

#run_ratchetObject



68
69
70
# File 'lib/quality/runner.rb', line 68

def run_ratchet
  @config.all_output_files.each { |filename| run_ratchet_on_file(filename) }
end

#run_ratchet_on_file(filename) ⇒ Object



72
73
74
75
76
77
# File 'lib/quality/runner.rb', line 72

def run_ratchet_on_file(filename)
  puts "Processing #{filename}"
  existing_violations = count_existing_violations(filename)
  new_violations = [0, existing_violations - 1].max
  write_violations(filename, new_violations)
end

#toolsObject



91
92
93
94
95
96
97
# File 'lib/quality/runner.rb', line 91

def tools
  self.class.ancestors.map do |ancestor|
    ancestor_name = ancestor.to_s
    next unless ancestor_name.start_with?('Quality::Tools::')
    ancestor_name.split('::').last.underscore
  end.compact
end

#write_violations(filename, new_violations) ⇒ Object



79
80
81
82
83
# File 'lib/quality/runner.rb', line 79

def write_violations(filename, new_violations)
  @count_file.open(filename, 'w') do |file|
    file.write(new_violations.to_s + "\n")
  end
end