-
Notifications
You must be signed in to change notification settings - Fork 0
/
rid_test.go
78 lines (60 loc) · 1.42 KB
/
rid_test.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
package rid
import (
"strings"
"testing"
"time"
)
func TestGeneric(t *testing.T) {
a := New("")
t.Logf("Generated ID: (%s)", a)
b := New("")
t.Logf("Generated ID: (%s)", b)
if a == b {
t.Errorf("consecutive IDs do not differ (%s) (%s)", a, b)
return
}
}
func TestKind(t *testing.T) {
a := New(Channel)
t.Logf("Generated channel ID: (%s)", a)
if !strings.HasSuffix(a, "-ch") {
t.Errorf("failed to apply proper resource suffix (%s); should have be -ch", a)
}
}
func TestKindClipping(t *testing.T) {
a := New("hello")
t.Logf("Generated hello ID: (%s)", a)
if !strings.HasSuffix(a, "-he") {
t.Errorf("failed to apply proper resource suffix (%s); should have been -he", a)
}
}
func TestTimestamp(t *testing.T) {
a := New(Channel)
ts, err := Timestamp(a)
if err != nil {
t.Error("failed to parse channel resource ID", err)
return
}
t.Log("parsed timestamp", ts.String())
if time.Since(ts) > time.Second {
t.Error("timestamp is older than a second")
}
if time.Until(ts) > time.Second {
t.Error("timestamp is in the future")
}
}
func TestTimestampGeneric(t *testing.T) {
a := New("")
ts, err := Timestamp(a)
if err != nil {
t.Error("failed to parse channel resource ID", err)
return
}
t.Log("parsed timestamp", ts.String())
if time.Since(ts) > time.Second {
t.Error("timestamp is older than a second")
}
if time.Until(ts) > time.Second {
t.Error("timestamp is in the future")
}
}