Stop and start quagga when reinstalling 45/34145/2
authorNikolas Hermanns <nikolas.hermanns@ericsson.com>
Wed, 3 May 2017 14:23:02 +0000 (16:23 +0200)
committertomsou <soth@intracom-telecom.com>
Thu, 4 May 2017 07:02:02 +0000 (07:02 +0000)
Change-Id: Iba9a5980de0cbdf9c04bdd4dad704c12abb55048
Signed-off-by: Nikolas Hermanns <nikolas.hermanns@ericsson.com>
odl-pipeline/lib/odl_reinstaller/odl_reinstaller.py

index 053e022..c0cf075 100644 (file)
@@ -52,6 +52,11 @@ class ODLReInstaller(Service):
                 self.odl_node = node
                 LOG.info("ODL node found: {}".format(self.odl_node.name))
                 node.execute('systemctl stop opendaylight', as_root=True)
+                # rc 5 means the service is not there.
+                node.execute('systemctl stop bgpd', as_root=True,
+                             check_exit_code=[0, 5])
+                node.execute('systemctl stop zrpcd', as_root=True,
+                             check_exit_code=[0, 5])
 
             self.disconnect_ovs(node)
 
@@ -90,8 +95,21 @@ class ODLReInstaller(Service):
             self.validate_ovs(node)
         LOG.info("OpenDaylight Upgrade Successful!")
 
-    @staticmethod
-    def reinstall_odl(node, odl_artifact):
+    def _start_service_if_enabled(self, node, service):
+        # rc 3 means service inactive
+        # rc 5 mean no service available
+        status, _ = node.execute('systemctl status {}'.
+                                 format(service), check_exit_code=[0, 3, 5])
+        if 'service; enabled' in status:
+            LOG.info('Starting {}'.format(service))
+            node.execute('systemctl start {}'.format(service), as_root=True)
+
+    def reinstall_odl(self, node, odl_artifact):
+        # Check for Quagga
+        self._start_service_if_enabled(node, 'zrpcd')
+        self._start_service_if_enabled(node, 'bgpd')
+
+        # Install odl
         tar_tmp_path = '/tmp/odl-artifact/'
         node.copy('to', odl_artifact, tar_tmp_path + odl_artifact)
         node.execute('rm -rf /opt/opendaylight/', as_root=True)