Skip to content

Commit f3c53b5

Browse files
ccbrownjasdel
authored andcommitted
service/sqs: Fix sqs batch send panic on failure (#239)
Fixes panic in verifySendMessageBatch if not all messages failed to send.
1 parent ad4b85d commit f3c53b5

File tree

2 files changed

+31
-4
lines changed

2 files changed

+31
-4
lines changed

service/sqs/checksums.go

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -50,10 +50,10 @@ func verifySendMessageBatch(r *request.Request) {
5050

5151
in := r.Params.(*SendMessageBatchInput)
5252
for _, entry := range in.Entries {
53-
e := entries[*entry.Id]
54-
err := checksumsMatch(entry.MessageBody, e.MD5OfMessageBody)
55-
if err != nil {
56-
ids = append(ids, *e.MessageId)
53+
if e, ok := entries[*entry.Id]; ok {
54+
if err := checksumsMatch(entry.MessageBody, e.MD5OfMessageBody); err != nil {
55+
ids = append(ids, *e.MessageId)
56+
}
5757
}
5858
}
5959
if len(ids) > 0 {

service/sqs/checksums_test.go

Lines changed: 27 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -212,6 +212,33 @@ func TestSendMessageBatchChecksum(t *testing.T) {
212212
}
213213
}
214214

215+
func TestSendMessageBatchChecksumFailed(t *testing.T) {
216+
req := svc.SendMessageBatchRequest(&sqs.SendMessageBatchInput{
217+
Entries: []sqs.SendMessageBatchRequestEntry{
218+
{Id: aws.String("1"), MessageBody: aws.String("test")},
219+
{Id: aws.String("2"), MessageBody: aws.String("test")},
220+
{Id: aws.String("3"), MessageBody: aws.String("test")},
221+
{Id: aws.String("4"), MessageBody: aws.String("test")},
222+
},
223+
})
224+
req.Handlers.Send.PushBack(func(r *request.Request) {
225+
body := ioutil.NopCloser(bytes.NewReader([]byte("")))
226+
r.HTTPResponse = &http.Response{StatusCode: 200, Body: body}
227+
r.Data = &sqs.SendMessageBatchOutput{
228+
Failed: []sqs.BatchResultErrorEntry{
229+
{Id: aws.String("1"), Code: aws.String("test"), Message: aws.String("test"), SenderFault: aws.Bool(false)},
230+
{Id: aws.String("2"), Code: aws.String("test"), Message: aws.String("test"), SenderFault: aws.Bool(false)},
231+
{Id: aws.String("3"), Code: aws.String("test"), Message: aws.String("test"), SenderFault: aws.Bool(false)},
232+
{Id: aws.String("4"), Code: aws.String("test"), Message: aws.String("test"), SenderFault: aws.Bool(false)},
233+
},
234+
}
235+
})
236+
_, err := req.Send()
237+
if err != nil {
238+
t.Errorf("expect no error, got %v", err)
239+
}
240+
}
241+
215242
func TestSendMessageBatchChecksumInvalid(t *testing.T) {
216243
req := svc.SendMessageBatchRequest(&sqs.SendMessageBatchInput{
217244
Entries: []sqs.SendMessageBatchRequestEntry{

0 commit comments

Comments
 (0)