mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	CLOUDSTACK-10227: Stabilization fixes for 4.11.0.0 (#2403)
This fixes regression failures seen in Trillian, fixes NPEs that cause Travis related failures. This also removes the aria2 dependency from rpms that require users to enable/install epel-release. This finally updates the checksums for 4.11 systemvmtemplates in db upgrade path. Signed-off-by: Rohit Yadav <rohit.yadav@shapeblue.com>
This commit is contained in:
		
							parent
							
								
									a30a31c9b7
								
							
						
					
					
						commit
						fa7c1e2e65
					
				| @ -84,6 +84,9 @@ public final class HostHAResponse extends BaseResponse { | |||||||
| 
 | 
 | ||||||
|     public void setHaState(HAConfig.HAState haState) { |     public void setHaState(HAConfig.HAState haState) { | ||||||
|         this.haState = haState; |         this.haState = haState; | ||||||
|  |         if (haState == null) { | ||||||
|  |             this.haState = HAConfig.HAState.Disabled; | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public String getProvider() { |     public String getProvider() { | ||||||
|  | |||||||
| @ -167,7 +167,6 @@ public class Upgrade41000to41100 implements DbUpgrade { | |||||||
| 
 | 
 | ||||||
|         final Map<Hypervisor.HypervisorType, String> newTemplateUrl = new HashMap<Hypervisor.HypervisorType, String>() { |         final Map<Hypervisor.HypervisorType, String> newTemplateUrl = new HashMap<Hypervisor.HypervisorType, String>() { | ||||||
|             { |             { | ||||||
|                 // FIXME: upload templates |  | ||||||
|                 put(Hypervisor.HypervisorType.KVM, "https://download.cloudstack.org/systemvm/4.11/systemvmtemplate-4.11.0-kvm.qcow2.bz2"); |                 put(Hypervisor.HypervisorType.KVM, "https://download.cloudstack.org/systemvm/4.11/systemvmtemplate-4.11.0-kvm.qcow2.bz2"); | ||||||
|                 put(Hypervisor.HypervisorType.VMware, "https://download.cloudstack.org/systemvm/4.11/systemvmtemplate-4.11.0-vmware.ova"); |                 put(Hypervisor.HypervisorType.VMware, "https://download.cloudstack.org/systemvm/4.11/systemvmtemplate-4.11.0-vmware.ova"); | ||||||
|                 put(Hypervisor.HypervisorType.XenServer, "https://download.cloudstack.org/systemvm/4.11/systemvmtemplate-4.11.0-xen.vhd.bz2"); |                 put(Hypervisor.HypervisorType.XenServer, "https://download.cloudstack.org/systemvm/4.11/systemvmtemplate-4.11.0-xen.vhd.bz2"); | ||||||
| @ -179,13 +178,12 @@ public class Upgrade41000to41100 implements DbUpgrade { | |||||||
| 
 | 
 | ||||||
|         final Map<Hypervisor.HypervisorType, String> newTemplateChecksum = new HashMap<Hypervisor.HypervisorType, String>() { |         final Map<Hypervisor.HypervisorType, String> newTemplateChecksum = new HashMap<Hypervisor.HypervisorType, String>() { | ||||||
|             { |             { | ||||||
|                 // FIXME: update checksums? |                 put(Hypervisor.HypervisorType.KVM, "2d8d1e4eacc976814b97f02849481433"); | ||||||
|                 put(Hypervisor.HypervisorType.KVM, "bc2eac46f16a2ece6c19d4b89db41de3"); |                 put(Hypervisor.HypervisorType.XenServer, "a5ecf7ed485e2da5ec1993069aa60553"); | ||||||
|                 put(Hypervisor.HypervisorType.XenServer, "908c28a8d4c232f960e0f84af7f86c80"); |                 put(Hypervisor.HypervisorType.VMware, "84dab5d1e8267b5dc85eb4eaa21a1efe"); | ||||||
|                 put(Hypervisor.HypervisorType.VMware, "970bfb070a80bd74820881d8149643c1"); |                 put(Hypervisor.HypervisorType.Hyperv, "d592ab6a2271303fe75b6a27f8e6bd53"); | ||||||
|                 put(Hypervisor.HypervisorType.Hyperv, "0adb35bd9f92e80d3fc63fcdd9bb55e5"); |                 put(Hypervisor.HypervisorType.LXC, "2d8d1e4eacc976814b97f02849481433"); | ||||||
|                 put(Hypervisor.HypervisorType.LXC, "bc2eac46f16a2ece6c19d4b89db41de3"); |                 put(Hypervisor.HypervisorType.Ovm3, "60fe2227b89a8980ee09f89dc7b19582"); | ||||||
|                 put(Hypervisor.HypervisorType.Ovm3, "94a41f0a5361933813bb34a51df56f56"); |  | ||||||
|             } |             } | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -130,8 +130,6 @@ Requires: perl | |||||||
| Requires: libvirt-python | Requires: libvirt-python | ||||||
| Requires: qemu-img | Requires: qemu-img | ||||||
| Requires: qemu-kvm | Requires: qemu-kvm | ||||||
| Requires: epel-release |  | ||||||
| Requires: aria2 |  | ||||||
| Provides: cloud-agent | Provides: cloud-agent | ||||||
| Obsoletes: cloud-agent < 4.1.0 | Obsoletes: cloud-agent < 4.1.0 | ||||||
| Obsoletes: cloud-agent-libs < 4.1.0 | Obsoletes: cloud-agent-libs < 4.1.0 | ||||||
|  | |||||||
| @ -111,8 +111,6 @@ Requires: perl | |||||||
| Requires: libvirt-python | Requires: libvirt-python | ||||||
| Requires: qemu-img | Requires: qemu-img | ||||||
| Requires: qemu-kvm | Requires: qemu-kvm | ||||||
| Requires: epel-release |  | ||||||
| Requires: aria2 |  | ||||||
| Provides: cloud-agent | Provides: cloud-agent | ||||||
| Group: System Environment/Libraries | Group: System Environment/Libraries | ||||||
| %description agent | %description agent | ||||||
|  | |||||||
| @ -451,6 +451,7 @@ public class HypervisorTemplateAdapter extends TemplateAdapterBase { | |||||||
| 
 | 
 | ||||||
|         if (imageStores == null || imageStores.size() == 0) { |         if (imageStores == null || imageStores.size() == 0) { | ||||||
|             // already destroyed on image stores |             // already destroyed on image stores | ||||||
|  |             success = true; | ||||||
|             s_logger.info("Unable to find image store still having template: " + template.getName() + ", so just mark the template removed"); |             s_logger.info("Unable to find image store still having template: " + template.getName() + ", so just mark the template removed"); | ||||||
|         } else { |         } else { | ||||||
|             // Make sure the template is downloaded to all found image stores |             // Make sure the template is downloaded to all found image stores | ||||||
| @ -536,10 +537,7 @@ public class HypervisorTemplateAdapter extends TemplateAdapterBase { | |||||||
|                                 templateZoneDao.remove(templateZone.getId()); |                                 templateZoneDao.remove(templateZone.getId()); | ||||||
|                             } |                             } | ||||||
|                         } |                         } | ||||||
|                     } catch (InterruptedException e) { |                     } catch (InterruptedException|ExecutionException e) { | ||||||
|                         s_logger.debug("Delete template Failed", e); |  | ||||||
|                         throw new CloudRuntimeException("Delete template Failed", e); |  | ||||||
|                     } catch (ExecutionException e) { |  | ||||||
|                         s_logger.debug("Delete template Failed", e); |                         s_logger.debug("Delete template Failed", e); | ||||||
|                         throw new CloudRuntimeException("Delete template Failed", e); |                         throw new CloudRuntimeException("Delete template Failed", e); | ||||||
|                     } |                     } | ||||||
| @ -551,7 +549,7 @@ public class HypervisorTemplateAdapter extends TemplateAdapterBase { | |||||||
| 
 | 
 | ||||||
|         } |         } | ||||||
|         if (success) { |         if (success) { | ||||||
|             if ((imageStores.size() > 1) && (profile.getZoneIdList() != null)) { |             if ((imageStores != null && imageStores.size() > 1) && (profile.getZoneIdList() != null)) { | ||||||
|                 //if template is stored in more than one image stores, and the zone id is not null, then don't delete other templates. |                 //if template is stored in more than one image stores, and the zone id is not null, then don't delete other templates. | ||||||
|                 return success; |                 return success; | ||||||
|             } |             } | ||||||
|  | |||||||
| @ -199,13 +199,16 @@ public final class HAManagerImpl extends ManagerBase implements HAManager, Clust | |||||||
| 
 | 
 | ||||||
|     private HAResource validateAndFindHAResource(final HAConfig haConfig) { |     private HAResource validateAndFindHAResource(final HAConfig haConfig) { | ||||||
|         HAResource resource = null; |         HAResource resource = null; | ||||||
|  |         if (haConfig == null) { | ||||||
|  |             return null; | ||||||
|  |         } | ||||||
|         if (haConfig.getResourceType() == HAResource.ResourceType.Host) { |         if (haConfig.getResourceType() == HAResource.ResourceType.Host) { | ||||||
|             final Host host = hostDao.findById(haConfig.getResourceId()); |             final Host host = hostDao.findById(haConfig.getResourceId()); | ||||||
|             if (host != null && host.getRemoved() != null) { |             if (host != null && host.getRemoved() != null) { | ||||||
|                 return null; |                 return null; | ||||||
|             } |             } | ||||||
|             resource = host; |             resource = host; | ||||||
|             if (resource == null && haConfig.getState() != HAConfig.HAState.Disabled) { |             if (haConfig.getState() == null || (resource == null && haConfig.getState() != HAConfig.HAState.Disabled)) { | ||||||
|                 disableHA(haConfig.getResourceId(), haConfig.getResourceType()); |                 disableHA(haConfig.getResourceId(), haConfig.getResourceType()); | ||||||
|                 return null; |                 return null; | ||||||
|             } |             } | ||||||
| @ -224,6 +227,9 @@ public final class HAManagerImpl extends ManagerBase implements HAManager, Clust | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private HAProvider<HAResource> validateAndFindHAProvider(final HAConfig haConfig, final HAResource resource) { |     private HAProvider<HAResource> validateAndFindHAProvider(final HAConfig haConfig, final HAResource resource) { | ||||||
|  |         if (haConfig == null) { | ||||||
|  |             return null; | ||||||
|  |         } | ||||||
|         final HAProvider<HAResource> haProvider = haProviderMap.get(haConfig.getHaProvider()); |         final HAProvider<HAResource> haProvider = haProviderMap.get(haConfig.getHaProvider()); | ||||||
|         if (haProvider != null && !haProvider.isEligible(resource)) { |         if (haProvider != null && !haProvider.isEligible(resource)) { | ||||||
|             if (haConfig.getState() != HAConfig.HAState.Ineligible) { |             if (haConfig.getState() != HAConfig.HAState.Ineligible) { | ||||||
| @ -639,6 +645,10 @@ public final class HAManagerImpl extends ManagerBase implements HAManager, Clust | |||||||
|                 } |                 } | ||||||
|                 final List<HAConfig> haConfigList = new ArrayList<HAConfig>(haConfigDao.listAll()); |                 final List<HAConfig> haConfigList = new ArrayList<HAConfig>(haConfigDao.listAll()); | ||||||
|                 for (final HAConfig haConfig : haConfigList) { |                 for (final HAConfig haConfig : haConfigList) { | ||||||
|  |                     if (haConfig == null) { | ||||||
|  |                         continue; | ||||||
|  |                     } | ||||||
|  | 
 | ||||||
|                     if (!checkHAOwnership(haConfig)) { |                     if (!checkHAOwnership(haConfig)) { | ||||||
|                         continue; |                         continue; | ||||||
|                     } |                     } | ||||||
|  | |||||||
| @ -352,6 +352,7 @@ class TestHostHA(cloudstackTestCase): | |||||||
|             Zone > Cluster > Host |             Zone > Cluster > Host | ||||||
|         """ |         """ | ||||||
|         host = self.getHost() |         host = self.getHost() | ||||||
|  |         self.configureAndDisableHostHa(host.id) | ||||||
|         self.configureAndEnableHostHa() |         self.configureAndEnableHostHa() | ||||||
| 
 | 
 | ||||||
|         self.checkSyncToState('Available') |         self.checkSyncToState('Available') | ||||||
|  | |||||||
| @ -218,7 +218,7 @@ class TestDedicatePublicIPRange(cloudstackTestCase): | |||||||
|                     return True, response[0].id |                     return True, response[0].id | ||||||
|             return False, None |             return False, None | ||||||
| 
 | 
 | ||||||
|         res, systemvmId = wait_until(3, 100, checkSystemVMUp) |         res, systemvmId = wait_until(3, 200, checkSystemVMUp) | ||||||
|         if not res: |         if not res: | ||||||
|             raise Exception("Failed to wait for systemvm to be running") |             raise Exception("Failed to wait for systemvm to be running") | ||||||
|         return systemvmId |         return systemvmId | ||||||
| @ -336,8 +336,8 @@ class TestDedicatePublicIPRange(cloudstackTestCase): | |||||||
|         return False |         return False | ||||||
| 
 | 
 | ||||||
|     @attr(tags = ["advanced", "publiciprange", "dedicate", "release"], required_hardware="false") |     @attr(tags = ["advanced", "publiciprange", "dedicate", "release"], required_hardware="false") | ||||||
|     def test_dedicate_public_ip_range_for_system_vms_cpvm(self): |     def test_dedicate_public_ip_range_for_system_vms_01_ssvm(self): | ||||||
|         """Test CPVM Public IP |         """Test SSVM Public IP | ||||||
|         """ |         """ | ||||||
|         self.debug("Precondition: No public IP range dedicated for system vms in the environment") |         self.debug("Precondition: No public IP range dedicated for system vms in the environment") | ||||||
|         if self.exists_public_ip_range_for_system_vms(self.services["zoneid"]): |         if self.exists_public_ip_range_for_system_vms(self.services["zoneid"]): | ||||||
| @ -355,13 +355,13 @@ class TestDedicatePublicIPRange(cloudstackTestCase): | |||||||
| 
 | 
 | ||||||
|         self.base_system_vm( |         self.base_system_vm( | ||||||
|             services, |             services, | ||||||
|             'consoleproxy' |             'secondarystoragevm' | ||||||
|         ) |         ) | ||||||
|         return |         return | ||||||
| 
 | 
 | ||||||
|     @attr(tags = ["advanced", "publiciprange", "dedicate", "release"], required_hardware="false") |     @attr(tags = ["advanced", "publiciprange", "dedicate", "release"], required_hardware="false") | ||||||
|     def test_dedicate_public_ip_range_for_system_vms_ssvm(self): |     def test_dedicate_public_ip_range_for_system_vms_02_cpvm(self): | ||||||
|         """Test SSVM Public IP |         """Test CPVM Public IP | ||||||
|         """ |         """ | ||||||
|         self.debug("Precondition: No public IP range dedicated for system vms in the environment") |         self.debug("Precondition: No public IP range dedicated for system vms in the environment") | ||||||
|         if self.exists_public_ip_range_for_system_vms(self.services["zoneid"]): |         if self.exists_public_ip_range_for_system_vms(self.services["zoneid"]): | ||||||
| @ -379,6 +379,6 @@ class TestDedicatePublicIPRange(cloudstackTestCase): | |||||||
| 
 | 
 | ||||||
|         self.base_system_vm( |         self.base_system_vm( | ||||||
|             services, |             services, | ||||||
|             'secondarystoragevm' |             'consoleproxy' | ||||||
|         ) |         ) | ||||||
|         return |         return | ||||||
|  | |||||||
| @ -198,7 +198,6 @@ class TestSSVMs(cloudstackTestCase): | |||||||
|                 True, |                 True, | ||||||
|                 "Check list response returns a valid list" |                 "Check list response returns a valid list" | ||||||
|             ) |             ) | ||||||
|             iprange = ipranges_response[0] |  | ||||||
| 
 | 
 | ||||||
|             # Fetch corresponding Physical Network of SSVM's Zone |             # Fetch corresponding Physical Network of SSVM's Zone | ||||||
|             listphyntwk = PhysicalNetwork.list( |             listphyntwk = PhysicalNetwork.list( | ||||||
| @ -213,9 +212,14 @@ class TestSSVMs(cloudstackTestCase): | |||||||
|                         self.apiclient, |                         self.apiclient, | ||||||
|                         physicalnetworkid=listphyntwk[0].id), |                         physicalnetworkid=listphyntwk[0].id), | ||||||
|                     list) is True): |                     list) is True): | ||||||
|                 self.assertEqual( |                 gatewayFound = False | ||||||
|                     ssvm.gateway, |                 for iprange in ipranges_response: | ||||||
|                     iprange.gateway, |                     if ssvm.gateway == iprange.gateway: | ||||||
|  |                         gatewayFound = True | ||||||
|  |                         break | ||||||
|  | 
 | ||||||
|  |                 self.assertTrue( | ||||||
|  |                     gatewayFound, | ||||||
|                     "Check gateway with that of corresponding ip range" |                     "Check gateway with that of corresponding ip range" | ||||||
|                 ) |                 ) | ||||||
| 
 | 
 | ||||||
| @ -333,7 +337,6 @@ class TestSSVMs(cloudstackTestCase): | |||||||
|                 True, |                 True, | ||||||
|                 "Check list response returns a valid list" |                 "Check list response returns a valid list" | ||||||
|             ) |             ) | ||||||
|             iprange = ipranges_response[0] |  | ||||||
| 
 | 
 | ||||||
|             # Fetch corresponding Physical Network of SSVM's Zone |             # Fetch corresponding Physical Network of SSVM's Zone | ||||||
|             listphyntwk = PhysicalNetwork.list( |             listphyntwk = PhysicalNetwork.list( | ||||||
| @ -348,13 +351,13 @@ class TestSSVMs(cloudstackTestCase): | |||||||
|                         self.apiclient, |                         self.apiclient, | ||||||
|                         physicalnetworkid=listphyntwk[0].id), |                         physicalnetworkid=listphyntwk[0].id), | ||||||
|                     list) is True): |                     list) is True): | ||||||
|                 cpvmValidGateway = False |                 gatewayFound = False | ||||||
|                 for iprange in ipranges_response: |                 for iprange in ipranges_response: | ||||||
|                     if iprange.gateway == cpvm.gateway: |                     if iprange.gateway == cpvm.gateway: | ||||||
|                         cpvmValidGateway = True |                         gatewayFound = True | ||||||
|                         break |                         break | ||||||
|                 self.assertTrue( |                 self.assertTrue( | ||||||
|                     cpvmValidGateway, |                     gatewayFound, | ||||||
|                     "Check gateway with that of corresponding ip range" |                     "Check gateway with that of corresponding ip range" | ||||||
|                 ) |                 ) | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -540,7 +540,6 @@ class TestTemplates(cloudstackTestCase): | |||||||
|         cls.services["template"]["ostypeid"] = template.ostypeid |         cls.services["template"]["ostypeid"] = template.ostypeid | ||||||
|         cls.services["template_2"]["ostypeid"] = template.ostypeid |         cls.services["template_2"]["ostypeid"] = template.ostypeid | ||||||
|         cls.services["ostypeid"] = template.ostypeid |         cls.services["ostypeid"] = template.ostypeid | ||||||
|         cls.services["isdynamicallyscalable"] = template.isdynamicallyscalable |  | ||||||
|         cls.account = Account.create( |         cls.account = Account.create( | ||||||
|                             cls.apiclient, |                             cls.apiclient, | ||||||
|                             cls.services["account"], |                             cls.services["account"], | ||||||
| @ -590,6 +589,7 @@ class TestTemplates(cloudstackTestCase): | |||||||
|                                          account=cls.account.name, |                                          account=cls.account.name, | ||||||
|                                          domainid=cls.account.domainid |                                          domainid=cls.account.domainid | ||||||
|                                          ) |                                          ) | ||||||
|  |         cls.services["isdynamicallyscalable"] = cls.template_1.isdynamicallyscalable | ||||||
|         cls.template_2 = Template.create( |         cls.template_2 = Template.create( | ||||||
|                                          cls.apiclient, |                                          cls.apiclient, | ||||||
|                                          cls.services["template_2"], |                                          cls.services["template_2"], | ||||||
|  | |||||||
| @ -246,8 +246,6 @@ class TestCreateVolume(cloudstackTestCase): | |||||||
|                 ret = checkVolumeSize(ssh_handle=ssh,volume_name=volume_name,size_to_verify=vol_sz) |                 ret = checkVolumeSize(ssh_handle=ssh,volume_name=volume_name,size_to_verify=vol_sz) | ||||||
|             elif list_volume_response[0].hypervisor.lower() == "hyperv": |             elif list_volume_response[0].hypervisor.lower() == "hyperv": | ||||||
|                 ret = checkVolumeSize(ssh_handle=ssh,volume_name="/dev/sdb",size_to_verify=vol_sz) |                 ret = checkVolumeSize(ssh_handle=ssh,volume_name="/dev/sdb",size_to_verify=vol_sz) | ||||||
|             elif list_volume_response[0].hypervisor.lower() == "vmware": |  | ||||||
|                 ret = checkVolumeSize(ssh_handle=ssh,volume_name="/dev/sdb",size_to_verify=vol_sz) |  | ||||||
|             else: |             else: | ||||||
|                 ret = checkVolumeSize(ssh_handle=ssh,size_to_verify=vol_sz) |                 ret = checkVolumeSize(ssh_handle=ssh,size_to_verify=vol_sz) | ||||||
|             self.debug(" Volume Size Expected %s  Actual :%s" %(vol_sz,ret[1])) |             self.debug(" Volume Size Expected %s  Actual :%s" %(vol_sz,ret[1])) | ||||||
|  | |||||||
| @ -258,8 +258,9 @@ | |||||||
|                                                     $form.find('.form-item[rel=rootDiskControllerTypeKVM]').hide(); |                                                     $form.find('.form-item[rel=rootDiskControllerTypeKVM]').hide(); | ||||||
|                                                     $form.find('.form-item[rel=directdownload]').hide(); |                                                     $form.find('.form-item[rel=directdownload]').hide(); | ||||||
| 
 | 
 | ||||||
|                                                     if (isAdmin()) |                                                     if (isAdmin()) { | ||||||
|                                                         $form.find('.form-item[rel=xenserverToolsVersion61plus]').css('display', 'inline-block'); |                                                         $form.find('.form-item[rel=xenserverToolsVersion61plus]').css('display', 'inline-block'); | ||||||
|  |                                                     } | ||||||
|                                                 } else if ($(this).val() == "KVM") { |                                                 } else if ($(this).val() == "KVM") { | ||||||
|                                                     $form.find('.form-item[rel=rootDiskControllerType]').hide(); |                                                     $form.find('.form-item[rel=rootDiskControllerType]').hide(); | ||||||
|                                                     $form.find('.form-item[rel=nicAdapterType]').hide(); |                                                     $form.find('.form-item[rel=nicAdapterType]').hide(); | ||||||
| @ -267,7 +268,9 @@ | |||||||
|                                                     $form.find('.form-item[rel=xenserverToolsVersion61plus]').hide(); |                                                     $form.find('.form-item[rel=xenserverToolsVersion61plus]').hide(); | ||||||
|                                                     $form.find('.form-item[rel=rootDiskControllerTypeKVM]').css('display', 'inline-block'); |                                                     $form.find('.form-item[rel=rootDiskControllerTypeKVM]').css('display', 'inline-block'); | ||||||
|                                                     $form.find('.form-item[rel=xenserverToolsVersion61plus]').css('display', 'inline-block'); |                                                     $form.find('.form-item[rel=xenserverToolsVersion61plus]').css('display', 'inline-block'); | ||||||
|  |                                                     if (isAdmin()) { | ||||||
|                                                       $form.find('.form-item[rel=directdownload]').css('display', 'inline-block'); |                                                       $form.find('.form-item[rel=directdownload]').css('display', 'inline-block'); | ||||||
|  |                                                     } | ||||||
|                                                 } else { |                                                 } else { | ||||||
|                                                     $form.find('.form-item[rel=rootDiskControllerType]').hide(); |                                                     $form.find('.form-item[rel=rootDiskControllerType]').hide(); | ||||||
|                                                     $form.find('.form-item[rel=nicAdapterType]').hide(); |                                                     $form.find('.form-item[rel=nicAdapterType]').hide(); | ||||||
|  | |||||||
| @ -1039,7 +1039,7 @@ public class HostMO extends BaseMO implements VmwareHypervisorHost { | |||||||
|     @Override |     @Override | ||||||
|     public boolean isHyperHostConnected() throws Exception { |     public boolean isHyperHostConnected() throws Exception { | ||||||
|         HostRuntimeInfo runtimeInfo = (HostRuntimeInfo)_context.getVimClient().getDynamicProperty(_mor, "runtime"); |         HostRuntimeInfo runtimeInfo = (HostRuntimeInfo)_context.getVimClient().getDynamicProperty(_mor, "runtime"); | ||||||
|         return runtimeInfo.getConnectionState() == HostSystemConnectionState.CONNECTED; |         return runtimeInfo != null && runtimeInfo.getConnectionState() == HostSystemConnectionState.CONNECTED; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public boolean revertToSnapshot(ManagedObjectReference morSnapshot) throws Exception { |     public boolean revertToSnapshot(ManagedObjectReference morSnapshot) throws Exception { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user