Steps in which deletion is not supported have to return an empty list
authorSapan Bhatia <gwsapan@gmail.com>
Wed, 23 Jul 2014 13:59:32 +0000 (09:59 -0400)
committerSapan Bhatia <gwsapan@gmail.com>
Wed, 23 Jul 2014 13:59:32 +0000 (09:59 -0400)
when queried for deleted objects.

planetstack/openstack_observer/steps/sync_image_deployments.py
planetstack/openstack_observer/steps/sync_images.py
planetstack/openstack_observer/steps/sync_nodes.py
planetstack/openstack_observer/steps/sync_roles.py
planetstack/openstack_observer/steps/sync_site_privileges.py
planetstack/openstack_observer/steps/sync_slice_memberships.py
planetstack/openstack_observer/steps/sync_sliver_ips.py

index 4a69b1c..20c22a2 100644 (file)
@@ -14,7 +14,9 @@ class SyncImageDeployments(OpenStackSyncStep):
     provides=[ImageDeployments]
     requested_interval=0
 
-    def fetch_pending(self):
+    def fetch_pending(self, deleted):
+        if (deleted):
+            return []
          # smbaker: commented out automatic creation of ImageDeployments as
          #    as they will now be configured in GUI. Not sure if this is
          #    sufficient.
index 2c24e83..9b915fb 100644 (file)
@@ -9,7 +9,12 @@ class SyncImages(OpenStackSyncStep):
     provides=[Image]
     requested_interval=0
 
-    def fetch_pending(self):
+    def fetch_pending(self, deleted):
+        # Images come from the back end
+        # You can't delete them
+        if (deleted):
+            return []
+
         # get list of images on disk
         images_path = Config().observer_images_directory 
         available_images = {}
index 030d57c..740b5e1 100644 (file)
@@ -12,7 +12,12 @@ class SyncNodes(OpenStackSyncStep):
     provides=[Node]
     requested_interval=0
 
-    def fetch_pending(self):
+    def fetch_pending(self, deleted):
+        # Nodes come from the back end
+        # You can't delete them
+        if (deleted):
+            return []
+
         # collect local nodes
         sites = Site.objects.all()
         nodes = Node.objects.all()
index e3a20e9..bb837db 100644 (file)
@@ -11,7 +11,11 @@ class SyncRoles(OpenStackSyncStep):
     provides=[Role]
     requested_interval=0
 
-    def fetch_pending(self):
+    def fetch_pending(self, deleted):
+        # Deleting roles is not supported yet
+        if (deleted):
+            return []
+
         site_roles = SiteRole.objects.filter(Q(enacted__lt=F('updated')) | Q(enacted=None))
         slice_roles = SliceRole.objects.filter(Q(enacted__lt=F('updated')) | Q(enacted=None))
         deployment_roles = DeploymentRole.objects.filter(Q(enacted__lt=F('updated')) | Q(enacted=None))
index c229257..a10d982 100644 (file)
@@ -9,7 +9,11 @@ class SyncSitePrivileges(OpenStackSyncStep):
     requested_interval=0
     provides=[SitePrivilege]
 
-    def fetch_pending(self):
+    def fetch_pending(self, deleted):
+        # Deleting site privileges is not supported yet
+        if (deleted):
+            return []
+
         return SitePrivilege.objects.filter(Q(enacted__lt=F('updated')) | Q(enacted=None))
 
     def sync_record(self, site_priv):
index d2ec03e..b1cd223 100644 (file)
@@ -13,7 +13,10 @@ class SyncSliceMemberships(OpenStackSyncStep):
     requested_interval=0
     provides=[SlicePrivilege]
 
-    def fetch_pending(self):
+    def fetch_pending(self, deleted):
+        # Deleting site memberships is not supported yet
+        if (deleted):
+            return []
         return SlicePrivilege.objects.filter(Q(enacted__lt=F('updated')) | Q(enacted=None))
 
     def sync_record(self, slice_memb):
index e2212d1..bd1d572 100644 (file)
@@ -9,7 +9,10 @@ class SyncSliverIps(OpenStackSyncStep):
     provides=[Sliver]
     requested_interval=0
 
-    def fetch_pending(self):
+    def fetch_pending(self, deleted):
+        # Not supported yet
+        if (deleted):
+            return []
         slivers = Sliver.objects.filter(ip=None)
         return slivers