Merge pull request #2624 from tirkarthi/fix-abc-warnings
Import ABC from collections.abc for Python 3.9 compatibility.
This commit is contained in:
commit
0f67a74d25
@ -1,5 +1,4 @@
|
|||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
import collections
|
|
||||||
import functools
|
import functools
|
||||||
import logging
|
import logging
|
||||||
import copy
|
import copy
|
||||||
@ -11,6 +10,7 @@ from moto.awslambda import models as lambda_models
|
|||||||
from moto.batch import models as batch_models
|
from moto.batch import models as batch_models
|
||||||
from moto.cloudwatch import models as cloudwatch_models
|
from moto.cloudwatch import models as cloudwatch_models
|
||||||
from moto.cognitoidentity import models as cognitoidentity_models
|
from moto.cognitoidentity import models as cognitoidentity_models
|
||||||
|
from moto.compat import collections_abc
|
||||||
from moto.datapipeline import models as datapipeline_models
|
from moto.datapipeline import models as datapipeline_models
|
||||||
from moto.dynamodb2 import models as dynamodb2_models
|
from moto.dynamodb2 import models as dynamodb2_models
|
||||||
from moto.ec2 import models as ec2_models
|
from moto.ec2 import models as ec2_models
|
||||||
@ -405,7 +405,7 @@ def parse_output(output_logical_id, output_json, resources_map):
|
|||||||
return output
|
return output
|
||||||
|
|
||||||
|
|
||||||
class ResourceMap(collections.Mapping):
|
class ResourceMap(collections_abc.Mapping):
|
||||||
"""
|
"""
|
||||||
This is a lazy loading map for resources. This allows us to create resources
|
This is a lazy loading map for resources. This allows us to create resources
|
||||||
without needing to create a full dependency tree. Upon creation, each
|
without needing to create a full dependency tree. Upon creation, each
|
||||||
@ -634,7 +634,7 @@ class ResourceMap(collections.Mapping):
|
|||||||
raise last_exception
|
raise last_exception
|
||||||
|
|
||||||
|
|
||||||
class OutputMap(collections.Mapping):
|
class OutputMap(collections_abc.Mapping):
|
||||||
def __init__(self, resources, template, stack_id):
|
def __init__(self, resources, template, stack_id):
|
||||||
self._template = template
|
self._template = template
|
||||||
self._stack_id = stack_id
|
self._stack_id = stack_id
|
||||||
|
@ -3,3 +3,8 @@ try:
|
|||||||
except ImportError:
|
except ImportError:
|
||||||
# python 2.6 or earlier, use backport
|
# python 2.6 or earlier, use backport
|
||||||
from ordereddict import OrderedDict # noqa
|
from ordereddict import OrderedDict # noqa
|
||||||
|
|
||||||
|
try:
|
||||||
|
import collections.abc as collections_abc # noqa
|
||||||
|
except ImportError:
|
||||||
|
import collections as collections_abc # noqa
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import collections
|
|
||||||
import six
|
import six
|
||||||
|
from moto.compat import collections_abc
|
||||||
from moto.core.utils import get_random_hex
|
from moto.core.utils import get_random_hex
|
||||||
|
|
||||||
|
|
||||||
@ -8,13 +8,13 @@ def get_random_pipeline_id():
|
|||||||
|
|
||||||
|
|
||||||
def remove_capitalization_of_dict_keys(obj):
|
def remove_capitalization_of_dict_keys(obj):
|
||||||
if isinstance(obj, collections.Mapping):
|
if isinstance(obj, collections_abc.Mapping):
|
||||||
result = obj.__class__()
|
result = obj.__class__()
|
||||||
for key, value in obj.items():
|
for key, value in obj.items():
|
||||||
normalized_key = key[:1].lower() + key[1:]
|
normalized_key = key[:1].lower() + key[1:]
|
||||||
result[normalized_key] = remove_capitalization_of_dict_keys(value)
|
result[normalized_key] = remove_capitalization_of_dict_keys(value)
|
||||||
return result
|
return result
|
||||||
elif isinstance(obj, collections.Iterable) and not isinstance(
|
elif isinstance(obj, collections_abc.Iterable) and not isinstance(
|
||||||
obj, six.string_types
|
obj, six.string_types
|
||||||
):
|
):
|
||||||
result = obj.__class__()
|
result = obj.__class__()
|
||||||
|
Loading…
Reference in New Issue
Block a user