-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathclock_test.go
More file actions
30 lines (28 loc) · 754 Bytes
/
clock_test.go
File metadata and controls
30 lines (28 loc) · 754 Bytes
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
package main
import (
"testing"
)
func TestMonotonicClock(t *testing.T) {
c := MonotonicClock(0, 0, 0, 5_000_000)
now1 := c.Now()
now2 := c.Now()
if now1.Unix() == now2.Unix() && now1.UnixNano() == now2.UnixNano() {
t.Fail()
t.Logf("now1==now2 = %v & %v & %v.%v", now1, now2, now1.Unix(), now1.UnixNano())
return
}
if now2.Unix() != now2.Unix() {
t.Fail()
t.Logf("now1.Unix()==now2.Unix() = %v & %v", now1, now2)
return
}
if now2.UnixNano() != (now1.UnixNano() + 5_000_000) {
t.Fail()
t.Logf("now2.UnixNano()!=now1.UnixNano()+5_000_000 = now1:%v (%d.%d) & now2:%v (%d.%d) => %d!=%d",
now1, now1.Unix(), now1.UnixNano(),
now2, now2.Unix(), now2.UnixNano(),
now2.UnixNano(), now1.UnixNano()+5_000_000,
)
return
}
}