-
Notifications
You must be signed in to change notification settings - Fork 19
/
Copy pathaggregated_feed_test.go
93 lines (79 loc) · 3.64 KB
/
aggregated_feed_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
package stream_test
import (
"context"
"fmt"
"net/http"
"testing"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
stream "github.com/GetStream/stream-go2/v8"
)
func TestAggregatedFeedGetActivities(t *testing.T) {
ctx := context.Background()
client, requester := newClient(t)
aggregated, _ := newAggregatedFeedWithUserID(client, "123")
testCases := []struct {
opts []stream.GetActivitiesOption
url string
enrichedURL string
}{
{
url: "https://api.stream-io-api.com/api/v1.0/feed/aggregated/123/?api_key=key",
enrichedURL: "https://api.stream-io-api.com/api/v1.0/enrich/feed/aggregated/123/?api_key=key",
},
{
opts: []stream.GetActivitiesOption{stream.WithActivitiesLimit(42)},
url: "https://api.stream-io-api.com/api/v1.0/feed/aggregated/123/?api_key=key&limit=42",
enrichedURL: "https://api.stream-io-api.com/api/v1.0/enrich/feed/aggregated/123/?api_key=key&limit=42",
},
{
opts: []stream.GetActivitiesOption{stream.WithActivitiesLimit(42), stream.WithActivitiesOffset(11), stream.WithActivitiesIDGT("aabbcc")},
url: "https://api.stream-io-api.com/api/v1.0/feed/aggregated/123/?api_key=key&id_gt=aabbcc&limit=42&offset=11",
enrichedURL: "https://api.stream-io-api.com/api/v1.0/enrich/feed/aggregated/123/?api_key=key&id_gt=aabbcc&limit=42&offset=11",
},
}
for _, tc := range testCases {
_, err := aggregated.GetActivities(ctx, tc.opts...)
assert.NoError(t, err)
testRequest(t, requester.req, http.MethodGet, tc.url, "")
_, err = aggregated.GetActivitiesWithRanking(ctx, "popularity", tc.opts...)
testRequest(t, requester.req, http.MethodGet, fmt.Sprintf("%s&ranking=popularity", tc.url), "")
assert.NoError(t, err)
_, err = aggregated.GetEnrichedActivities(ctx, tc.opts...)
assert.NoError(t, err)
testRequest(t, requester.req, http.MethodGet, tc.enrichedURL, "")
_, err = aggregated.GetEnrichedActivitiesWithRanking(ctx, "popularity", tc.opts...)
testRequest(t, requester.req, http.MethodGet, fmt.Sprintf("%s&ranking=popularity", tc.enrichedURL), "")
assert.NoError(t, err)
}
}
func TestAggregatedFeedGetNextPageActivities(t *testing.T) {
ctx := context.Background()
client, requester := newClient(t)
aggregated, _ := newAggregatedFeedWithUserID(client, "123")
requester.resp = `{"next":"/api/v1.0/feed/aggregated/123/?id_lt=78c1a709-aff2-11e7-b3a7-a45e60be7d3b&limit=25"}`
resp, err := aggregated.GetActivities(ctx)
require.NoError(t, err)
_, err = aggregated.GetNextPageActivities(ctx, resp)
testRequest(t, requester.req, http.MethodGet, "https://api.stream-io-api.com/api/v1.0/feed/aggregated/123/?api_key=key&id_lt=78c1a709-aff2-11e7-b3a7-a45e60be7d3b&limit=25", "")
require.NoError(t, err)
requester.resp = `{"next":"/api/v1.0/enrich/feed/aggregated/123/?id_lt=78c1a709-aff2-11e7-b3a7-a45e60be7d3b&limit=25"}`
enrichedResp, err := aggregated.GetEnrichedActivities(ctx)
require.NoError(t, err)
_, err = aggregated.GetNextPageEnrichedActivities(ctx, enrichedResp)
testRequest(t, requester.req, http.MethodGet, "https://api.stream-io-api.com/api/v1.0/enrich/feed/aggregated/123/?api_key=key&id_lt=78c1a709-aff2-11e7-b3a7-a45e60be7d3b&limit=25", "")
require.NoError(t, err)
requester.resp = `{"next":123}`
_, err = aggregated.GetActivities(ctx)
require.Error(t, err)
requester.resp = `{"next":"123"}`
resp, err = aggregated.GetActivities(ctx)
require.NoError(t, err)
_, err = aggregated.GetNextPageActivities(ctx, resp)
require.Error(t, err)
requester.resp = `{"next":"?q=a%"}`
resp, err = aggregated.GetActivities(ctx)
require.NoError(t, err)
_, err = aggregated.GetNextPageActivities(ctx, resp)
require.Error(t, err)
}