Adding support for RHEL8 binary-compatible variants (#5158)

* Adding support for RHEL binary-compatible variants

* Skip ipmi related tests

* Fixing security_groups.py
This commit is contained in:
davidjumani 2021-08-18 13:33:03 +05:30 committed by GitHub
parent 72182b6bd9
commit 98d3231dbf
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 63 additions and 67 deletions

View File

@ -23,38 +23,6 @@ from .configFileOps import configFileOps
import os import os
import shutil import shutil
# exit() error constants
Unknown = 0
CentOS6 = 1
CentOS7 = 2
CentOS8 = 3
Ubuntu = 4
RHEL6 = 5
RHEL7 = 6
RHEL8 = 7
distro = None
#=================== DISTRIBUTION DETECTION =================
if os.path.exists("/etc/centos-release"):
version = open("/etc/centos-release").readline()
if version.find("CentOS release 6") != -1:
distro = CentOS6
elif version.find("CentOS Linux release 7") != -1:
distro = CentOS7
elif version.find("CentOS Linux release 8") != -1:
distro = CentOS8
elif os.path.exists("/etc/redhat-release"):
version = open("/etc/redhat-release").readline()
if version.find("Red Hat Enterprise Linux Server release 6") != -1:
distro = RHEL6
elif version.find("Red Hat Enterprise Linux Server 7") != -1:
distro = RHEL7
elif version.find("Red Hat Enterprise Linux Server 8") != -1:
distro = RHEL8
elif os.path.exists("/etc/lsb-release") and "Ubuntu" in open("/etc/lsb-release").read(-1): distro = Ubuntu
else: distro = Unknown
#=================== DISTRIBUTION DETECTION =================
class serviceCfgBase(object): class serviceCfgBase(object):
def __init__(self, syscfg): def __init__(self, syscfg):
self.status = None self.status = None
@ -531,8 +499,6 @@ class libvirtConfigRedhat(serviceCfgBase):
configureLibvirtConfig(self.syscfg.env.secure, self) configureLibvirtConfig(self.syscfg.env.secure, self)
cfo = configFileOps("/etc/sysconfig/libvirtd", self) cfo = configFileOps("/etc/sysconfig/libvirtd", self)
if distro in (CentOS6,RHEL6):
cfo.addEntry("export CGROUP_DAEMON", "'cpu:/virt'")
cfo.addEntry("LIBVIRTD_ARGS", "-l") cfo.addEntry("LIBVIRTD_ARGS", "-l")
cfo.save() cfo.save()
if os.path.exists("/lib/systemd/system/libvirtd.socket"): if os.path.exists("/lib/systemd/system/libvirtd.socket"):

View File

@ -5,9 +5,9 @@
# to you under the Apache License, Version 2.0 (the # to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance # "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at # with the License. You may obtain a copy of the License at
# #
# http://www.apache.org/licenses/LICENSE-2.0 # http://www.apache.org/licenses/LICENSE-2.0
# #
# Unless required by applicable law or agreed to in writing, # Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an # software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
@ -53,25 +53,25 @@ class bash:
except: except:
raise CloudRuntimeException(formatExceptionInfo()) raise CloudRuntimeException(formatExceptionInfo())
if not self.success: if not self.success:
logging.debug("Failed to execute:" + self.getErrMsg()) logging.debug("Failed to execute:" + self.getErrMsg())
def isSuccess(self): def isSuccess(self):
return self.success return self.success
def getStdout(self): def getStdout(self):
return self.stdout.decode('utf-8').strip('\n') return self.stdout.decode('utf-8').strip('\n')
def getLines(self): def getLines(self):
return self.stdout.decode('utf-8').strip('\n') return self.stdout.decode('utf-8').strip('\n')
def getStderr(self): def getStderr(self):
return self.stderr.decode('utf-8').strip('\n') return self.stderr.decode('utf-8').strip('\n')
def getErrMsg(self): def getErrMsg(self):
if self.isSuccess(): if self.isSuccess():
return "" return ""
if self.getStderr() is None or self.getStderr() == "": if self.getStderr() is None or self.getStderr() == "":
return self.getStdout() return self.getStdout()
else: else:
@ -80,11 +80,11 @@ class bash:
def initLoging(logFile=None): def initLoging(logFile=None):
try: try:
if logFile is None: if logFile is None:
logging.basicConfig(level=logging.DEBUG) logging.basicConfig(level=logging.DEBUG)
else: else:
logging.basicConfig(filename=logFile, level=logging.DEBUG) logging.basicConfig(filename=logFile, level=logging.DEBUG)
except: except:
logging.basicConfig(level=logging.DEBUG) logging.basicConfig(level=logging.DEBUG)
def writeProgressBar(msg, result): def writeProgressBar(msg, result):
output = "[%-6s]\n"%"Failed" output = "[%-6s]\n"%"Failed"
@ -100,7 +100,7 @@ def writeProgressBar(msg, result):
class UnknownSystemException(Exception): class UnknownSystemException(Exception):
"This Excption is raised if the current operating enviornment is unknown" "This Excption is raised if the current operating enviornment is unknown"
pass pass
class Distribution: class Distribution:
def __init__(self): def __init__(self):
self.distro = "Unknown" self.distro = "Unknown"
@ -110,11 +110,15 @@ class Distribution:
self.distro = "Fedora" self.distro = "Fedora"
elif os.path.exists("/etc/redhat-release"): elif os.path.exists("/etc/redhat-release"):
version = open("/etc/redhat-release").readline() version = open("/etc/redhat-release").readline()
if version.find("Red Hat Enterprise Linux Server release 6") != -1 or version.find("Scientific Linux release 6") != -1 or version.find("CentOS Linux release 6") != -1 or version.find("CentOS release 6.") != -1: if (version.find("Red Hat Enterprise Linux Server release 6") != -1 or version.find("Scientific Linux release 6") != -1 or
version.find("CentOS Linux release 6") != -1 or version.find("CentOS release 6.") != -1):
self.distro = "RHEL6" self.distro = "RHEL6"
elif version.find("Red Hat Enterprise Linux Server release 7") != -1 or version.find("Scientific Linux release 7") != -1 or version.find("CentOS Linux release 7") != -1 or version.find("CentOS release 7.") != -1: elif (version.find("Red Hat Enterprise Linux Server release 7") != -1 or version.find("Scientific Linux release 7") != -1 or
version.find("CentOS Linux release 7") != -1 or version.find("CentOS release 7.") != -1):
self.distro = "RHEL7" self.distro = "RHEL7"
elif version.find("Red Hat Enterprise Linux Server release 8") != -1 or version.find("Scientific Linux release 8") != -1 or version.find("CentOS Linux release 8") != -1 or version.find("CentOS release 8.") != -1: elif (version.find("Red Hat Enterprise Linux Server release 8") != -1 or version.find("Scientific Linux release 8") != -1 or
version.find("CentOS Linux release 8") != -1 or version.find("CentOS release 8.") != -1 or
version.find("Linux release 8") != -1):
self.distro = "RHEL8" self.distro = "RHEL8"
elif version.find("CentOS") != -1: elif version.find("CentOS") != -1:
self.distro = "CentOS" self.distro = "CentOS"
@ -134,17 +138,17 @@ class Distribution:
self.distro = "Ubuntu" self.distro = "Ubuntu"
else: else:
raise UnknownSystemException(distributor) raise UnknownSystemException(distributor)
else: else:
raise UnknownSystemException raise UnknownSystemException
def getVersion(self): def getVersion(self):
return self.distro return self.distro
def getRelease(self): def getRelease(self):
return self.release return self.release
def getArch(self): def getArch(self):
return self.arch return self.arch
class serviceOps: class serviceOps:
pass pass
class serviceOpsRedhat(serviceOps): class serviceOpsRedhat(serviceOps):
@ -161,7 +165,7 @@ class serviceOpsRedhat(serviceOps):
def stopService(self, servicename,force=False): def stopService(self, servicename,force=False):
if self.isServiceRunning(servicename) or force: if self.isServiceRunning(servicename) or force:
return bash("service " + servicename +" stop").isSuccess() return bash("service " + servicename +" stop").isSuccess()
return True return True
def disableService(self, servicename): def disableService(self, servicename):
result = self.stopService(servicename) result = self.stopService(servicename)
@ -176,13 +180,13 @@ class serviceOpsRedhat(serviceOps):
def enableService(self, servicename,forcestart=False): def enableService(self, servicename,forcestart=False):
bash("chkconfig --level 2345 " + servicename + " on") bash("chkconfig --level 2345 " + servicename + " on")
return self.startService(servicename,force=forcestart) return self.startService(servicename,force=forcestart)
def isKVMEnabled(self): def isKVMEnabled(self):
if os.path.exists("/dev/kvm"): if os.path.exists("/dev/kvm"):
return True return True
else: else:
return False return False
class serviceOpsUbuntu(serviceOps): class serviceOpsUbuntu(serviceOps):
def isServiceRunning(self, servicename): def isServiceRunning(self, servicename):
try: try:
@ -202,7 +206,7 @@ class serviceOpsUbuntu(serviceOps):
result = self.stopService(servicename) result = self.stopService(servicename)
bash("sudo update-rc.d -f " + servicename + " remove") bash("sudo update-rc.d -f " + servicename + " remove")
return result return result
def startService(self, servicename,force=True): def startService(self, servicename,force=True):
if not self.isServiceRunning(servicename) or force: if not self.isServiceRunning(servicename) or force:
return bash("sudo /usr/sbin/service " + servicename + " start").isSuccess() return bash("sudo /usr/sbin/service " + servicename + " start").isSuccess()

View File

@ -185,7 +185,7 @@ def destroy_network_rules_for_nic(vm_name, vm_ip, vm_mac, vif, sec_ips):
logging.debug("Ignoring failure to delete ebtable rules for vm: " + vm_name) logging.debug("Ignoring failure to delete ebtable rules for vm: " + vm_name)
def get_bridge_physdev(brname): def get_bridge_physdev(brname):
physdev = execute("bridge -o link show | awk '/master %s / && !/^[0-9]+: vnet/ {print $2}' | head -1 | cut -d ':' -f1" % brname) physdev = execute("bridge -o link show | awk '/master %s / && !/^[0-9]+: vnet/ {print $2}' | head -1 | cut -d ':' -f1 | cut -d '@' -f1" % brname)
return physdev.strip() return physdev.strip()

View File

@ -58,7 +58,7 @@ class TestDeployVMFromISOWithUefi(cloudstackTestCase):
if not cls.isUefiEnabledOnAtLeastOnHost(hosts): if not cls.isUefiEnabledOnAtLeastOnHost(hosts):
raise unittest.SkipTest("At least one host should support UEFI") raise unittest.SkipTest("At least one host should support UEFI")
cls.hostConfig = cls.config.__dict__["zones"][0].__dict__["pods"][0].__dict__["clusters"][0].__dict__["hosts"][0].__dict__ cls.hostConfig = cls.config.__dict__["zones"][0].__dict__["pods"][0].__dict__["clusters"][0].__dict__["hosts"][0].__dict__
# Create service, disk offerings etc # Create service, disk offerings etc
@ -179,12 +179,12 @@ class TestDeployVMFromISOWithUefi(cloudstackTestCase):
def checkBootTypeAndMode(self, root, bootmodesecure, isWindowsIso): def checkBootTypeAndMode(self, root, bootmodesecure, isWindowsIso):
machine = root.find(".os/type").get("machine") machine = root.find(".os/type").get("machine")
self.assertEqual(("q35" in machine), True, "The virtual machine is not with UEFI boot type") self.assertEqual(("q35" in machine), True, "The virtual machine is not with UEFI boot type")
bootmode = root.find(".os/loader").get("secure") if root.find(".os/loader") is not None :
bootmode = root.find(".os/loader").get("secure")
self.assertEqual((bootmode == bootmodesecure), True, "The VM is not in the right boot mode") if bootmode is not None :
self.assertEqual((bootmode == bootmodesecure), True, "The VM is not in the right boot mode")
if isWindowsIso: if isWindowsIso:
disks = root.findall("devices/disk") disks = root.findall("devices/disk")

View File

@ -209,6 +209,18 @@ class TestHAKVM(cloudstackTestCase):
except Exception as e: except Exception as e:
raise self.skipTest("Failed to deploy VM, skipping kvm host-ha test case") raise self.skipTest("Failed to deploy VM, skipping kvm host-ha test case")
def skipIfMSIsUnsupported(self) :
os_details = SshClient(self.mgtSvrDetails["mgtSvrIp"], 22, self.mgtSvrDetails["user"], self.mgtSvrDetails["passwd"]).execute \
("/usr/share/cloudstack-common/scripts/vm/hypervisor/versions.sh | cut -d '=' -f2")
os = os_details[0].lower()
if 'ubuntu' in os or 'debian' in os :
return
# RHEL < 8 works fine
os_ver = os_details[1].split('.')[0]
if float(os_ver) < 8:
return
self.skipTest("Skipping since RHEL8 / SUSE have known IPMI issues")
@attr(tags=["devcloud", "advanced", "advancedns", "smoke", "basic", "sg"], required_hardware="true") @attr(tags=["devcloud", "advanced", "advancedns", "smoke", "basic", "sg"], required_hardware="true")
def test_disable_oobm_ha_state_ineligible(self): def test_disable_oobm_ha_state_ineligible(self):
""" """
@ -276,10 +288,10 @@ class TestHAKVM(cloudstackTestCase):
self.logger.debug("Starting test_hostha_enable_ha_when_host_in_maintenance") self.logger.debug("Starting test_hostha_enable_ha_when_host_in_maintenance")
self.logger.debug("Pausing to wait for VMs to have finished starting") self.logger.debug("Pausing to wait for VMs to have finished starting")
time.sleep(300) time.sleep(300)
# Enable HA # Enable HA
self.configureAndEnableHostHa() self.configureAndEnableHostHa()
# Prepare for maintenance Host # Prepare for maintenance Host
self.setHostToMaintanance(self.host.id) self.setHostToMaintanance(self.host.id)
@ -351,6 +363,7 @@ class TestHAKVM(cloudstackTestCase):
Tests degraded HA state when agent is stopped/killed Tests degraded HA state when agent is stopped/killed
""" """
self.skipIfMSIsUnsupported()
self.configureAndStartIpmiServer() self.configureAndStartIpmiServer()
self.assertIssueCommandState('ON', 'On') self.assertIssueCommandState('ON', 'On')
self.configureAndEnableHostHa() self.configureAndEnableHostHa()
@ -387,6 +400,7 @@ class TestHAKVM(cloudstackTestCase):
Tests recovery and fencing HA state transitions Tests recovery and fencing HA state transitions
""" """
self.skipIfMSIsUnsupported()
self.configureAndStartIpmiServer() self.configureAndStartIpmiServer()
self.assertIssueCommandState('ON', 'On') self.assertIssueCommandState('ON', 'On')
self.configureAndEnableHostHa() self.configureAndEnableHostHa()
@ -426,7 +440,7 @@ class TestHAKVM(cloudstackTestCase):
""" """
self.logger.debug("Starting test_ha_kvm_host_fencing") self.logger.debug("Starting test_ha_kvm_host_fencing")
self.skipIfMSIsUnsupported()
self.configureAndStartIpmiServer() self.configureAndStartIpmiServer()
self.assertIssueCommandState('ON', 'On') self.assertIssueCommandState('ON', 'On')
self.configureAndEnableHostHa() self.configureAndEnableHostHa()

View File

@ -42,10 +42,12 @@ class TestOutOfBandManagement(cloudstackTestCase):
def setUpClass(cls): def setUpClass(cls):
testClient = super(TestOutOfBandManagement, cls).getClsTestClient() testClient = super(TestOutOfBandManagement, cls).getClsTestClient()
cls.apiclient = testClient.getApiClient() cls.apiclient = testClient.getApiClient()
cls.mgtSvrDetails = cls.config.__dict__["mgtSvr"][0].__dict__
cls.services = testClient.getParsedTestDataConfig() cls.services = testClient.getParsedTestDataConfig()
cls.zone = get_zone(cls.apiclient, testClient.getZoneForTests()) cls.zone = get_zone(cls.apiclient, testClient.getZoneForTests())
cls.host = None cls.host = None
cls.cleanup = [] cls.cleanup = []
cls.skipIfMSIsUnsupported(cls)
# use random port for ipmisim # use random port for ipmisim
s = socket.socket() s = socket.socket()
@ -82,7 +84,6 @@ class TestOutOfBandManagement(cloudstackTestCase):
self.fakeMsId = random.randint(10000, 99999) * random.randint(10, 20) self.fakeMsId = random.randint(10000, 99999) * random.randint(10, 20)
self.cleanup = [] self.cleanup = []
def tearDown(self): def tearDown(self):
try: try:
self.dbclient.execute("delete from oobm where port=%d" % self.getIpmiServerPort()) self.dbclient.execute("delete from oobm where port=%d" % self.getIpmiServerPort())
@ -94,6 +95,17 @@ class TestOutOfBandManagement(cloudstackTestCase):
except Exception as e: except Exception as e:
raise Exception("Warning: Exception during cleanup : %s" % e) raise Exception("Warning: Exception during cleanup : %s" % e)
def skipIfMSIsUnsupported(self) :
os_details = SshClient(self.mgtSvrDetails["mgtSvrIp"], 22, self.mgtSvrDetails["user"], self.mgtSvrDetails["passwd"]).execute \
("/usr/share/cloudstack-common/scripts/vm/hypervisor/versions.sh | cut -d '=' -f2")
os = os_details[0].lower()
if 'ubuntu' in os or 'debian' in os :
return
# RHEL < 8 works fine
os_ver = os_details[1].split('.')[0]
if float(os_ver) < 8:
return
self.skipTest(self, reason="Skipping since RHEL8 / SUSE have known IPMI issues")
def getFakeMsId(self): def getFakeMsId(self):
return self.fakeMsId return self.fakeMsId