summaryrefslogtreecommitdiff
path: root/scripts/static-analysis
blob: 7dc8f6790364041d58291c05df26c943758f2ca5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#!/usr/bin/env ruby

require ::File.expand_path('../lib/gitlab/popen', __dir__)

tasks = [
  %w[bundle exec bundle-audit check --update --ignore CVE-2016-4658],
  %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