-
Notifications
You must be signed in to change notification settings - Fork 1
/
fields_test.go
110 lines (94 loc) · 2.83 KB
/
fields_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
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
package qstring
import (
"net/url"
"strings"
"testing"
)
func TestComparativeTimeParse(t *testing.T) {
tme := "2006-01-02T15:04:05Z"
testio := []struct {
inp string
operator string
errString string
}{
{inp: tme, operator: "=", errString: ""},
{inp: ">" + tme, operator: ">", errString: ""},
{inp: "<" + tme, operator: "<", errString: ""},
{inp: ">=" + tme, operator: ">=", errString: ""},
{inp: "<=" + tme, operator: "<=", errString: ""},
{inp: "<=" + tme, operator: "<=", errString: ""},
{inp: "", operator: "=", errString: "qstring: Invalid Timestamp Query"},
{inp: ">=", operator: "=", errString: "qstring: Invalid Timestamp Query"},
{inp: ">=" + "foobar", operator: ">=",
errString: `parsing time "foobar" as "2006-01-02T15:04:05Z07:00": cannot parse "foobar" as "2006"`},
}
var ct *ComparativeTime
var err error
for _, test := range testio {
ct = NewComparativeTime()
err = ct.Parse(test.inp)
if ct.Operator != test.operator {
t.Errorf("Expected operator %q, got %q", test.operator, ct.Operator)
}
if err == nil && len(test.errString) != 0 {
t.Errorf("Expected error %q, got nil", test.errString)
}
if err != nil && err.Error() != test.errString {
t.Errorf("Expected error %q, got %q", test.errString, err.Error())
}
}
}
func TestComparativeTimeUnmarshal(t *testing.T) {
type Query struct {
Created ComparativeTime
Modified ComparativeTime
}
createdTS := ">2006-01-02T15:04:05Z"
updatedTS := "<=2016-01-02T15:04:05-07:00"
query := url.Values{
"created": []string{createdTS},
"modified": []string{updatedTS},
}
params := &Query{}
err := Unmarshal(query, params)
if err != nil {
t.Fatal(err.Error())
}
created := params.Created.String()
if created != createdTS {
t.Errorf("Expected created ts of %s, got %s instead.", createdTS, created)
}
modified := params.Modified.String()
if modified != updatedTS {
t.Errorf("Expected update ts of %s, got %s instead.", updatedTS, modified)
}
}
func TestComparativeTimeMarshalString(t *testing.T) {
type Query struct {
Created ComparativeTime
Modified ComparativeTime
}
createdTS := ">2006-01-02T15:04:05Z"
created := NewComparativeTime()
created.Parse(createdTS)
updatedTS := "<=2016-01-02T15:04:05-07:00"
updated := NewComparativeTime()
updated.Parse(updatedTS)
q := &Query{*created, *updated}
result, err := MarshalString(q)
if err != nil {
t.Fatalf("Unable to marshal comparative timestamp: %s", err.Error())
}
var unescaped string
unescaped, err = url.QueryUnescape(result)
if err != nil {
t.Fatalf("Unable to unescape query string %q: %q", result, err.Error())
}
expected := []string{"created=>2006-01-02T15:04:05Z",
"modified=<=2016-01-02T15:04:05-07:00"}
for _, ts := range expected {
if !strings.Contains(unescaped, ts) {
t.Errorf("Expected query string %s to contain %s", unescaped, ts)
}
}
}