summaryrefslogtreecommitdiffstats
path: root/vendor/github.com/goamz/goamz/sqs/sqs_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/github.com/goamz/goamz/sqs/sqs_test.go')
-rw-r--r--vendor/github.com/goamz/goamz/sqs/sqs_test.go414
1 files changed, 0 insertions, 414 deletions
diff --git a/vendor/github.com/goamz/goamz/sqs/sqs_test.go b/vendor/github.com/goamz/goamz/sqs/sqs_test.go
deleted file mode 100644
index a06433535..000000000
--- a/vendor/github.com/goamz/goamz/sqs/sqs_test.go
+++ /dev/null
@@ -1,414 +0,0 @@
-package sqs
-
-import (
- "crypto/md5"
- "encoding/binary"
- "fmt"
- "hash"
-
- "github.com/goamz/goamz/aws"
- . "gopkg.in/check.v1"
-)
-
-var _ = Suite(&S{})
-
-type S struct {
- HTTPSuite
- sqs *SQS
-}
-
-func (s *S) SetUpSuite(c *C) {
- s.HTTPSuite.SetUpSuite(c)
- auth := aws.Auth{AccessKey: "abc", SecretKey: "123"}
- s.sqs = New(auth, aws.Region{SQSEndpoint: testServer.URL})
-}
-
-func (s *S) TestCreateQueue(c *C) {
- testServer.PrepareResponse(200, nil, TestCreateQueueXmlOK)
-
- resp, err := s.sqs.CreateQueue("testQueue")
- req := testServer.WaitRequest()
-
- c.Assert(req.Method, Equals, "GET")
- c.Assert(req.URL.Path, Equals, "/")
- c.Assert(req.Header["Date"], Not(Equals), "")
- fmt.Printf("%+v\n", req)
- c.Assert(req.Form["Action"], DeepEquals, []string{"CreateQueue"})
- c.Assert(req.Form["Attribute.1.Name"], DeepEquals, []string{"VisibilityTimeout"})
- c.Assert(req.Form["Attribute.1.Value"], DeepEquals, []string{"30"})
-
- c.Assert(resp.Url, Equals, "http://sqs.us-east-1.amazonaws.com/123456789012/testQueue")
- c.Assert(err, IsNil)
-}
-
-func (s *S) TestCreateQueueWithTimeout(c *C) {
- testServer.PrepareResponse(200, nil, TestCreateQueueXmlOK)
-
- s.sqs.CreateQueueWithTimeout("testQueue", 180)
- req := testServer.WaitRequest()
-
- // TestCreateQueue() tests the core functionality, just check the timeout in this test
- c.Assert(req.Form["Attribute.1.Name"], DeepEquals, []string{"VisibilityTimeout"})
- c.Assert(req.Form["Attribute.1.Value"], DeepEquals, []string{"180"})
-}
-
-func (s *S) TestCreateQueueWithAttributes(c *C) {
- testServer.PrepareResponse(200, nil, TestCreateQueueXmlOK)
-
- s.sqs.CreateQueueWithAttributes("testQueue", map[string]string{
- "ReceiveMessageWaitTimeSeconds": "20",
- "VisibilityTimeout": "240",
- })
- req := testServer.WaitRequest()
-
- // TestCreateQueue() tests the core functionality, just check the timeout in this test
- var receiveMessageWaitSet bool
- var visibilityTimeoutSet bool
-
- for i := 1; i <= 2; i++ {
- prefix := fmt.Sprintf("Attribute.%d.", i)
- attr := req.FormValue(prefix + "Name")
- value := req.FormValue(prefix + "Value")
- switch attr {
- case "ReceiveMessageWaitTimeSeconds":
- c.Assert(value, DeepEquals, "20")
- receiveMessageWaitSet = true
- case "VisibilityTimeout":
- c.Assert(value, DeepEquals, "240")
- visibilityTimeoutSet = true
- }
- }
- c.Assert(receiveMessageWaitSet, Equals, true)
- c.Assert(visibilityTimeoutSet, Equals, true)
-}
-
-func (s *S) TestListQueues(c *C) {
- testServer.PrepareResponse(200, nil, TestListQueuesXmlOK)
-
- resp, err := s.sqs.ListQueues("")
- req := testServer.WaitRequest()
-
- c.Assert(req.Method, Equals, "GET")
- c.Assert(req.URL.Path, Equals, "/")
- c.Assert(req.Header["Date"], Not(Equals), "")
-
- c.Assert(len(resp.QueueUrl), Not(Equals), 0)
- c.Assert(resp.QueueUrl[0], Equals, "http://sqs.us-east-1.amazonaws.com/123456789012/testQueue")
- c.Assert(resp.ResponseMetadata.RequestId, Equals, "725275ae-0b9b-4762-b238-436d7c65a1ac")
- c.Assert(err, IsNil)
-}
-
-func (s *S) TestDeleteQueue(c *C) {
- testServer.PrepareResponse(200, nil, TestDeleteQueueXmlOK)
-
- q := &Queue{s.sqs, testServer.URL + "/123456789012/testQueue/"}
- resp, err := q.Delete()
- req := testServer.WaitRequest()
-
- c.Assert(req.Method, Equals, "GET")
- c.Assert(req.URL.Path, Equals, "/123456789012/testQueue/")
- c.Assert(req.Header["Date"], Not(Equals), "")
-
- c.Assert(resp.ResponseMetadata.RequestId, Equals, "6fde8d1e-52cd-4581-8cd9-c512f4c64223")
- c.Assert(err, IsNil)
-}
-
-func (s *S) TestPurgeQueue(c *C) {
- testServer.PrepareResponse(200, nil, TestPurgeQueueXmlOK)
-
- q := &Queue{s.sqs, testServer.URL + "/123456789012/testQueue/"}
- resp, err := q.Purge()
- req := testServer.WaitRequest()
-
- c.Assert(req.Method, Equals, "GET")
- c.Assert(req.URL.Path, Equals, "/123456789012/testQueue/")
- c.Assert(req.Header["Date"], Not(Equals), "")
-
- c.Assert(resp.ResponseMetadata.RequestId, Equals, "6fde8d1e-52cd-4581-8cd9-c512f4c64223")
- c.Assert(err, IsNil)
-}
-
-func (s *S) TestSendMessage(c *C) {
- testServer.PrepareResponse(200, nil, TestSendMessageXmlOK)
-
- q := &Queue{s.sqs, testServer.URL + "/123456789012/testQueue/"}
- resp, err := q.SendMessage("This is a test message")
- req := testServer.WaitRequest()
-
- c.Assert(req.Method, Equals, "GET")
- c.Assert(req.URL.Path, Equals, "/123456789012/testQueue/")
- c.Assert(req.Header["Date"], Not(Equals), "")
-
- msg := "This is a test message"
- var h hash.Hash = md5.New()
- h.Write([]byte(msg))
- c.Assert(resp.MD5, Equals, fmt.Sprintf("%x", h.Sum(nil)))
- c.Assert(resp.Id, Equals, "5fea7756-0ea4-451a-a703-a558b933e274")
- c.Assert(err, IsNil)
-}
-
-func (s *S) TestSendMessageRelativePath(c *C) {
- testServer.PrepareResponse(200, nil, TestSendMessageXmlOK)
-
- q := &Queue{s.sqs, "/123456789012/testQueue/"}
- resp, err := q.SendMessage("This is a test message")
- req := testServer.WaitRequest()
-
- c.Assert(req.Method, Equals, "GET")
- c.Assert(req.URL.Path, Equals, "/123456789012/testQueue/")
- c.Assert(req.Header["Date"], Not(Equals), "")
-
- msg := "This is a test message"
- var h hash.Hash = md5.New()
- h.Write([]byte(msg))
- c.Assert(resp.MD5, Equals, fmt.Sprintf("%x", h.Sum(nil)))
- c.Assert(resp.Id, Equals, "5fea7756-0ea4-451a-a703-a558b933e274")
- c.Assert(err, IsNil)
-}
-
-func encodeMessageAttribute(str string) []byte {
- bstr := []byte(str)
- bs := make([]byte, 4+len(bstr))
- binary.BigEndian.PutUint32(bs, uint32(len(bstr)))
- copy(bs[4:len(bs)], bstr)
- return bs
-}
-
-func (s *S) TestSendMessageWithAttributes(c *C) {
- testServer.PrepareResponse(200, nil, TestSendMessageXmlOK)
-
- q := &Queue{s.sqs, testServer.URL + "/123456789012/testQueue/"}
- attrs := map[string]string{
- "test_attribute_name_1": "test_attribute_value_1",
- }
- resp, err := q.SendMessageWithAttributes("This is a test message", attrs)
- req := testServer.WaitRequest()
-
- c.Assert(req.Method, Equals, "GET")
- c.Assert(req.URL.Path, Equals, "/123456789012/testQueue/")
- c.Assert(req.Header["Date"], Not(Equals), "")
-
- var attrsHash = md5.New()
- attrsHash.Write(encodeMessageAttribute("test_attribute_name_1"))
- attrsHash.Write(encodeMessageAttribute("String"))
- attrsHash.Write([]byte{1})
- attrsHash.Write(encodeMessageAttribute("test_attribute_value_1"))
- c.Assert(resp.MD5OfMessageAttributes, Equals, fmt.Sprintf("%x", attrsHash.Sum(nil)))
-
- msg := "This is a test message"
- var h hash.Hash = md5.New()
- h.Write([]byte(msg))
- c.Assert(resp.MD5, Equals, fmt.Sprintf("%x", h.Sum(nil)))
- c.Assert(resp.Id, Equals, "5fea7756-0ea4-451a-a703-a558b933e274")
- c.Assert(err, IsNil)
-}
-
-func (s *S) TestSendMessageBatch(c *C) {
- testServer.PrepareResponse(200, nil, TestSendMessageBatchXmlOk)
-
- q := &Queue{s.sqs, testServer.URL + "/123456789012/testQueue/"}
-
- msgList := []string{"test message body 1", "test message body 2"}
- resp, err := q.SendMessageBatchString(msgList)
- req := testServer.WaitRequest()
-
- c.Assert(req.Method, Equals, "GET")
- c.Assert(req.URL.Path, Equals, "/123456789012/testQueue/")
- c.Assert(req.Header["Date"], Not(Equals), "")
-
- for idx, msg := range msgList {
- var h hash.Hash = md5.New()
- h.Write([]byte(msg))
- c.Assert(resp.SendMessageBatchResult[idx].MD5OfMessageBody, Equals, fmt.Sprintf("%x", h.Sum(nil)))
- c.Assert(err, IsNil)
- }
-}
-
-func (s *S) TestDeleteMessageBatch(c *C) {
- testServer.PrepareResponse(200, nil, TestDeleteMessageBatchXmlOK)
-
- q := &Queue{s.sqs, testServer.URL + "/123456789012/testQueue/"}
-
- msgList := []Message{*(&Message{ReceiptHandle: "gfk0T0R0waama4fVFffkjPQrrvzMrOg0fTFk2LxT33EuB8wR0ZCFgKWyXGWFoqqpCIiprQUEhir%2F5LeGPpYTLzjqLQxyQYaQALeSNHb0us3uE84uujxpBhsDkZUQkjFFkNqBXn48xlMcVhTcI3YLH%2Bd%2BIqetIOHgBCZAPx6r%2B09dWaBXei6nbK5Ygih21DCDdAwFV68Jo8DXhb3ErEfoDqx7vyvC5nCpdwqv%2BJhU%2FTNGjNN8t51v5c%2FAXvQsAzyZVNapxUrHIt4NxRhKJ72uICcxruyE8eRXlxIVNgeNP8ZEDcw7zZU1Zw%3D%3D"}),
- *(&Message{ReceiptHandle: "gfk0T0R0waama4fVFffkjKzmhMCymjQvfTFk2LxT33G4ms5subrE0deLKWSscPU1oD3J9zgeS4PQQ3U30qOumIE6AdAv3w%2F%2Fa1IXW6AqaWhGsEPaLm3Vf6IiWqdM8u5imB%2BNTwj3tQRzOWdTOePjOjPcTpRxBtXix%2BEvwJOZUma9wabv%2BSw6ZHjwmNcVDx8dZXJhVp16Bksiox%2FGrUvrVTCJRTWTLc59oHLLF8sEkKzRmGNzTDGTiV%2BYjHfQj60FD3rVaXmzTsoNxRhKJ72uIHVMGVQiAGgB%2BqAbSqfKHDQtVOmJJgkHug%3D%3D"}),
- }
-
- resp, err := q.DeleteMessageBatch(msgList)
- c.Assert(err, IsNil)
- req := testServer.WaitRequest()
-
- c.Assert(req.Method, Equals, "GET")
- c.Assert(req.URL.Path, Equals, "/123456789012/testQueue/")
- c.Assert(req.Header["Date"], Not(Equals), "")
-
- for idx, _ := range msgList {
- c.Assert(resp.DeleteMessageBatchResult[idx].Id, Equals, fmt.Sprintf("msg%d", idx+1))
- }
-}
-
-func (s *S) TestDeleteMessageUsingReceiptHandle(c *C) {
- testServer.PrepareResponse(200, nil, TestDeleteMessageUsingReceiptXmlOK)
-
- q := &Queue{s.sqs, testServer.URL + "/123456789012/testQueue/"}
-
- msg := &Message{ReceiptHandle: "gfk0T0R0waama4fVFffkjRQrrvzMrOg0fTFk2LxT33EuB8wR0ZCFgKWyXGWFoqqpCIiprQUEhir%2F5LeGPpYTLzjqLQxyQYaQALeSNHb0us3uE84uujxpBhsDkZUQkjFFkNqBXn48xlMcVhTcI3YLH%2Bd%2BIqetIOHgBCZAPx6r%2B09dWaBXei6nbK5Ygih21DCDdAwFV68Jo8DXhb3ErEfoDqx7vyvC5nCpdwqv%2BJhU%2FTNGjNN8t51v5c%2FAXvQsAzyZVNapxUrHIt4NxRhKJ72uICcxruyE8eRXlxIVNgeNP8ZEDcw7zZU1Zw%3D%3D"}
-
- resp, err := q.DeleteMessageUsingReceiptHandle(msg.ReceiptHandle)
- c.Assert(err, IsNil)
- req := testServer.WaitRequest()
-
- c.Assert(req.Method, Equals, "GET")
- c.Assert(req.URL.Path, Equals, "/123456789012/testQueue/")
- c.Assert(req.Header["Date"], Not(Equals), "")
-
- c.Assert(resp.ResponseMetadata.RequestId, Equals, "d6d86b7a-74d1-4439-b43f-196a1e29cd85")
-}
-
-func (s *S) TestReceiveMessage(c *C) {
- testServer.PrepareResponse(200, nil, TestReceiveMessageXmlOK)
-
- q := &Queue{s.sqs, testServer.URL + "/123456789012/testQueue/"}
- resp, err := q.ReceiveMessage(5)
- req := testServer.WaitRequest()
-
- c.Assert(req.Method, Equals, "GET")
- c.Assert(req.URL.Path, Equals, "/123456789012/testQueue/")
- c.Assert(req.Header["Date"], Not(Equals), "")
-
- c.Assert(len(resp.Messages), Not(Equals), 0)
- c.Assert(resp.Messages[0].MessageId, Equals, "5fea7756-0ea4-451a-a703-a558b933e274")
- c.Assert(resp.Messages[0].MD5OfBody, Equals, "fafb00f5732ab283681e124bf8747ed1")
- c.Assert(resp.Messages[0].ReceiptHandle, Equals, "MbZj6wDWli+JvwwJaBV+3dcjk2YW2vA3+STFFljTM8tJJg6HRG6PYSasuWXPJB+CwLj1FjgXUv1uSj1gUPAWV66FU/WeR4mq2OKpEGYWbnLmpRCJVAyeMjeU5ZBdtcQ+QEauMZc8ZRv37sIW2iJKq3M9MFx1YvV11A2x/KSbkJ0=")
- c.Assert(resp.Messages[0].Body, Equals, "This is a test message")
-
- c.Assert(len(resp.Messages[0].Attribute), Not(Equals), 0)
-
- expectedAttributeResults := []struct {
- Name string
- Value string
- }{
- {Name: "SenderId", Value: "195004372649"},
- {Name: "SentTimestamp", Value: "1238099229000"},
- {Name: "ApproximateReceiveCount", Value: "5"},
- {Name: "ApproximateFirstReceiveTimestamp", Value: "1250700979248"},
- }
-
- for i, expected := range expectedAttributeResults {
- c.Assert(resp.Messages[0].Attribute[i].Name, Equals, expected.Name)
- c.Assert(resp.Messages[0].Attribute[i].Value, Equals, expected.Value)
- }
-
- c.Assert(len(resp.Messages[0].MessageAttribute), Not(Equals), 0)
-
- expectedMessageAttributeResults := []struct {
- Name string
- Value struct {
- DataType string
- BinaryValue []byte
- StringValue string
-
- // Not yet implemented (Reserved for future use)
- BinaryListValues [][]byte
- StringListValues []string
- }
- }{
- {
- Name: "CustomAttribute",
- Value: struct {
- DataType string
- BinaryValue []byte
- StringValue string
-
- // Not yet implemented (Reserved for future use)
- BinaryListValues [][]byte
- StringListValues []string
- }{
- DataType: "String",
- StringValue: "Testing, testing, 1, 2, 3",
- },
- },
- {
- Name: "BinaryCustomAttribute",
- Value: struct {
- DataType string
- BinaryValue []byte
- StringValue string
-
- // Not yet implemented (Reserved for future use)
- BinaryListValues [][]byte
- StringListValues []string
- }{
- DataType: "Binary",
- BinaryValue: []byte("iVBORw0KGgoAAAANSUhEUgAAABIAAAASCAYAAABWzo5XAAABA0lEQVQ4T72UrQ4CMRCEewhyiiBPopBgcfAUSIICB88CDhRB8hTgsCBRyJMEdUFwZJpMs/3LHQlhVdPufJ1ut03UjyKJcR5zVc4umbW87eeqvVFBjTdJwP54D+4xGXVUCGiBxoOsJOCd9IKgRnnV8wAezrnRmwGcpKtCJ8UgJBNWLFNzVAOimyqIhElXGkQ3LmQ6fKrdqaW1cixhdKVBcEOBLEwViBugVv8B1elVuLYcoTea624drcl5LW4KTRsFhQpLtVzzQKGCh2DuHI8FvdVH7vGQKEPerHRjgegKMESsXgAgWBtu5D1a9BQWCXSrzx9BvjPPkRQR6IJcQNTRV/cvkj93DqUTWzVDIQAAAABJRU5ErkJggg=="),
- },
- },
- }
-
- for i, expected := range expectedMessageAttributeResults {
- c.Assert(resp.Messages[0].MessageAttribute[i].Name, Equals, expected.Name)
- c.Assert(resp.Messages[0].MessageAttribute[i].Value.DataType, Equals, expected.Value.DataType)
- c.Assert(string(resp.Messages[0].MessageAttribute[i].Value.BinaryValue), Equals, string(expected.Value.BinaryValue))
- c.Assert(resp.Messages[0].MessageAttribute[i].Value.StringValue, Equals, expected.Value.StringValue)
- }
-
- c.Assert(err, IsNil)
-}
-
-func (s *S) TestChangeMessageVisibility(c *C) {
- testServer.PrepareResponse(200, nil, TestReceiveMessageXmlOK)
-
- q := &Queue{s.sqs, testServer.URL + "/123456789012/testQueue/"}
-
- resp1, err := q.ReceiveMessage(1)
- req := testServer.WaitRequest()
-
- testServer.PrepareResponse(200, nil, TestChangeMessageVisibilityXmlOK)
-
- resp, err := q.ChangeMessageVisibility(&resp1.Messages[0], 50)
- req = testServer.WaitRequest()
-
- c.Assert(req.Method, Equals, "GET")
- c.Assert(req.URL.Path, Equals, "/123456789012/testQueue/")
- c.Assert(req.Header["Date"], Not(Equals), "")
-
- c.Assert(resp.ResponseMetadata.RequestId, Equals, "6a7a282a-d013-4a59-aba9-335b0fa48bed")
- c.Assert(err, IsNil)
-}
-
-func (s *S) TestGetQueueAttributes(c *C) {
- testServer.PrepareResponse(200, nil, TestGetQueueAttributesXmlOK)
-
- q := &Queue{s.sqs, testServer.URL + "/123456789012/testQueue/"}
-
- resp, err := q.GetQueueAttributes("All")
- req := testServer.WaitRequest()
-
- c.Assert(req.Method, Equals, "GET")
- c.Assert(req.URL.Path, Equals, "/123456789012/testQueue/")
-
- c.Assert(resp.ResponseMetadata.RequestId, Equals, "1ea71be5-b5a2-4f9d-b85a-945d8d08cd0b")
-
- c.Assert(len(resp.Attributes), Equals, 9)
-
- expectedResults := []struct {
- Name string
- Value string
- }{
- {Name: "ReceiveMessageWaitTimeSeconds", Value: "2"},
- {Name: "VisibilityTimeout", Value: "30"},
- {Name: "ApproximateNumberOfMessages", Value: "0"},
- {Name: "ApproximateNumberOfMessagesNotVisible", Value: "0"},
- {Name: "CreatedTimestamp", Value: "1286771522"},
- {Name: "LastModifiedTimestamp", Value: "1286771522"},
- {Name: "QueueArn", Value: "arn:aws:sqs:us-east-1:123456789012:qfoo"},
- {Name: "MaximumMessageSize", Value: "8192"},
- {Name: "MessageRetentionPeriod", Value: "345600"},
- }
-
- for i, expected := range expectedResults {
- c.Assert(resp.Attributes[i].Name, Equals, expected.Name)
- c.Assert(resp.Attributes[i].Value, Equals, expected.Value)
- }
-
- c.Assert(err, IsNil)
-}