From becf0a1d3de3c8c44c4cdf09e7377e1bee784fd3 Mon Sep 17 00:00:00 2001 From: David Morrison Date: Mon, 23 Oct 2017 09:46:21 -0700 Subject: [PATCH] fix deep-copy in ec2.models.all_reservations --- moto/ec2/models.py | 15 +++------------ moto/ec2/responses/instances.py | 3 +-- 2 files changed, 4 insertions(+), 14 deletions(-) diff --git a/moto/ec2/models.py b/moto/ec2/models.py index f8090e783..1835f4dfc 100755 --- a/moto/ec2/models.py +++ b/moto/ec2/models.py @@ -765,14 +765,12 @@ class InstanceBackend(object): associated with the given instance_ids. """ reservations = [] - for reservation in self.all_reservations(make_copy=True): + for reservation in self.all_reservations(): reservation_instance_ids = [ instance.id for instance in reservation.instances] matching_reservation = any( instance_id in reservation_instance_ids for instance_id in instance_ids) if matching_reservation: - # We need to make a copy of the reservation because we have to modify the - # instances to limit to those requested reservation.instances = [ instance for instance in reservation.instances if instance.id in instance_ids] reservations.append(reservation) @@ -786,15 +784,8 @@ class InstanceBackend(object): reservations = filter_reservations(reservations, filters) return reservations - def all_reservations(self, make_copy=False, filters=None): - if make_copy: - # Return copies so that other functions can modify them with changing - # the originals - reservations = [copy.deepcopy(reservation) - for reservation in self.reservations.values()] - else: - reservations = [ - reservation for reservation in self.reservations.values()] + def all_reservations(self, filters=None): + reservations = [copy.copy(reservation) for reservation in self.reservations.values()] if filters is not None: reservations = filter_reservations(reservations, filters) return reservations diff --git a/moto/ec2/responses/instances.py b/moto/ec2/responses/instances.py index 1550fddeb..4401c31b7 100644 --- a/moto/ec2/responses/instances.py +++ b/moto/ec2/responses/instances.py @@ -16,8 +16,7 @@ class InstanceResponse(BaseResponse): reservations = self.ec2_backend.get_reservations_by_instance_ids( instance_ids, filters=filter_dict) else: - reservations = self.ec2_backend.all_reservations( - make_copy=True, filters=filter_dict) + reservations = self.ec2_backend.all_reservations(filters=filter_dict) reservation_ids = [reservation.id for reservation in reservations] if token: