-
Notifications
You must be signed in to change notification settings - Fork 0
/
gotest2bq.go
117 lines (103 loc) · 2.46 KB
/
gotest2bq.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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
package gotest2bq
import (
"bufio"
"context"
"encoding/json"
"fmt"
"os"
"time"
"cloud.google.com/go/bigquery"
"github.com/google/uuid"
)
type TestEvent struct {
Branch string `bigquery:"branch"`
Env string `bigquery:"env"`
Commit string `bigquery:"commit"`
GroupId string `bigquery:"group_id"`
Time time.Time `bigquery:"time"`
Action string `bigquery:"action"`
Package string `bigquery:"package"`
Test string `bigquery:"test"`
Elapsed float64 `bigquery:"elapsed"`
Output string `bigquery:"-"`
}
func loadTestLog(args GoTest2BQArgs) ([]*TestEvent, error) {
testEvents := make([]*TestEvent, 0)
file, err := os.Open(args.Filename)
if err != nil {
return nil, err
}
defer file.Close()
scanner := bufio.NewScanner(file)
for scanner.Scan() {
line := scanner.Text()
testEvent := &TestEvent{}
err := json.Unmarshal([]byte(line), testEvent)
if err != nil {
return nil, err
}
testEvent.Branch = args.Branch
testEvent.Env = args.Env
testEvent.Commit = args.Commit
testEvent.GroupId = args.groupId
testEvents = append(testEvents, testEvent)
}
if err := scanner.Err(); err != nil {
return nil, err
}
return testEvents, nil
}
type GoTest2BQArgs struct {
Branch string
Env string
Commit string
Filename string
Project string
Dataset string
Table string
groupId string
}
func GoTest2BQ(args GoTest2BQArgs) error {
ctx := context.Background()
args.groupId = uuid.NewString()
testEvents, err := loadTestLog(args)
if err != nil {
return fmt.Errorf("load test log: %w", err)
}
client, err := bigquery.NewClient(ctx, args.Project)
if err != nil {
return fmt.Errorf("bigquery client: %w", err)
}
defer client.Close()
schema, err := bigquery.InferSchema(TestEvent{})
if err != nil {
return fmt.Errorf("infer schema: %w", err)
}
schema = schema.Relax()
table := client.Dataset(args.Dataset).Table(args.Table)
tm, err := table.Metadata(ctx)
if err != nil {
err := table.Create(ctx, &bigquery.TableMetadata{
Schema: schema,
TimePartitioning: &bigquery.TimePartitioning{
Field: "time",
},
},
)
if err != nil {
return fmt.Errorf("create table: %w", err)
}
} else {
_, err = table.Update(ctx, bigquery.TableMetadataToUpdate{
Schema: schema,
}, tm.ETag)
}
if err != nil {
return fmt.Errorf("update table: %w", err)
}
inserter := table.Inserter()
if err := inserter.Put(ctx, testEvents); err != nil {
return fmt.Errorf("insert: %w", err)
}
return nil
}