MotoAPI - do not blow up on uninitialized objects (#5384)
This commit is contained in:
parent
af5d3f9e30
commit
cd08144d93
@ -54,7 +54,7 @@ class MotoAPIResponse(BaseResponse):
|
||||
if not attr.startswith("_"):
|
||||
try:
|
||||
json.dumps(getattr(instance, attr))
|
||||
except TypeError:
|
||||
except (TypeError, AttributeError):
|
||||
pass
|
||||
else:
|
||||
inst_result[attr] = getattr(instance, attr)
|
||||
|
@ -2,7 +2,11 @@ import sure # noqa # pylint: disable=unused-import
|
||||
import requests
|
||||
|
||||
import boto3
|
||||
from moto import mock_sqs, settings
|
||||
import json
|
||||
import pytest
|
||||
from botocore.exceptions import ClientError
|
||||
from moto import mock_autoscaling, mock_sqs, settings
|
||||
from unittest import SkipTest
|
||||
|
||||
base_url = (
|
||||
"http://localhost:5000"
|
||||
@ -33,3 +37,39 @@ def test_data_api():
|
||||
len(queues).should.equal(1)
|
||||
queue = queues[0]
|
||||
queue["name"].should.equal("queue1")
|
||||
|
||||
|
||||
@mock_autoscaling
|
||||
def test_creation_error__data_api_still_returns_thing():
|
||||
if settings.TEST_SERVER_MODE:
|
||||
raise SkipTest("No point in testing this behaves the same in ServerMode")
|
||||
# Timeline:
|
||||
#
|
||||
# When calling BaseModel.__new__, the created instance (of type FakeAutoScalingGroup) is stored in `model_data`
|
||||
# We then try and initialize the instance by calling __init__
|
||||
#
|
||||
# Initialization fails in this test, but: by then, the instance is already registered
|
||||
# This test ensures that we can still print/__repr__ the uninitialized instance, despite the fact that no attributes have been set
|
||||
client = boto3.client("autoscaling", region_name="us-east-1")
|
||||
# Creating this ASG fails, because it doesn't specify a Region/VPC
|
||||
with pytest.raises(ClientError):
|
||||
client.create_auto_scaling_group(
|
||||
AutoScalingGroupName="test_asg",
|
||||
LaunchTemplate={
|
||||
"LaunchTemplateName": "test_launch_template",
|
||||
"Version": "1",
|
||||
},
|
||||
MinSize=0,
|
||||
MaxSize=20,
|
||||
)
|
||||
|
||||
from moto.moto_api._internal.urls import response_instance
|
||||
|
||||
_, _, x = response_instance.model_data(None, None, None)
|
||||
|
||||
as_objects = json.loads(x)["autoscaling"]
|
||||
as_objects.should.have.key("FakeAutoScalingGroup")
|
||||
assert len(as_objects["FakeAutoScalingGroup"]) >= 1
|
||||
|
||||
names = [obj["name"] for obj in as_objects["FakeAutoScalingGroup"]]
|
||||
names.should.contain("test_asg")
|
||||
|
Loading…
Reference in New Issue
Block a user