This repository has been archived by the owner on Aug 1, 2023. It is now read-only.
/
linked_test.go
120 lines (95 loc) · 2.75 KB
/
linked_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
package pagination
import (
"fmt"
"net/http"
"reflect"
"testing"
"github.com/mitchellh/mapstructure"
"github.com/rackspace/gophercloud/testhelper"
)
// LinkedPager sample and test cases.
type LinkedPageResult struct {
LinkedPageBase
}
func (r LinkedPageResult) IsEmpty() (bool, error) {
is, err := ExtractLinkedInts(r)
if err != nil {
return true, nil
}
return len(is) == 0, nil
}
func ExtractLinkedInts(page Page) ([]int, error) {
var response struct {
Ints []int `mapstructure:"ints"`
}
err := mapstructure.Decode(page.(LinkedPageResult).Body, &response)
if err != nil {
return nil, err
}
return response.Ints, nil
}
func createLinked(t *testing.T) Pager {
testhelper.SetupHTTP()
testhelper.Mux.HandleFunc("/page1", func(w http.ResponseWriter, r *http.Request) {
w.Header().Add("Content-Type", "application/json")
fmt.Fprintf(w, `{ "ints": [1, 2, 3], "links": { "next": "%s/page2" } }`, testhelper.Server.URL)
})
testhelper.Mux.HandleFunc("/page2", func(w http.ResponseWriter, r *http.Request) {
w.Header().Add("Content-Type", "application/json")
fmt.Fprintf(w, `{ "ints": [4, 5, 6], "links": { "next": "%s/page3" } }`, testhelper.Server.URL)
})
testhelper.Mux.HandleFunc("/page3", func(w http.ResponseWriter, r *http.Request) {
w.Header().Add("Content-Type", "application/json")
fmt.Fprintf(w, `{ "ints": [7, 8, 9], "links": { "next": null } }`)
})
client := createClient()
createPage := func(r PageResult) Page {
return LinkedPageResult{LinkedPageBase{PageResult: r}}
}
return NewPager(client, testhelper.Server.URL+"/page1", createPage)
}
func TestEnumerateLinked(t *testing.T) {
pager := createLinked(t)
defer testhelper.TeardownHTTP()
callCount := 0
err := pager.EachPage(func(page Page) (bool, error) {
actual, err := ExtractLinkedInts(page)
if err != nil {
return false, err
}
t.Logf("Handler invoked with %v", actual)
var expected []int
switch callCount {
case 0:
expected = []int{1, 2, 3}
case 1:
expected = []int{4, 5, 6}
case 2:
expected = []int{7, 8, 9}
default:
t.Fatalf("Unexpected call count: %d", callCount)
return false, nil
}
if !reflect.DeepEqual(expected, actual) {
t.Errorf("Call %d: Expected %#v, but was %#v", callCount, expected, actual)
}
callCount++
return true, nil
})
if err != nil {
t.Errorf("Unexpected error for page iteration: %v", err)
}
if callCount != 3 {
t.Errorf("Expected 3 calls, but was %d", callCount)
}
}
func TestAllPagesLinked(t *testing.T) {
pager := createLinked(t)
defer testhelper.TeardownHTTP()
page, err := pager.AllPages()
testhelper.AssertNoErr(t, err)
expected := []int{1, 2, 3, 4, 5, 6, 7, 8, 9}
actual, err := ExtractLinkedInts(page)
testhelper.AssertNoErr(t, err)
testhelper.CheckDeepEquals(t, expected, actual)
}