In our code, we delete a message from a sqs queue and get the deletResponse
.
String deleteResponse = sqsClient.deleteMessage(simBridge2ESBUrl, message.getReceiptHandle()).toString();
The message is deleted after this call but deleteResponse
is always {}
. So we checked the source code and found DeleteMessageResult::toString
function does only return {}
.
Below is the AWS source code. The toString()
and hashCode()
functions seem to be weird. Is there error in the source code or am I doing it wrong? Thanks.
/*
* Copyright 2010-2016 Amazon.com, Inc. or its affiliates. All Rights
* Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file is distributed
* on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
package com.amazonaws.services.sqs.model;
import java.io.Serializable;
/**
*
*/
public class DeleteMessageResult implements Serializable, Cloneable {
/**
* Returns a string representation of this object; useful for testing and
* debugging.
*
* @return A string representation of this object.
*
* @see java.lang.Object#toString()
*/
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("{");
sb.append("}");
return sb.toString();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (obj instanceof DeleteMessageResult == false)
return false;
DeleteMessageResult other = (DeleteMessageResult) obj;
return true;
}
@Override
public int hashCode() {
final int prime = 31;
int hashCode = 1;
return hashCode;
}
@Override
public DeleteMessageResult clone() {
try {
return (DeleteMessageResult) super.clone();
} catch (CloneNotSupportedException e) {
throw new IllegalStateException(
"Got a CloneNotSupportedException from Object.clone() "
+ "even though we're Cloneable!", e);
}
}
}
From programming perspective
toString()
is written correctly. Think about what this function does:Since
DeleteMessageResult
class has no properties, there is nothing to return. Same applies tohashCode()
. Two objects ofDeleteMessageResult
are always identical, so they have the same hash every time.That being said, I do think that
DeleteMessageResult
should containResposeMetadata
with uniqueRequestId
as show in API reference:So, yes, this class could (probably, should) be patched to fully back the SQS API.