记录一下 用dumpxml方式测试qos时,当时自己写的代码:
摘自NBSChecker.java
public void checkDumpXML(VolumeParas paras, SSHClient sshClient) {
String instanceId = paras.getInstanceId();
String projectId = paras.getProjectId();
String volumeId = paras.getVolumeId();
String hostIp = NBSConfig.hostIpMap.get(instanceId);
logger.info(CheckupAction + "Check CloudHost " + instanceId + " dumpXML file ...");
try {
String cmd = "sudo su - nbs -c 'sudo virsh dumpxml " + instanceId + "'";
String dumpXMLFile = sshClient.execute(cmd);
Element root = DocumentHelper.parseText(dumpXMLFile).getRootElement();
Element devices = root.element("devices");
String devicePath1 = "";
String maxBandWidth1 = "";
String maxIOPS1 = "";
String domain = "";
String bus = "";
String slot = "";
String function = "";
for (Iterator iter = devices.elementIterator(); iter.hasNext(); ) {
Element element = (Element) iter.next();
if (!element.getQName().getName().equals("disk"))
continue;
else if (!element.attribute("type").getValue().equals("block"))
continue;
else if (!element.elementText("serial").equals(volumeId))
continue;
Element source = (Element) element.elements("source").get(0);
Element iotune = (Element) element.elements("iotune").get(0);
Element total_bytes_sec = (Element) iotune.elements("total_bytes_sec").get(0);
Element total_iops_sec = (Element) iotune.elements("total_iops_sec").get(0);
Element address = (Element) element.elements("address").get(0);
devicePath1 = source.attributeValue("dev");
maxBandWidth1 = total_bytes_sec.getText();
maxIOPS1 = total_iops_sec.getText();
domain = address.attributeValue("domain");
bus = address.attributeValue("bus");
slot = address.attributeValue("slot");
function = address.attributeValue("function");
break;
}
// 4个地方的检查
String deviceName1 = generateDeviceName(domain, bus, slot, function);
String deviceName2 = paras.getDevice();
String devicePath2 = getDevicePath(projectId, volumeId, hostIp);
String maxBandWidth2 = String.valueOf(Long.valueOf(paras.getMaxBandWidth()) * 1024);
String maxIOPS2 = paras.getMaxIOPS();
if (devicePath1.equals(devicePath2) && maxBandWidth1.equals(maxBandWidth2) && maxIOPS1.equals(maxIOPS2) && deviceName1.equals
(deviceName2))
logger.info(CheckupResult + "Check CloudHost " + instanceId + " dumpXML file - pass!");
else {
logger.warn(JaggerFormating + "Actual deviceName - " + deviceName1);
logger.warn(JaggerFormating + "Expect deviceName - " + deviceName2);
logger.warn(JaggerFormating + "Actual devicePath - " + devicePath1);
logger.warn(JaggerFormating + "Expect devicePath - " + devicePath2);
logger.warn(JaggerFormating + "Actual maxBandWidth - " + maxBandWidth1);
logger.warn(JaggerFormating + "Expect maxBandWidth - " + maxBandWidth2);
logger.warn(JaggerFormating + "Actual maxIOPS - " + maxIOPS1);
logger.warn(JaggerFormating + "Expect maxIOPS - " + maxIOPS2);
logger.warn(CheckupResult + "Check CloudHost " + instanceId + " dumpXML file - NOT pass!");
Assert.fail();
}
} catch (DocumentException de) {
Assert.fail();
} catch (IndexOutOfBoundsException be) {
logger.warn("Failed to get specified word from dumpXML file, instanceId: " + instanceId + ", volumeId: " + volumeId);
Assert.fail("Failed to get specified word from dumpXML file, InstanceId: " + instanceId + ", VolumeId: " + volumeId);
}
}