File: kinesis_test.go

package info (click to toggle)
golang-github-docker-goamz 0.0~git20160206.0.f0a21f5-3
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 1,580 kB
  • sloc: makefile: 66
file content (106 lines) | stat: -rw-r--r-- 3,247 bytes parent folder | download
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
//
// goamz - Go packages to interact with the Amazon Web Services.
//
//   https://wiki.ubuntu.com/goamz
//
// Written by Tim Bart <tim@fewagainstmany.com>
package kinesis_test

import (
	"encoding/base64"
	"encoding/json"
	"fmt"
	"github.com/docker/goamz/kinesis"
	"path/filepath"
	"reflect"
	"runtime"
	"testing"
)

// assert fails the test if the condition is false.
func assert(tb testing.TB, condition bool, msg string, v ...interface{}) {
	if !condition {
		_, file, line, _ := runtime.Caller(1)
		fmt.Printf("\033[31m%s:%d: "+msg+"\033[39m\n\n", append([]interface{}{filepath.Base(file), line}, v...)...)
		tb.FailNow()
	}
}

// ok fails the test if an err is not nil.
func ok(tb testing.TB, err error) {
	if err != nil {
		_, file, line, _ := runtime.Caller(1)
		fmt.Printf("\033[31m%s:%d: unexpected error: %s\033[39m\n\n", filepath.Base(file), line, err.Error())
		tb.FailNow()
	}
}

// equals fails the test if exp is not equal to act.
func equals(tb testing.TB, exp, act interface{}) {
	if !reflect.DeepEqual(exp, act) {
		_, file, line, _ := runtime.Caller(1)
		fmt.Printf("\033[31m%s:%d:\n\n\texp: %#v\n\n\tgot: %#v\033[39m\n\n", filepath.Base(file), line, exp, act)
		tb.FailNow()
	}
}

func TestDescribeStreamResponse(t *testing.T) {
	resp := &kinesis.DescribeStreamResponse{}
	err := json.Unmarshal([]byte(describeStream), resp)

	ok(t, err)
	equals(t, false, resp.StreamDescription.HasMoreShards)
	equals(t, 3, len(resp.StreamDescription.Shards))
	equals(t, "arn:aws:kinesis:us-east-1:052958737983:exampleStreamName", resp.StreamDescription.StreamARN)
	equals(t, "exampleStreamName", resp.StreamDescription.StreamName)
	equals(t, kinesis.StreamStatusActive, resp.StreamDescription.StreamStatus)
}

func TestGetRecordsResponse(t *testing.T) {
	resp := &kinesis.GetRecordsResponse{}
	err := json.Unmarshal([]byte(getRecords), resp)

	ok(t, err)
	equals(t, 1, len(resp.Records))
	equals(t, "XzxkYXRhPl8w", base64.StdEncoding.EncodeToString(resp.Records[0].Data))
	equals(t, "partitionKey", resp.Records[0].PartitionKey)
	equals(t, "21269319989652663814458848515492872193", resp.Records[0].SequenceNumber)
}

func TestGetShardIteratorResponse(t *testing.T) {
	resp := &kinesis.GetShardIteratorResponse{}
	err := json.Unmarshal([]byte(getShardIterator), resp)

	ok(t, err)
	equals(t, "AAAAAAAAAAETY", resp.ShardIterator[:13])
}

func TestListStreams(t *testing.T) {
	resp := &kinesis.ListStreamResponse{}
	err := json.Unmarshal([]byte(listStreams), resp)

	ok(t, err)
	equals(t, false, resp.HasMoreStreams)
	equals(t, 1, len(resp.StreamNames))
	equals(t, "exampleStreamName", resp.StreamNames[0])
}

func TestPutRecord(t *testing.T) {
	resp := &kinesis.PutRecordResponse{}
	err := json.Unmarshal([]byte(putRecord), resp)

	ok(t, err)
	equals(t, "21269319989653637946712965403778482177", resp.SequenceNumber)
	equals(t, "shardId-000000000001", resp.ShardId)
}

func TestPutRecords(t *testing.T) {
	resp := &kinesis.PutRecordsResponse{}
	err := json.Unmarshal([]byte(putRecords), resp)

	ok(t, err)
	equals(t, 0, resp.FailedRecordCount)
	equals(t, 1, len(resp.Records))
	equals(t, "49543463076548007577105092703039560359975228518395019266", resp.Records[0].SequenceNumber)
	equals(t, "shardId-000000000000", resp.Records[0].ShardId)
}