| 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
 | module Charts
  class Chart
    attr_reader :labels, :total, :success, :project, :build_times
    def initialize(project)
      @labels = []
      @total = []
      @success = []
      @build_times = []
      @project = project
      collect
    end
    def push(from, to, format)
      @labels << from.strftime(format)
      @total << project.builds.
        where('? > builds.created_at AND builds.created_at > ?', to, from).
        count(:all)
      @success << project.builds.
        where('? > builds.created_at AND builds.created_at > ?', to, from).
        success.count(:all)
    end
  end
  class YearChart < Chart
    def collect
      13.times do |i|
        start_month = (Date.today.years_ago(1) + i.month).beginning_of_month
        end_month = start_month.end_of_month
        push(start_month, end_month, "%d %B %Y")
      end
    end
  end
  class MonthChart < Chart
    def collect
      30.times do |i|
        start_day = Date.today - 30.days + i.days
        end_day = Date.today - 30.days + i.day + 1.day
        push(start_day, end_day, "%d %B")
      end
    end
  end
  class WeekChart < Chart
    def collect
      7.times do |i|
        start_day = Date.today - 7.days + i.days
        end_day = Date.today - 7.days + i.day + 1.day
        push(start_day, end_day, "%d %B")
      end
    end
  end
  class BuildTime < Chart
    def collect
      commits = project.commits.joins(:builds).where('builds.finished_at is NOT NULL AND builds.started_at is NOT NULL').last(30)
      commits.each do |commit|
        @labels << commit.short_sha
        @build_times << (commit.duration / 60)
      end
    end
  end
end
 |