2017-04-28 11:31:18 -04:00
|
|
|
#!/usr/bin/env ruby
|
|
|
|
|
|
|
|
require ::File.expand_path('../lib/gitlab/popen', __dir__)
|
|
|
|
|
|
|
|
tasks = [
|
2017-06-12 16:45:55 -04:00
|
|
|
%w[bundle exec bundle-audit check --update --ignore CVE-2016-4658 CVE-2017-5029],
|
2017-04-28 11:31:18 -04:00
|
|
|
%w[bundle exec rake config_lint],
|
|
|
|
%w[bundle exec rake flay],
|
|
|
|
%w[bundle exec rake haml_lint],
|
|
|
|
%w[bundle exec rake scss_lint],
|
|
|
|
%w[bundle exec rake brakeman],
|
|
|
|
%w[bundle exec license_finder],
|
|
|
|
%w[yarn run eslint],
|
|
|
|
%w[bundle exec rubocop --require rubocop-rspec]
|
|
|
|
]
|
|
|
|
|
|
|
|
failed_tasks = tasks.reduce({}) do |failures, task|
|
|
|
|
output, status = Gitlab::Popen.popen(task)
|
|
|
|
|
|
|
|
puts "Running: #{task.join(' ')}"
|
|
|
|
puts output
|
|
|
|
|
|
|
|
failures[task.join(' ')] = output unless status.zero?
|
|
|
|
|
|
|
|
failures
|
|
|
|
end
|
|
|
|
|
|
|
|
if failed_tasks.empty?
|
|
|
|
puts 'All static analyses passed successfully.'
|
|
|
|
else
|
|
|
|
puts "\n===================================================\n\n"
|
|
|
|
puts "Some static analyses failed:"
|
|
|
|
|
|
|
|
failed_tasks.each do |failed_task, output|
|
|
|
|
puts "\n**** #{failed_task} failed with the following error:\n\n"
|
|
|
|
puts output
|
|
|
|
end
|
|
|
|
|
|
|
|
exit 1
|
|
|
|
end
|