1
#!/usr/bin/env ruby
2
3
require 'tmpdir'
4
require "fileutils"
5
6
LOCK_FILE_PATH = File.join(Dir.tmpdir, "gitorious_graphgenerator_lockfile")
7
if File.exist?(LOCK_FILE_PATH)
8
    $stderr.puts "Lockfile '#{LOCK_FILE_PATH}' exists!"
9
    exit(1)
10
end
11
12
ENV["PATH"] = "/usr/local/bin/:/opt/local/bin:#{ENV["PATH"]}"
13
14
FileUtils.touch(LOCK_FILE_PATH)
15
16
ENV["RAILS_ENV"] ||= "production"
17
require File.dirname(__FILE__) + "/../config/environment"
18
19
log = Logger.new(File.join(RAILS_ROOT, "log", "graph_generator.log"))
20
log.formatter = Logger::Formatter.new
21
log.level = Logger::INFO
22
log.formatter.datetime_format = "%Y-%m-%d %H:%M:%S"
23
24
STATUS_FILE = File.join(RAILS_ROOT, "tmp", "graph_generator.status")
25
update_status = !File.exist?(STATUS_FILE)
26
tmpdir = File.join(RAILS_ROOT, "tmp", "graph_generator")
27
if !File.directory?(tmpdir)
28
  FileUtils.mkdir_p(tmpdir)
29
elsif !update_status
30
  mtime = File.mtime(STATUS_FILE).utc
31
32
  days = (Time.now.utc - mtime) / (3600*24)
33
  if days >= 5
34
    log.info "Cleaning '#{tmpdir}'..."
35
    Dir.glob(File.join(tmpdir, "*.status")) do |file|
36
      FileUtils.rm(file)
37
    end
38
39
    update_status = true
40
  end
41
end
42
43
if update_status
44
  FileUtils.touch(STATUS_FILE)
45
end
46
47
log.info "Starting graph generation run..."
48
Repository.find(:all).each_with_index do |repository, index|
49
	begin
50
		Gitorious::Graphs::Builder.generate_all_for(repository)
51
		if index % 5 == 0
52
			# GC every five cycles
53
			GC.start
54
		end
55
		sleep(0.1)
56
	rescue => e
57
		log.fatal "Error generating graphs for repo##{repository.id}"
58
    exception_backtrace_string = "#{e.class.name} #{e.message}\n#{e.backtrace.join("\n  ")}"
59
    log.fatal exception_backtrace_string
60
    $stderr.puts exception_backtrace_string
61
#    exit(1)		
62
	end
63
end
64
log.info "Done with graph generation run"
65
66
FileUtils.rm(LOCK_FILE_PATH)