forked from SparkPost/gosparkpost
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmessage_events_test.go
142 lines (128 loc) · 4.71 KB
/
message_events_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
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
package gosparkpost_test
import (
"fmt"
"reflect"
"testing"
sp "github.com/SparkPost/gosparkpost"
"github.com/SparkPost/gosparkpost/events"
"github.com/kylelemons/godebug/pretty"
"github.com/pkg/errors"
)
type EventsPageResult struct {
err error
status int
json string
out *sp.EventsPage
}
func TestMessageEventsSearch(t *testing.T) {
var err error
msgEventsPageAll.json = loadTestFile(t, "test/json/message-events_search_200.json")
msgEventsPage1.json = loadTestFile(t, "test/json/message-events_search_200-1.json")
msgEventsPage2.json = loadTestFile(t, "test/json/message-events_search_200-2.json")
msgEventsPage3.json = loadTestFile(t, "test/json/message-events_search_200-3.json")
// Each test can return multiple pages of results
for idx, outer := range []struct {
input *sp.EventsPage
results []EventsPageResult
}{
{&sp.EventsPage{Params: map[string]string{"from": "1970-01-01T00:00"}},
[]EventsPageResult{EventsPageResult{
nil, // filled out below in the `if idx == 0` block
200, "{}", nil},
},
},
{&sp.EventsPage{Params: map[string]string{"from": "1970-01-01T00:00"}},
[]EventsPageResult{EventsPageResult{
errors.New("parsing api response: unexpected end of JSON input"),
200, "{", nil},
},
},
{&sp.EventsPage{Params: map[string]string{"from": "1970-01-01T00:00", "per_page": "1"}},
[]EventsPageResult{msgEventsPage1, msgEventsPage2Syntax, msgEventsPage3, msgEventsPage4},
},
{&sp.EventsPage{Params: map[string]string{"from": "1970-01-01T00:00"}},
[]EventsPageResult{msgEventsPageAll},
},
{&sp.EventsPage{Params: map[string]string{"from": "1970-01-01T00:00", "per_page": "1"}},
[]EventsPageResult{msgEventsPage1, msgEventsPage2, msgEventsPage3, msgEventsPage4},
},
} {
var page *sp.EventsPage
for j, test := range outer.results {
// Set up a new test in our inner loop since re-registering a handler will panic,
// and the content we're returning needs to vary.
testSetup(t)
mockRestResponseBuilderFormat(t, "GET", test.status, sp.MessageEventsPathFormat, test.json)
// Trigger url parse failure
if idx == 0 {
testClient.Config.BaseUrl += "/%xx"
test.err = errors.Errorf("parsing url: parse %q: %s",
testClient.Config.BaseUrl+
fmt.Sprintf(sp.MessageEventsPathFormat, testClient.Config.ApiVersion),
`invalid URL escape "%xx"`)
}
if page == nil {
_, err = testClient.MessageEventsSearch(outer.input)
page = outer.input
} else {
page, _, err = page.Next()
}
if err == nil && test.err != nil || err != nil && test.err == nil {
t.Errorf("MessageEventsSearch[%d.%d] => err %#v want %#v", idx, j, err, test.err)
} else if err != nil && err.Error() != test.err.Error() {
t.Errorf("MessageEventsSearch[%d.%d] => err %#v want %#v", idx, j, err, test.err)
t.Errorf("%s", pretty.Compare(err.Error(), test.err.Error()))
} else if test.out != nil {
if page != nil {
test.out.Client = page.Client // samesies
if !reflect.DeepEqual(page, test.out) {
t.Errorf("MessageEventsSearch[%d.%d] => template got/want:\n%v\n%v", idx, j, page, test.out)
}
} else {
if j+1 != len(outer.results) { // nil `page` is ok if we're on the last page
t.Errorf("MessageEventsSearch[%d.%d] => page %d is nil!", idx, j, len(outer.results))
}
}
}
testTeardown()
}
}
}
func TestEventSamples(t *testing.T) {
for idx, test := range []struct {
in []string
err error
status int
json string
out *events.Events
}{
{nil, nil, 200, `{}`, nil},
{nil, nil, 200, `{}`, nil},
{[]string{"open"}, errors.New("parsing api response: unexpected end of JSON input"),
200, `{`, nil},
{[]string{"ignore"}, errors.New("Invalid event type [ignore]"), 200, `{}`, nil},
{[]string{"open"}, nil, 200, `{}`, nil},
} {
testSetup(t)
defer testTeardown()
mockRestResponseBuilderFormat(t, "GET", test.status, sp.MessageEventsSamplesPathFormat, test.json)
if idx == 0 {
testClient.Config.BaseUrl += "/%xx"
test.err = errors.Errorf("parsing url: parse %q: %s",
testClient.Config.BaseUrl+
fmt.Sprintf(sp.MessageEventsSamplesPathFormat, testClient.Config.ApiVersion),
`invalid URL escape "%xx"`)
}
events, _, err := testClient.EventSamples(test.in)
if err == nil && test.err != nil || err != nil && test.err == nil {
t.Errorf("EventSamples[%d] => err %#v want %#v", idx, err, test.err)
} else if err != nil && err.Error() != test.err.Error() {
t.Errorf("EventSamples[%d] => err %#v want %#v", idx, err, test.err)
t.Errorf("%s", pretty.Compare(err.Error(), test.err.Error()))
} else if test.out != nil {
if !reflect.DeepEqual(events, test.out) {
t.Errorf("EventSamples[%d] => events got/want:\n%#v\n%#v", idx, events, test.out)
}
}
}
}