-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathcalculations.go
67 lines (57 loc) · 2.44 KB
/
calculations.go
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
package main
import (
"strings"
"time"
"github.com/brejoc/githubv4"
)
// Calculates how long an issue was blocked
func calculateBlockedTime() {
//TODO: Implement me
}
// Calculates how long an issue was worked on
func calculateWipTime() {
//TODO: Implement me
}
// Calculates the cycle time of an issue.
// Therefore we need to get the date of when the issue was moved to one of the "planned" columns first. The planned
// columns are defined in the config. The cycle time is the difference between this date and when the issue was closed.
func calculateCycleTime(timelineItems queryTimelineItems, createdAt githubv4.DateTime,
closedAt githubv4.DateTime, boardName string) time.Duration {
for _, event := range timelineItems.Nodes {
if event.Typename == "MovedColumnsInProjectEvent" {
if strings.ToLower(string(event.MovedEvent.Project.Name)) == strings.ToLower(boardName) {
// previousColumn := strings.ToLower(string(event.MovedEvent.PreviousProjectColumnName))
targetColumn := strings.ToLower(string(event.MovedEvent.ProjectColumnName))
// Start time is when an issue is moved to a planned (backlog) column
if isColumnInColumnSlice(targetColumn, config.Boards[boardName].PlannedColumns) &&
event.AddedEvent.CreatedAt.Before(closedAt.Time) {
return closedAt.Sub(event.MovedEvent.CreatedAt.Time)
}
}
}
}
// There are cases when issues are added to boards directly in backlog or "in progress" (skipping inbox)
// In those cases we consider the time the issue was added to the board as the initial cycle time
for _, event := range timelineItems.Nodes {
if strings.ToLower(string(event.AddedEvent.Project.Name)) == strings.ToLower(boardName) &&
event.AddedEvent.CreatedAt.Before(closedAt.Time) {
return closedAt.Sub(event.AddedEvent.CreatedAt.Time)
}
}
// The issue was not handled correctly. Assume cycle time = lead time in such cases
return calculateLeadTime(createdAt, closedAt)
}
// Calculates the lead time of an issue.
// This is the difference between when the issues was created and closed.
func calculateLeadTime(createdAt githubv4.DateTime, closedAt githubv4.DateTime) time.Duration {
return closedAt.Sub(createdAt.Time)
}
// isColumenInColumnSlice checks if a column is in a slice of columns. Cases are ignored.
func isColumnInColumnSlice(column string, list []string) bool {
for _, sliceColumn := range list {
if strings.ToLower(sliceColumn) == strings.ToLower(column) {
return true
}
}
return false
}