mirror of
https://github.com/chromebrew/chromebrew.git
synced 2026-01-08 23:18:10 -05:00
* Rename IgnoredPatterns to AllowedPatterns. * Exclude docopt.rb (not our code) from Rubocop * Disable Style/RedundantReturn * Disable Style/MutableConstant * Disable Style/NumericLiterals * Set Layout/IndentationStyle to spaces * Temporarily disable various cops. * Add Rubocop CI via Octocop * Lint tree with rubocop -A -c .rubocop.yml Co-authored-by: Satadru Pramanik <satadru@gmail.com>
68 lines
1.5 KiB
Ruby
Executable File
68 lines
1.5 KiB
Ruby
Executable File
#!/usr/bin/env ruby
|
|
|
|
# This test checks whether the packages create a dependency cycle.
|
|
|
|
require 'find'
|
|
require_relative '../lib/const'
|
|
require_relative '../lib/color'
|
|
require_relative '../lib/package'
|
|
|
|
@all_pkgs = {}
|
|
|
|
$LOAD_PATH.unshift '../lib'
|
|
|
|
puts "Running dependency cycle tests...\n".yellow
|
|
|
|
# Loads all packages
|
|
Dir['../packages/*.rb'].each do |filename|
|
|
name = File.basename(filename, '.rb')
|
|
pkg = Package.load_package(filename, name)
|
|
@all_pkgs[name] = pkg
|
|
end
|
|
|
|
# Looking for cycles. @path will keep the current dependency path.
|
|
# @state will store :on_path for vertices on the current dependency path
|
|
# and :visited for vertices that have already been checked not to lead to
|
|
# cycles.
|
|
@failed = 0
|
|
@state = {}
|
|
@path = []
|
|
@uniq_path = []
|
|
def dfs(pkg)
|
|
@path.push(pkg.name)
|
|
case @state[pkg]
|
|
when :on_path
|
|
@path.shift while @path.first != @path.last
|
|
if (!@uniq_path.include? @path.to_s) && @path.to_s.include?(',')
|
|
@uniq_path.push(@path.to_s)
|
|
@failed += 1
|
|
end
|
|
when nil
|
|
@state[pkg] = :on_path
|
|
pkg.dependencies&.each do |name, _v|
|
|
dfs(@all_pkgs[name]) if name != pkg.name
|
|
end
|
|
@state[pkg] = :visited
|
|
end
|
|
@path.pop
|
|
end
|
|
|
|
# Calls dfs for every path
|
|
@all_pkgs.each do |_name, pkg|
|
|
dfs(pkg)
|
|
end
|
|
|
|
# Display dependency cycles
|
|
@uniq_path.sort.each do |path|
|
|
puts path.lightred
|
|
end
|
|
|
|
@cycles = 'cycles'
|
|
@cycles = 'cycle' if @failed == 1
|
|
|
|
if @failed.positive?
|
|
abort "\n#{@failed} dependency #{@cycles} found.".lightred
|
|
else
|
|
puts "\nNo dependency cycles found.".lightgreen
|
|
end
|