blob: f5ded7a78b8041a240c408cbca5244973a338bf6 (
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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
 | #!/usr/bin/env ruby
#
#
#
require 'yaml'
require 'tmpdir'
class YamlValidate
  def self.yaml_file?(filename)
    return filename.end_with?('.yaml') || filename.end_with?('.yml')
  end
  def self.short_yaml_ext?(filename)
    return filename.end_with?(".yml")
  end
  def self.valid_yaml?(filename)
    YAML::load_file(filename)
    return true
  end
end
class GitCommit
  attr_accessor :oldrev, :newrev, :refname, :tmp
  def initialize(oldrev, newrev, refname)
    @oldrev = oldrev
    @newrev = newrev
    @refname = refname
    @tmp = Dir.mktmpdir(@newrev)
  end
  def get_file_changes()
    files = %x[/usr/bin/git diff --name-only #{@oldrev} #{@newrev} --diff-filter=ACM].split("\n")
    # if files is empty we will get a full checkout.  This happens on
    # a git rm file.  If there are no changes then we need to skip the archive
    return [] if files.empty?
    # We only want to take the files that changed.  Archive will do that when passed
    # the filenames.  It will export these to a tmp dir
    system("/usr/bin/git archive #{@newrev} #{files.join(" ")} | tar x -C #{@tmp}")
    return Dir.glob("#{@tmp}/**/*").delete_if { |file| File.directory?(file) }
  end
end
if __FILE__ == $0
  while data = STDIN.gets
    oldrev, newrev, refname = data.split
    gc = GitCommit.new(oldrev, newrev, refname)
    results = []
    gc.get_file_changes().each do |file|
      begin
        puts "++++++ Received:  #{file}"
        #raise "Yaml file extensions must be .yaml not .yml" if YamlValidate.short_yaml_ext? file
        # skip readme, other files, etc
        next unless YamlValidate.yaml_file?(file)
        results << YamlValidate.valid_yaml?(file)
      rescue Exception => ex
        puts "\n#{ex.message}\n\n"
        results << false
      end
    end
    #puts "RESULTS\n#{results.inspect}\n"
    exit 1 if results.include?(false)
  end
end
 |