SNS: delete_endpoint() is now an idempotent operation, just like AWS (#7524)
This commit is contained in:
parent
e4ec1a40ed
commit
1fc22000d9
@ -715,7 +715,7 @@ class SNSBackend(BaseBackend):
|
|||||||
try:
|
try:
|
||||||
del self.platform_endpoints[arn]
|
del self.platform_endpoints[arn]
|
||||||
except KeyError:
|
except KeyError:
|
||||||
raise SNSNotFoundError(f"Endpoint with arn {arn} not found")
|
pass # idempotent operation
|
||||||
|
|
||||||
def get_subscription_attributes(self, arn: str) -> Dict[str, Any]:
|
def get_subscription_attributes(self, arn: str) -> Dict[str, Any]:
|
||||||
subscription = self.subscriptions.get(arn)
|
subscription = self.subscriptions.get(arn)
|
||||||
|
@ -266,6 +266,13 @@ def test_get_list_endpoints_by_platform_application(api_key=None):
|
|||||||
assert len(endpoint_list) == 1
|
assert len(endpoint_list) == 1
|
||||||
assert endpoint_list[0]["Attributes"]["CustomUserData"] == "some data"
|
assert endpoint_list[0]["Attributes"]["CustomUserData"] == "some data"
|
||||||
assert endpoint_list[0]["EndpointArn"] == endpoint_arn
|
assert endpoint_list[0]["EndpointArn"] == endpoint_arn
|
||||||
|
|
||||||
|
resp = conn.delete_endpoint(EndpointArn=endpoint_arn)
|
||||||
|
assert resp["ResponseMetadata"]["HTTPStatusCode"] == 200
|
||||||
|
|
||||||
|
# Idempotent operation
|
||||||
|
resp = conn.delete_endpoint(EndpointArn=endpoint_arn)
|
||||||
|
assert resp["ResponseMetadata"]["HTTPStatusCode"] == 200
|
||||||
finally:
|
finally:
|
||||||
if application_arn is not None:
|
if application_arn is not None:
|
||||||
conn.delete_platform_application(PlatformApplicationArn=application_arn)
|
conn.delete_platform_application(PlatformApplicationArn=application_arn)
|
||||||
|
Loading…
Reference in New Issue
Block a user