/
models.go
68 lines (60 loc) · 2.06 KB
/
models.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
package database
import (
"database/sql"
"time"
"github.com/ooni/probe-engine/pkg/model"
"github.com/pkg/errors"
)
// Finished implements WritableDatabase.Finished
func (d *Database) Finished(result *model.DatabaseResult) error {
if result.IsDone || result.Runtime != 0 {
return errors.New("Result is already finished")
}
result.Runtime = time.Now().UTC().Sub(result.StartTime).Seconds()
result.IsDone = true
err := d.sess.Collection("results").Find("result_id", result.ID).Update(result)
if err != nil {
return errors.Wrap(err, "updating finished result")
}
return nil
}
// Failed implements WritableDatabase.Failed
func (d *Database) Failed(msmt *model.DatabaseMeasurement, failure string) error {
msmt.FailureMsg = sql.NullString{String: failure, Valid: true}
msmt.IsFailed = true
err := d.sess.Collection("measurements").Find("measurement_id", msmt.ID).Update(msmt)
if err != nil {
return errors.Wrap(err, "updating measurement")
}
return nil
}
// Done implements WritableDatabase.Done
func (d *Database) Done(msmt *model.DatabaseMeasurement) error {
runtime := time.Now().UTC().Sub(msmt.StartTime)
msmt.Runtime = runtime.Seconds()
msmt.IsDone = true
err := d.sess.Collection("measurements").Find("measurement_id", msmt.ID).Update(msmt)
if err != nil {
return errors.Wrap(err, "updating measurement")
}
return nil
}
// UploadFailed implements WritableDatabase.UploadFailed
func (d *Database) UploadFailed(msmt *model.DatabaseMeasurement, failure string) error {
msmt.UploadFailureMsg = sql.NullString{String: failure, Valid: true}
msmt.IsUploaded = false
err := d.sess.Collection("measurements").Find("measurement_id", msmt.ID).Update(msmt)
if err != nil {
return errors.Wrap(err, "updating measurement")
}
return nil
}
// UploadSucceeded implements WritableDatabase.UploadSucceeded
func (d *Database) UploadSucceeded(msmt *model.DatabaseMeasurement) error {
msmt.IsUploaded = true
err := d.sess.Collection("measurements").Find("measurement_id", msmt.ID).Update(msmt)
if err != nil {
return errors.Wrap(err, "updating measurement")
}
return nil
}