mirror of https://github.com/apache/jclouds.git
Issue 830: Updates to VAppClientLiveTest and Checks, and changes to associated domain objects
This commit is contained in:
parent
a9bceb9027
commit
78b5a16e29
|
@ -63,7 +63,7 @@ import com.google.common.collect.Sets;
|
|||
* </pre>
|
||||
*/
|
||||
@XmlRootElement(name = "LeaseSettingsSection")
|
||||
@XmlType(name = "LeaseSettingsSection")
|
||||
@XmlType(name = "LeaseSettingsSectionType")
|
||||
public class LeaseSettingsSection extends SectionType {
|
||||
|
||||
public static Builder<?> builder() {
|
||||
|
@ -142,7 +142,6 @@ public class LeaseSettingsSection extends SectionType {
|
|||
return self();
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public LeaseSettingsSection build() {
|
||||
return new LeaseSettingsSection(this);
|
||||
|
@ -194,17 +193,14 @@ public class LeaseSettingsSection extends SectionType {
|
|||
}
|
||||
|
||||
/**
|
||||
* Gets the value of the link property.
|
||||
* Gets the value of the links property.
|
||||
*/
|
||||
public Set<Link> getLinks() {
|
||||
return Collections.unmodifiableSet(this.links);
|
||||
return Collections.unmodifiableSet(links);
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the value of the deploymentLeaseInSeconds property.
|
||||
*
|
||||
* @return possible object is
|
||||
* {@link Integer }
|
||||
*/
|
||||
public Integer getDeploymentLeaseInSeconds() {
|
||||
return deploymentLeaseInSeconds;
|
||||
|
@ -212,9 +208,6 @@ public class LeaseSettingsSection extends SectionType {
|
|||
|
||||
/**
|
||||
* Gets the value of the storageLeaseInSeconds property.
|
||||
*
|
||||
* @return possible object is
|
||||
* {@link Integer }
|
||||
*/
|
||||
public Integer getStorageLeaseInSeconds() {
|
||||
return storageLeaseInSeconds;
|
||||
|
@ -235,7 +228,7 @@ public class LeaseSettingsSection extends SectionType {
|
|||
}
|
||||
|
||||
/**
|
||||
* @return the value of the href property.
|
||||
* Gets the value of the href property.
|
||||
*/
|
||||
public URI getHref() {
|
||||
return href;
|
||||
|
@ -243,9 +236,6 @@ public class LeaseSettingsSection extends SectionType {
|
|||
|
||||
/**
|
||||
* Gets the value of the type property.
|
||||
*
|
||||
* @return possible object is
|
||||
* {@link String }
|
||||
*/
|
||||
public String getType() {
|
||||
return type;
|
||||
|
@ -259,13 +249,13 @@ public class LeaseSettingsSection extends SectionType {
|
|||
return false;
|
||||
LeaseSettingsSection that = LeaseSettingsSection.class.cast(o);
|
||||
return super.equals(that) &&
|
||||
equal(links, that.links) &&
|
||||
equal(deploymentLeaseInSeconds, that.deploymentLeaseInSeconds) &&
|
||||
equal(storageLeaseInSeconds, that.storageLeaseInSeconds) &&
|
||||
equal(deploymentLeaseExpiration, that.deploymentLeaseExpiration) &&
|
||||
equal(storageLeaseExpiration, that.storageLeaseExpiration) &&
|
||||
equal(href, that.href) &&
|
||||
equal(type, that.type);
|
||||
equal(this.links, that.links) &&
|
||||
equal(this.deploymentLeaseInSeconds, that.deploymentLeaseInSeconds) &&
|
||||
equal(this.storageLeaseInSeconds, that.storageLeaseInSeconds) &&
|
||||
equal(this.deploymentLeaseExpiration, that.deploymentLeaseExpiration) &&
|
||||
equal(this.storageLeaseExpiration, that.storageLeaseExpiration) &&
|
||||
equal(this.href, that.href) &&
|
||||
equal(this.type, that.type);
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -21,8 +21,7 @@ package org.jclouds.vcloud.director.v1_5.domain;
|
|||
|
||||
import static com.google.common.base.Objects.equal;
|
||||
|
||||
import javax.xml.bind.annotation.XmlAccessType;
|
||||
import javax.xml.bind.annotation.XmlAccessorType;
|
||||
import javax.xml.bind.annotation.XmlRootElement;
|
||||
import javax.xml.bind.annotation.XmlType;
|
||||
import javax.xml.bind.annotation.XmlValue;
|
||||
|
||||
|
@ -35,8 +34,8 @@ import com.google.common.base.Objects;
|
|||
* <complexType name="ScreenTicket" />
|
||||
* </pre>
|
||||
*/
|
||||
@XmlAccessorType(XmlAccessType.FIELD)
|
||||
@XmlType(name = "ScreenTicket")
|
||||
@XmlRootElement(name = "ScreenTicket")
|
||||
@XmlType(name = "ScreenTicketType")
|
||||
public class ScreenTicket {
|
||||
|
||||
public static Builder builder() {
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
/**
|
||||
/*
|
||||
* Licensed to jclouds, Inc. (jclouds) under one or more
|
||||
* contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
|
@ -16,14 +16,12 @@
|
|||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
|
||||
package org.jclouds.vcloud.director.v1_5.domain;
|
||||
|
||||
import static com.google.common.base.Objects.*;
|
||||
import static com.google.common.base.Objects.equal;
|
||||
|
||||
import javax.xml.bind.annotation.XmlAccessType;
|
||||
import javax.xml.bind.annotation.XmlAccessorType;
|
||||
import javax.xml.bind.annotation.XmlElement;
|
||||
import javax.xml.bind.annotation.XmlRootElement;
|
||||
import javax.xml.bind.annotation.XmlType;
|
||||
|
||||
import com.google.common.base.Objects;
|
||||
|
@ -32,20 +30,14 @@ import com.google.common.base.Objects;
|
|||
* Represents vApp/VM undeployment parameters.
|
||||
*
|
||||
* <pre>
|
||||
* <complexType name="UndeployVAppParams">
|
||||
* <complexContent>
|
||||
* <extension base="{http://www.vmware.com/vcloud/v1.5}VCloudExtensibleType">
|
||||
* <sequence>
|
||||
* <element name="UndeployPowerAction" type="{http://www.w3.org/2001/XMLSchema}string" minOccurs="0"/>
|
||||
* </sequence>
|
||||
* <anyAttribute processContents='lax' namespace='##other'/>
|
||||
* </extension>
|
||||
* </complexContent>
|
||||
* </complexType>
|
||||
* <complexType name="UndeployVAppParamsType" />
|
||||
* </pre>
|
||||
*
|
||||
* @author grkvlt@apache.org
|
||||
* @since 0.9
|
||||
*/
|
||||
@XmlAccessorType(XmlAccessType.FIELD)
|
||||
@XmlType(name = "UndeployVAppParams")
|
||||
@XmlRootElement(name = "UndeployVAppParams")
|
||||
@XmlType(name = "UndeployVAppParamsType")
|
||||
public class UndeployVAppParams {
|
||||
|
||||
public static Builder builder() {
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
/**
|
||||
/*
|
||||
* Licensed to jclouds, Inc. (jclouds) under one or more
|
||||
* contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
|
@ -16,38 +16,28 @@
|
|||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
|
||||
package org.jclouds.vcloud.director.v1_5.domain;
|
||||
|
||||
import static com.google.common.base.Objects.equal;
|
||||
|
||||
import javax.xml.bind.annotation.XmlAttribute;
|
||||
import javax.xml.bind.annotation.XmlRootElement;
|
||||
import javax.xml.bind.annotation.XmlType;
|
||||
|
||||
import com.google.common.base.Objects;
|
||||
|
||||
|
||||
/**
|
||||
* Represents vApp Template upload parameters.
|
||||
* <p/>
|
||||
* <p/>
|
||||
* <p>Java class for UploadVAppTemplateParams complex type.
|
||||
* <p/>
|
||||
* <p>The following schema fragment specifies the expected content contained within this class.
|
||||
* <p/>
|
||||
*
|
||||
* <pre>
|
||||
* <complexType name="UploadVAppTemplateParams">
|
||||
* <complexContent>
|
||||
* <extension base="{http://www.vmware.com/vcloud/v1.5}ParamsType">
|
||||
* <attribute name="transferFormat" type="{http://www.w3.org/2001/XMLSchema}string" />
|
||||
* <attribute name="manifestRequired" type="{http://www.w3.org/2001/XMLSchema}boolean" />
|
||||
* <anyAttribute processContents='lax' namespace='##other'/>
|
||||
* </extension>
|
||||
* </complexContent>
|
||||
* </complexType>
|
||||
* <complexType name="UploadVAppTemplateParamsType" />
|
||||
* </pre>
|
||||
*
|
||||
* @author grkvlt@apache.org
|
||||
* @since 0.9
|
||||
*/
|
||||
@XmlType(name = "UploadVAppTemplateParams")
|
||||
@XmlRootElement(name = "UploadVAppTemplateParams")
|
||||
@XmlType(name = "UploadVAppTemplateParamsType")
|
||||
public class UploadVAppTemplateParams extends ParamsType {
|
||||
public static Builder<?> builder() {
|
||||
return new ConcreteBuilder();
|
||||
|
|
|
@ -23,6 +23,7 @@ import static com.google.common.base.Objects.*;
|
|||
import javax.xml.bind.annotation.XmlAccessType;
|
||||
import javax.xml.bind.annotation.XmlAccessorType;
|
||||
import javax.xml.bind.annotation.XmlAttribute;
|
||||
import javax.xml.bind.annotation.XmlRootElement;
|
||||
import javax.xml.bind.annotation.XmlType;
|
||||
|
||||
import com.google.common.base.Objects;
|
||||
|
@ -30,7 +31,7 @@ import com.google.common.base.Objects;
|
|||
/**
|
||||
* @author grkvlt@apache.org
|
||||
*/
|
||||
@XmlAccessorType(XmlAccessType.FIELD)
|
||||
@XmlRootElement(name = "VMWareTools")
|
||||
@XmlType(name = "VMWareTools")
|
||||
public class VMWareTools {
|
||||
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
/**
|
||||
/*
|
||||
* Licensed to jclouds, Inc. (jclouds) under one or more
|
||||
* contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
|
@ -18,7 +18,6 @@
|
|||
*/
|
||||
package org.jclouds.vcloud.director.v1_5.domain.ovf;
|
||||
|
||||
|
||||
import javax.xml.bind.annotation.XmlRootElement;
|
||||
|
||||
/**
|
||||
|
|
|
@ -135,7 +135,7 @@ public abstract class SectionType {
|
|||
if (getClass() != obj.getClass())
|
||||
return false;
|
||||
SectionType other = (SectionType) obj;
|
||||
return Objects.equal(info, other.info) && Objects.equal(required, other.required);
|
||||
return Objects.equal(this.info, other.info) && Objects.equal(this.required, other.required);
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -1,15 +1,25 @@
|
|||
//
|
||||
// This file was generated by the JavaTM Architecture for XML Binding(JAXB) Reference Implementation, vJAXB 2.1.10 in JDK 6
|
||||
// See <a href="http://java.sun.com/xml/jaxb">http://java.sun.com/xml/jaxb</a>
|
||||
// Any modifications to this file will be lost upon recompilation of the source schema.
|
||||
// Generated on: 2012.02.08 at 02:47:44 PM GMT
|
||||
//
|
||||
|
||||
/*
|
||||
* Licensed to jclouds, Inc. (jclouds) under one or more
|
||||
* contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. jclouds licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.jclouds.vcloud.director.v1_5.domain.ovf;
|
||||
|
||||
import static com.google.common.base.Objects.equal;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collections;
|
||||
import java.util.List;
|
||||
|
||||
|
@ -74,7 +84,7 @@ public class StartupSection extends SectionType {
|
|||
}
|
||||
|
||||
@XmlElement(name = "Item")
|
||||
private List<StartupSectionItem> item;
|
||||
private List<StartupSectionItem> items;
|
||||
@XmlAnyElement(lax = true)
|
||||
private List<Object> any;
|
||||
|
||||
|
@ -84,50 +94,22 @@ public class StartupSection extends SectionType {
|
|||
|
||||
public StartupSection(Builder<?> builder) {
|
||||
super(builder);
|
||||
this.item = (item != null) ? ImmutableList.<StartupSectionItem>copyOf(builder.item) : Collections.<StartupSectionItem>emptyList();
|
||||
this.items = (items != null) ? ImmutableList.<StartupSectionItem>copyOf(builder.item) : Collections.<StartupSectionItem>emptyList();
|
||||
this.any = (any != null) ? ImmutableList.<Object>copyOf(builder.any) : Collections.<Object>emptyList();
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the value of the item property.
|
||||
* <p>
|
||||
* This accessor method returns a reference to the live list, not a snapshot. Therefore any modification you make to the returned
|
||||
* list will be present inside the JAXB object. This is why there is not a <CODE>set</CODE> method for the item property.
|
||||
* <p>
|
||||
* For example, to add a new item, do as follows:
|
||||
*
|
||||
* <pre>
|
||||
* getItem().add(newItem);
|
||||
* </pre>
|
||||
* <p>
|
||||
* Objects of the following type(s) are allowed in the list {@link StartupSectionItem }
|
||||
*/
|
||||
public List<StartupSectionItem> getItem() {
|
||||
if (item == null) {
|
||||
item = new ArrayList<StartupSectionItem>();
|
||||
}
|
||||
return this.item;
|
||||
return items;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the value of the any property.
|
||||
* <p>
|
||||
* This accessor method returns a reference to the live list, not a snapshot. Therefore any modification you make to the returned
|
||||
* list will be present inside the JAXB object. This is why there is not a <CODE>set</CODE> method for the any property.
|
||||
* <p>
|
||||
* For example, to add a new item, do as follows:
|
||||
*
|
||||
* <pre>
|
||||
* getAny().add(newItem);
|
||||
* </pre>
|
||||
* <p>
|
||||
* Objects of the following type(s) are allowed in the list {@link Object } {@link Element }
|
||||
*/
|
||||
public List<Object> getAny() {
|
||||
if (any == null) {
|
||||
any = new ArrayList<Object>();
|
||||
}
|
||||
return this.any;
|
||||
return any;
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -138,16 +120,16 @@ public class StartupSection extends SectionType {
|
|||
return false;
|
||||
StartupSection that = StartupSection.class.cast(o);
|
||||
return super.equals(that) &&
|
||||
equal(this.item, that.item) && equal(this.any, that.any);
|
||||
equal(this.items, that.items) && equal(this.any, that.any);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int hashCode() {
|
||||
return Objects.hashCode(super.hashCode(), item, any);
|
||||
return Objects.hashCode(super.hashCode(), items, any);
|
||||
}
|
||||
|
||||
@Override
|
||||
public ToStringHelper string() {
|
||||
return super.string().add("item", item).add("any", any);
|
||||
return super.string().add("item", items).add("any", any);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -345,7 +345,7 @@ public interface VAppAsyncClient {
|
|||
@Consumes(TASK)
|
||||
@JAXBResponseParser
|
||||
@ExceptionParser(ThrowVCloudErrorOn4xx.class)
|
||||
ListenableFuture<Task> ejectMedia(@EndpointParam URI vAppURI,
|
||||
ListenableFuture<Task> ejectMedia(@EndpointParam URI vmURI,
|
||||
@BinderParam(BindToXMLPayload.class) MediaInsertOrEjectParams mediaParams);
|
||||
|
||||
/**
|
||||
|
@ -357,7 +357,7 @@ public interface VAppAsyncClient {
|
|||
@Consumes(TASK)
|
||||
@JAXBResponseParser
|
||||
@ExceptionParser(ThrowVCloudErrorOn4xx.class)
|
||||
ListenableFuture<Task> insertMedia(@EndpointParam URI vAppURI,
|
||||
ListenableFuture<Task> insertMedia(@EndpointParam URI vmURI,
|
||||
@BinderParam(BindToXMLPayload.class) MediaInsertOrEjectParams mediaParams);
|
||||
|
||||
/**
|
||||
|
@ -396,7 +396,7 @@ public interface VAppAsyncClient {
|
|||
@Consumes
|
||||
@JAXBResponseParser
|
||||
@ExceptionParser(ThrowVCloudErrorOn4xx.class)
|
||||
ListenableFuture<NetworkConnectionSection> getNetworkConnectionSection(@EndpointParam URI vAppURI);
|
||||
ListenableFuture<NetworkConnectionSection> getNetworkConnectionSection(@EndpointParam URI vmURI);
|
||||
|
||||
/**
|
||||
* @see VAppClient#modifyNetworkConnectionSection(URI, NetworkConnectionSection)
|
||||
|
@ -407,7 +407,7 @@ public interface VAppAsyncClient {
|
|||
@Consumes(TASK)
|
||||
@JAXBResponseParser
|
||||
@ExceptionParser(ThrowVCloudErrorOn4xx.class)
|
||||
ListenableFuture<Task> modifyNetworkConnectionSection(@EndpointParam URI vAppURI,
|
||||
ListenableFuture<Task> modifyNetworkConnectionSection(@EndpointParam URI vmURI,
|
||||
@BinderParam(BindToXMLPayload.class) NetworkConnectionSection section);
|
||||
|
||||
/**
|
||||
|
@ -428,7 +428,7 @@ public interface VAppAsyncClient {
|
|||
@Consumes
|
||||
@JAXBResponseParser
|
||||
@ExceptionParser(ThrowVCloudErrorOn4xx.class)
|
||||
ListenableFuture<OperatingSystemSection> getOperatingSystemSection(@EndpointParam URI vAppURI);
|
||||
ListenableFuture<OperatingSystemSection> getOperatingSystemSection(@EndpointParam URI vmURI);
|
||||
|
||||
/**
|
||||
* @see VAppClient#modifyOperatingSystemSection(URI, OperatingSystemSection)
|
||||
|
@ -439,7 +439,7 @@ public interface VAppAsyncClient {
|
|||
@Consumes(TASK)
|
||||
@JAXBResponseParser
|
||||
@ExceptionParser(ThrowVCloudErrorOn4xx.class)
|
||||
ListenableFuture<Task> modifyOperatingSystemSection(@EndpointParam URI vAppURI,
|
||||
ListenableFuture<Task> modifyOperatingSystemSection(@EndpointParam URI vmURI,
|
||||
@BinderParam(BindToXMLPayload.class) OperatingSystemSection section);
|
||||
|
||||
/**
|
||||
|
|
|
@ -420,7 +420,7 @@ public interface VAppClient {
|
|||
*
|
||||
* @since 0.9
|
||||
*/
|
||||
Task ejectMedia(URI vAppURI, MediaInsertOrEjectParams mediaParams);
|
||||
Task ejectMedia(URI vmURI, MediaInsertOrEjectParams mediaParams);
|
||||
|
||||
/**
|
||||
* Inserts a media into a VM.
|
||||
|
@ -431,7 +431,7 @@ public interface VAppClient {
|
|||
*
|
||||
* @since 0.9
|
||||
*/
|
||||
Task insertMedia(URI vAppURI, MediaInsertOrEjectParams mediaParams);
|
||||
Task insertMedia(URI vmURI, MediaInsertOrEjectParams mediaParams);
|
||||
|
||||
/**
|
||||
* @return synchronous access to {@link Metadata} features
|
||||
|
@ -440,7 +440,7 @@ public interface VAppClient {
|
|||
MetadataClient.Writeable getMetadataClient();
|
||||
|
||||
/**
|
||||
* Retrieves the network configuration section of a VM.
|
||||
* Retrieves the network config section of a vApp or vApp template.
|
||||
*
|
||||
* <pre>
|
||||
* GET /vApp/{id}/networkConfigSection
|
||||
|
@ -448,10 +448,10 @@ public interface VAppClient {
|
|||
*
|
||||
* @since 0.9
|
||||
*/
|
||||
NetworkConfigSection getNetworkConfigSection(URI vAppURI);
|
||||
NetworkConfigSection getNetworkConfigSection(URI vmURI);
|
||||
|
||||
/**
|
||||
* Modifies the network configuration section of a VM.
|
||||
* Modifies the network config section of a vApp.
|
||||
*
|
||||
* <pre>
|
||||
* PUT /vApp/{id}/networkConfigSection
|
||||
|
@ -459,7 +459,7 @@ public interface VAppClient {
|
|||
*
|
||||
* @since 0.9
|
||||
*/
|
||||
Task modifyNetworkConfigSection(URI vAppURI, NetworkConfigSection section);
|
||||
Task modifyNetworkConfigSection(URI vmURI, NetworkConfigSection section);
|
||||
|
||||
/**
|
||||
* Retrieves the network connection section of a VM.
|
||||
|
@ -470,7 +470,7 @@ public interface VAppClient {
|
|||
*
|
||||
* @since 0.9
|
||||
*/
|
||||
NetworkConnectionSection getNetworkConnectionSection(URI vAppURI);
|
||||
NetworkConnectionSection getNetworkConnectionSection(URI vmURI);
|
||||
|
||||
/**
|
||||
* Modifies the network connection section of a VM.
|
||||
|
@ -481,10 +481,10 @@ public interface VAppClient {
|
|||
*
|
||||
* @since 0.9
|
||||
*/
|
||||
Task modifyNetworkConnectionSection(URI vAppURI, NetworkConnectionSection section);
|
||||
Task modifyNetworkConnectionSection(URI vmURI, NetworkConnectionSection section);
|
||||
|
||||
/**
|
||||
* Retrieves the network section of a VM.
|
||||
* Retrieves the network section of a vApp or vApp template.
|
||||
*
|
||||
* <pre>
|
||||
* GET /vApp/{id}/networkSection
|
||||
|
@ -503,7 +503,7 @@ public interface VAppClient {
|
|||
*
|
||||
* @since 0.9
|
||||
*/
|
||||
OperatingSystemSection getOperatingSystemSection(URI vAppURI);
|
||||
OperatingSystemSection getOperatingSystemSection(URI vmURI);
|
||||
|
||||
/**
|
||||
* Modifies the operating system section of a VM.
|
||||
|
@ -514,7 +514,7 @@ public interface VAppClient {
|
|||
*
|
||||
* @since 0.9
|
||||
*/
|
||||
Task modifyOperatingSystemSection(URI vAppURI, OperatingSystemSection section);
|
||||
Task modifyOperatingSystemSection(URI vmURI, OperatingSystemSection section);
|
||||
|
||||
/**
|
||||
* Retrieves the owner of a vApp.
|
||||
|
|
|
@ -20,27 +20,22 @@ package org.jclouds.vcloud.director.v1_5.predicates;
|
|||
|
||||
import static com.google.common.base.Preconditions.checkNotNull;
|
||||
|
||||
import org.jclouds.vcloud.director.v1_5.VCloudDirectorMediaType;
|
||||
import org.jclouds.vcloud.director.v1_5.domain.Link;
|
||||
import org.jclouds.vcloud.director.v1_5.domain.Reference;
|
||||
|
||||
import com.google.common.base.Predicate;
|
||||
|
||||
/**
|
||||
* Predicates handy when working with Reference Types
|
||||
* Predicates for working with {@link Reference} collections.
|
||||
*
|
||||
* @author Adrian Cole
|
||||
*/
|
||||
|
||||
public class ReferenceTypePredicates {
|
||||
|
||||
/**
|
||||
* matches references of the given name
|
||||
* Matches {@link Reference}s of the given name.
|
||||
*
|
||||
* @param <T>
|
||||
* type of the ReferenceType, ex. {@link Link}
|
||||
* @param name
|
||||
* ex. {@code context.getApi().getCurrentSession().getOrg()}
|
||||
* @param T type of the reference, for example {@link Link}
|
||||
* @param name value of the name attribute of the referenced object
|
||||
* @return predicate that will match references of the given name
|
||||
*/
|
||||
public static <T extends Reference> Predicate<T> nameEquals(final String name) {
|
||||
|
@ -60,12 +55,10 @@ public class ReferenceTypePredicates {
|
|||
}
|
||||
|
||||
/**
|
||||
* matches references of the given type
|
||||
* Matches {@link Reference}s of the given type.
|
||||
*
|
||||
* @param <T>
|
||||
* type of the ReferenceType, ex. {@link Link}
|
||||
* @param type
|
||||
* ex. {@link VCloudDirectorMediaType#CATALOG}
|
||||
* @param T type of the reference, for example {@link Link}
|
||||
* @param type the media type string of the referenced object, for example {@link VCloudDirectorMediaType#CATALOG}
|
||||
* @return predicate that will match references of the given type
|
||||
* @see VCloudDirectorMediaType
|
||||
*/
|
||||
|
|
|
@ -23,9 +23,15 @@ package org.jclouds.vcloud.director.v1_5;
|
|||
*/
|
||||
public class VCloudDirectorLiveTestConstants {
|
||||
|
||||
/* regular expressions for pattern matching */
|
||||
|
||||
public static final String MAC_ADDRESS_PATTERN = "^([0-9A-F]{2}[:-]){5}([0-9A-F]{2})$";
|
||||
|
||||
/* Error code 200 indicates success. */
|
||||
|
||||
public static final String OK = "ERR-200: ok";
|
||||
|
||||
/* Error codes from 100 to 199 reflect parsing and other errors in domain objects. */
|
||||
/* Error codes from 100 to 199 reflect parsing and other errors in domain object fields and attributes. */
|
||||
|
||||
public static final String REF_REQ_LIVE = "ERR-101: %s reference required to perform live tests";
|
||||
|
||||
|
@ -53,7 +59,7 @@ public class VCloudDirectorLiveTestConstants {
|
|||
|
||||
public static final String TASK_COMPLETE_TIMELY = "ERR-113: Task %s should complete in a timely fashion";
|
||||
|
||||
public static final String NOT_NULL_OBJECT_FMT = "ERR-114: The %s field of the %s must not be null";
|
||||
public static final String NOT_NULL_OBJ_FIELD_FMT = "ERR-114: The %s field of the %s must not be null";
|
||||
|
||||
public static final String NOT_EMPTY_OBJECT_FMT = "ERR-115: One or more %s fields of the %s must be present";
|
||||
|
||||
|
@ -75,6 +81,12 @@ public class VCloudDirectorLiveTestConstants {
|
|||
|
||||
public static final String OBJ_FIELD_EMPTY_TO_DELETE = "ERR-124: %s must have no %s to be deleted (%s)";
|
||||
|
||||
public static final String NOT_NULL_OBJ_FMT = "ERR-125: The %s object must not be null";
|
||||
|
||||
public static final String NOT_EMPTY_STRING_FMT = "ERR-126: The %s field must not be an empty string";
|
||||
|
||||
public static final String MATCHES_STRING_FMT = "ERR-127: The %s field must match the pattern \"%s\"";
|
||||
|
||||
/* Error codes from 300 to 399 reflect entities and their links and relationship errors. */
|
||||
|
||||
public static final String ENTITY_NON_NULL = "ERR-301: The %s entity must not be null";
|
||||
|
|
|
@ -19,9 +19,13 @@
|
|||
package org.jclouds.vcloud.director.v1_5.domain;
|
||||
|
||||
import static org.jclouds.vcloud.director.v1_5.VCloudDirectorLiveTestConstants.CONDITION_FMT;
|
||||
import static org.jclouds.vcloud.director.v1_5.VCloudDirectorLiveTestConstants.MAC_ADDRESS_PATTERN;
|
||||
import static org.jclouds.vcloud.director.v1_5.VCloudDirectorLiveTestConstants.MATCHES_STRING_FMT;
|
||||
import static org.jclouds.vcloud.director.v1_5.VCloudDirectorLiveTestConstants.MUST_BE_WELL_FORMED_FMT;
|
||||
import static org.jclouds.vcloud.director.v1_5.VCloudDirectorLiveTestConstants.MUST_CONTAIN_FMT;
|
||||
import static org.jclouds.vcloud.director.v1_5.VCloudDirectorLiveTestConstants.NOT_NULL_OBJECT_FMT;
|
||||
import static org.jclouds.vcloud.director.v1_5.VCloudDirectorLiveTestConstants.NOT_EMPTY_STRING_FMT;
|
||||
import static org.jclouds.vcloud.director.v1_5.VCloudDirectorLiveTestConstants.NOT_NULL_OBJ_FIELD_FMT;
|
||||
import static org.jclouds.vcloud.director.v1_5.VCloudDirectorLiveTestConstants.NOT_NULL_OBJ_FMT;
|
||||
import static org.jclouds.vcloud.director.v1_5.VCloudDirectorLiveTestConstants.OBJ_DEL;
|
||||
import static org.jclouds.vcloud.director.v1_5.VCloudDirectorLiveTestConstants.OBJ_FIELD_ATTRB_REQ;
|
||||
import static org.jclouds.vcloud.director.v1_5.VCloudDirectorLiveTestConstants.OBJ_FIELD_EQ;
|
||||
|
@ -56,7 +60,9 @@ import org.jclouds.vcloud.director.v1_5.domain.ovf.Network;
|
|||
import org.jclouds.vcloud.director.v1_5.domain.ovf.NetworkSection;
|
||||
import org.jclouds.vcloud.director.v1_5.domain.ovf.OperatingSystemSection;
|
||||
import org.jclouds.vcloud.director.v1_5.domain.ovf.ProductSection;
|
||||
import org.jclouds.vcloud.director.v1_5.domain.ovf.RASD;
|
||||
import org.jclouds.vcloud.director.v1_5.domain.ovf.SectionType;
|
||||
import org.jclouds.vcloud.director.v1_5.domain.ovf.StartupSection;
|
||||
import org.jclouds.vcloud.director.v1_5.domain.ovf.VirtualHardwareSection;
|
||||
import org.jclouds.vcloud.director.v1_5.domain.ovf.VirtualSystem;
|
||||
import org.jclouds.vcloud.director.v1_5.domain.ovf.environment.EnvironmentType;
|
||||
|
@ -85,7 +91,7 @@ public class Checks {
|
|||
|
||||
public static void checkEntityType(EntityType entity) {
|
||||
// Check required fields
|
||||
assertNotNull(entity.getName(), String.format(NOT_NULL_OBJECT_FMT, "Name", "EntityType"));
|
||||
assertNotNull(entity.getName(), String.format(NOT_NULL_OBJ_FIELD_FMT, "Name", "EntityType"));
|
||||
|
||||
// Check optional fields
|
||||
// NOTE description cannot be checked
|
||||
|
@ -109,7 +115,7 @@ public class Checks {
|
|||
|
||||
public static void checkReferenceType(Reference reference, Collection<String> validTypes) {
|
||||
// Check required fields
|
||||
assertNotNull(reference.getHref(), String.format(NOT_NULL_OBJECT_FMT, "Href", "ReferenceType"));
|
||||
assertNotNull(reference.getHref(), String.format(NOT_NULL_OBJ_FIELD_FMT, "Href", "ReferenceType"));
|
||||
|
||||
// Check optional fields
|
||||
String id = reference.getId();
|
||||
|
@ -164,7 +170,7 @@ public class Checks {
|
|||
|
||||
public static void checkLink(Link link) {
|
||||
// Check required fields
|
||||
assertNotNull(link.getRel(), String.format(NOT_NULL_OBJECT_FMT, "Rel", "Link"));
|
||||
assertNotNull(link.getRel(), String.format(NOT_NULL_OBJ_FIELD_FMT, "Rel", "Link"));
|
||||
assertTrue(Link.Rel.ALL.contains(link.getRel()), String.format(REQUIRED_VALUE_OBJECT_FMT, "Rel", "Link", link.getRel(), Iterables.toString(Link.Rel.ALL)));
|
||||
|
||||
// Check parent type
|
||||
|
@ -173,7 +179,7 @@ public class Checks {
|
|||
|
||||
public static void checkTask(Task task) {
|
||||
// Check required fields
|
||||
assertNotNull(task.getStatus(), String.format(NOT_NULL_OBJECT_FMT, "Status", "Task"));
|
||||
assertNotNull(task.getStatus(), String.format(NOT_NULL_OBJ_FIELD_FMT, "Status", "Task"));
|
||||
assertTrue(Task.Status.ALL.contains(task.getStatus()), String.format(REQUIRED_VALUE_OBJECT_FMT, "Status", "Task", task.getStatus(), Iterables.toString(Task.Status.ALL)));
|
||||
|
||||
// Check optional fields
|
||||
|
@ -228,8 +234,8 @@ public class Checks {
|
|||
|
||||
public static void checkMetadataEntry(MetadataEntry metadataEntry) {
|
||||
// Check required fields
|
||||
assertNotNull(metadataEntry.getKey(), String.format(NOT_NULL_OBJECT_FMT, "Key", "MetadataEntry"));
|
||||
assertNotNull(metadataEntry.getValue(), String.format(NOT_NULL_OBJECT_FMT, "Value", "MetadataEntry"));
|
||||
assertNotNull(metadataEntry.getKey(), String.format(NOT_NULL_OBJ_FIELD_FMT, "Key", "MetadataEntry"));
|
||||
assertNotNull(metadataEntry.getValue(), String.format(NOT_NULL_OBJ_FIELD_FMT, "Value", "MetadataEntry"));
|
||||
|
||||
// Check parent type
|
||||
checkResourceType(metadataEntry);
|
||||
|
@ -237,7 +243,7 @@ public class Checks {
|
|||
|
||||
public static void checkMetadataValue(MetadataValue metadataValue) {
|
||||
// Check required elements and attributes
|
||||
assertNotNull(metadataValue.getValue(), String.format(NOT_NULL_OBJECT_FMT, "Value", "MetadataValue"));
|
||||
assertNotNull(metadataValue.getValue(), String.format(NOT_NULL_OBJ_FIELD_FMT, "Value", "MetadataValue"));
|
||||
|
||||
// Check parent type
|
||||
checkResourceType(metadataValue);
|
||||
|
@ -249,9 +255,9 @@ public class Checks {
|
|||
|
||||
public static void checkError(Error error) {
|
||||
// Check required fields
|
||||
assertNotNull(error.getMessage(), String.format(NOT_NULL_OBJECT_FMT, "Message", "Error"));
|
||||
assertNotNull(error.getMajorErrorCode(), String.format(NOT_NULL_OBJECT_FMT, "MajorErrorCode", "Error"));
|
||||
assertNotNull(error.getMinorErrorCode(), String.format(NOT_NULL_OBJECT_FMT, "MinorErrorCode", "Error"));
|
||||
assertNotNull(error.getMessage(), String.format(NOT_NULL_OBJ_FIELD_FMT, "Message", "Error"));
|
||||
assertNotNull(error.getMajorErrorCode(), String.format(NOT_NULL_OBJ_FIELD_FMT, "MajorErrorCode", "Error"));
|
||||
assertNotNull(error.getMinorErrorCode(), String.format(NOT_NULL_OBJ_FIELD_FMT, "MinorErrorCode", "Error"));
|
||||
|
||||
// NOTE vendorSpecificErrorCode cannot be checked
|
||||
// NOTE stackTrace cannot be checked
|
||||
|
@ -259,7 +265,7 @@ public class Checks {
|
|||
|
||||
public static void checkOrg(Org org) {
|
||||
// Check required elements and attributes
|
||||
assertNotNull(org.getFullName(), String.format(NOT_NULL_OBJECT_FMT, "FullName", "Org"));
|
||||
assertNotNull(org.getFullName(), String.format(NOT_NULL_OBJ_FIELD_FMT, "FullName", "Org"));
|
||||
|
||||
// Check parent type
|
||||
checkEntityType(org);
|
||||
|
@ -267,7 +273,7 @@ public class Checks {
|
|||
|
||||
public static void checkAdminOrg(AdminOrg org) {
|
||||
// required
|
||||
assertNotNull(org.getSettings(), String.format(NOT_NULL_OBJECT_FMT, "settings", "AdminOrg"));
|
||||
assertNotNull(org.getSettings(), String.format(NOT_NULL_OBJ_FIELD_FMT, "settings", "AdminOrg"));
|
||||
|
||||
// optional
|
||||
if (org.getGroups() != null) {
|
||||
|
@ -405,7 +411,7 @@ public class Checks {
|
|||
public static void checkNetworkFeatures(NetworkFeatures features) {
|
||||
// Check optional fields
|
||||
if (features.getNetworkServices() != null) {
|
||||
for (NetworkServiceType service : features.getNetworkServices()) {
|
||||
for (NetworkServiceType<?> service : features.getNetworkServices()) {
|
||||
checkNetworkService(service);
|
||||
}
|
||||
}
|
||||
|
@ -456,12 +462,14 @@ public class Checks {
|
|||
}
|
||||
|
||||
public static void checkIpAddress(String ip) {
|
||||
InetAddresses.isInetAddress(ip);
|
||||
// Check the string is a valid IP address
|
||||
assertTrue(InetAddresses.isInetAddress(ip), String.format(CONDITION_FMT, "IpAddress", "a valid IP address", ip));
|
||||
}
|
||||
|
||||
private static void checkMacAddress(String macAddress) {
|
||||
assertNotNull(macAddress, String.format(NOT_NULL_OBJECT_FMT, "macAddress", ""));
|
||||
assertTrue(macAddress.matches("^([0-9A-F]{2}[:-]){5}([0-9A-F]{2})$"));
|
||||
// Check the string is a valid MAC address
|
||||
assertNotNull(macAddress, String.format(NOT_EMPTY_STRING_FMT, "macAddress"));
|
||||
assertTrue(macAddress.matches(MAC_ADDRESS_PATTERN), String.format(MATCHES_STRING_FMT, "macAddress", MAC_ADDRESS_PATTERN));
|
||||
}
|
||||
|
||||
public static void checkComputeCapacity(ComputeCapacity computeCapacity) {
|
||||
|
@ -493,7 +501,6 @@ public class Checks {
|
|||
assertNotNull(capacity.getLimit(), "The limit attribute of a CapacityWithUsage must be set");
|
||||
assertTrue(capacity.getLimit() >= 0, "Limit must be greater than or equal to 0");
|
||||
|
||||
|
||||
// Check optional fields
|
||||
if (capacity.getAllocated() != null) {
|
||||
assertTrue(capacity.getAllocated() >= 0, "allocated must be greater than or equal to 0");
|
||||
|
@ -615,7 +622,7 @@ public class Checks {
|
|||
|
||||
public static void checkVAppTemplate(VAppTemplate template) {
|
||||
// Check required fields
|
||||
assertNotNull(template.getName(), String.format(NOT_NULL_OBJECT_FMT, "Name", "VAppTemplate"));
|
||||
assertNotNull(template.getName(), String.format(NOT_NULL_OBJ_FIELD_FMT, "Name", "VAppTemplate"));
|
||||
|
||||
// Check optional fields
|
||||
Owner owner = template.getOwner();
|
||||
|
@ -810,16 +817,16 @@ public class Checks {
|
|||
// NOTE canPublishCatalogs cannot be checked
|
||||
// NOTE useServerBootSequence cannot be checked
|
||||
if (settings.getDeployedVMQuota() != null) {
|
||||
assertTrue(settings.getDeployedVMQuota() >= 0, String.format(
|
||||
OBJ_FIELD_GTE_0, "deployedVMQuota", "port", settings.getDeployedVMQuota()));
|
||||
assertTrue(settings.getDeployedVMQuota() >= 0,
|
||||
String.format(OBJ_FIELD_GTE_0, "deployedVMQuota", "port", settings.getDeployedVMQuota()));
|
||||
}
|
||||
if (settings.getStoredVmQuota() != null) {
|
||||
assertTrue(settings.getStoredVmQuota() >= 0, String.format(
|
||||
OBJ_FIELD_GTE_0, "storedVmQuota", "port", settings.getStoredVmQuota()));
|
||||
assertTrue(settings.getStoredVmQuota() >= 0,
|
||||
String.format(OBJ_FIELD_GTE_0, "storedVmQuota", "port", settings.getStoredVmQuota()));
|
||||
}
|
||||
if (settings.getDelayAfterPowerOnSeconds() != null) {
|
||||
assertTrue(settings.getDelayAfterPowerOnSeconds() >= 0, String.format(
|
||||
OBJ_FIELD_GTE_0, "delayAfterPowerOnSeconds", "port", settings.getDelayAfterPowerOnSeconds()));
|
||||
assertTrue(settings.getDelayAfterPowerOnSeconds() >= 0,
|
||||
String.format(OBJ_FIELD_GTE_0, "delayAfterPowerOnSeconds", "port", settings.getDelayAfterPowerOnSeconds()));
|
||||
}
|
||||
|
||||
// parent type
|
||||
|
@ -830,8 +837,9 @@ public class Checks {
|
|||
// Check optional fields
|
||||
// NOTE customUsersOu cannot be checked
|
||||
if (settings.getLdapMode() != null) {
|
||||
assertTrue(LdapMode.ALL.contains(settings.getLdapMode()), String.format(REQUIRED_VALUE_OBJECT_FMT,
|
||||
"LdapMode", "OrdLdapSettings", settings.getLdapMode(), Iterables.toString(OrgLdapSettings.LdapMode.ALL)));
|
||||
assertTrue(LdapMode.ALL.contains(settings.getLdapMode()),
|
||||
String.format(REQUIRED_VALUE_OBJECT_FMT, "LdapMode", "OrdLdapSettings", settings.getLdapMode(),
|
||||
Iterables.toString(OrgLdapSettings.LdapMode.ALL)));
|
||||
}
|
||||
if (settings.getCustomOrgLdapSettings() != null) {
|
||||
checkCustomOrgLdapSettings(settings.getCustomOrgLdapSettings());
|
||||
|
@ -845,16 +853,16 @@ public class Checks {
|
|||
// required
|
||||
assertNotNull(settings.getHostName(), String.format(OBJ_FIELD_REQ, "CustomOrgLdapSettings", "hostName"));
|
||||
assertNotNull(settings.getPort(), String.format(OBJ_FIELD_REQ, "CustomOrgLdapSettings", "port"));
|
||||
assertTrue(settings.getPort() >= 0, String.format(
|
||||
OBJ_FIELD_GTE_0, "CustomOrgLdapSettings", "port", settings.getPort()));
|
||||
assertTrue(settings.getPort() >= 0,
|
||||
String.format(OBJ_FIELD_GTE_0, "CustomOrgLdapSettings", "port", settings.getPort()));
|
||||
assertNotNull(settings.getAuthenticationMechanism(), String.format(OBJ_FIELD_REQ, "CustomOrgLdapSettings", "authenticationMechanism"));
|
||||
assertTrue(AuthenticationMechanism.ALL.contains(settings.getAuthenticationMechanism()), String.format(REQUIRED_VALUE_OBJECT_FMT,
|
||||
"AuthenticationMechanism", "CustomOrdLdapSettings", settings.getAuthenticationMechanism(),
|
||||
assertTrue(AuthenticationMechanism.ALL.contains(settings.getAuthenticationMechanism()),
|
||||
String.format(REQUIRED_VALUE_OBJECT_FMT, "AuthenticationMechanism", "CustomOrdLdapSettings", settings.getAuthenticationMechanism(),
|
||||
Iterables.toString(CustomOrgLdapSettings.AuthenticationMechanism.ALL)));
|
||||
assertNotNull(settings.isGroupSearchBaseEnabled(), String.format(OBJ_FIELD_REQ, "CustomOrgLdapSettings", "isGroupSearchBaseEnabled"));
|
||||
assertNotNull(settings.getConnectorType(), String.format(OBJ_FIELD_REQ, "CustomOrgLdapSettings", "connectorType"));
|
||||
assertTrue(ConnectorType.ALL.contains(settings.getConnectorType()), String.format(REQUIRED_VALUE_OBJECT_FMT,
|
||||
"ConnectorType", "CustomOrdLdapSettings", settings.getConnectorType(),
|
||||
assertTrue(ConnectorType.ALL.contains(settings.getConnectorType()),
|
||||
String.format(REQUIRED_VALUE_OBJECT_FMT, "ConnectorType", "CustomOrdLdapSettings", settings.getConnectorType(),
|
||||
Iterables.toString(CustomOrgLdapSettings.ConnectorType.ALL)));
|
||||
assertNotNull(settings.getUserAttributes(), String.format(OBJ_FIELD_REQ, "CustomOrgLdapSettings", "userAttributes"));
|
||||
checkUserAttributes("CustomOrdLdapSettings", settings.getUserAttributes());
|
||||
|
@ -901,13 +909,16 @@ public class Checks {
|
|||
|
||||
public static void checkPasswordPolicySettings(OrgPasswordPolicySettings settings) {
|
||||
// required
|
||||
assertNotNull(settings.isAccountLockoutEnabled(), String.format(OBJ_FIELD_REQ, "OrgPasswordPolicySettings", "isAccountLockoutEnabled"));
|
||||
assertNotNull(settings.getInvalidLoginsBeforeLockout(), String.format(OBJ_FIELD_REQ, "OrgPasswordPolicySettings", "invalidLoginsBeforeLockout"));
|
||||
assertTrue(settings.getInvalidLoginsBeforeLockout() >= 0, String.format(
|
||||
OBJ_FIELD_GTE_0, "OrgPasswordPolicySettings", "storageLeaseSeconds", settings.getInvalidLoginsBeforeLockout()));
|
||||
assertNotNull(settings.getAccountLockoutIntervalMinutes(), String.format(OBJ_FIELD_REQ, "OrgPasswordPolicySettings", "accountLockoutIntervalMinutes"));
|
||||
assertTrue(settings.getAccountLockoutIntervalMinutes() >= 0, String.format(
|
||||
OBJ_FIELD_GTE_0, "OrgPasswordPolicySettings", "accountLockoutIntervalMinutes", settings.getAccountLockoutIntervalMinutes()));
|
||||
assertNotNull(settings.isAccountLockoutEnabled(),
|
||||
String.format(OBJ_FIELD_REQ, "OrgPasswordPolicySettings", "isAccountLockoutEnabled"));
|
||||
assertNotNull(settings.getInvalidLoginsBeforeLockout(),
|
||||
String.format(OBJ_FIELD_REQ, "OrgPasswordPolicySettings", "invalidLoginsBeforeLockout"));
|
||||
assertTrue(settings.getInvalidLoginsBeforeLockout() >= 0,
|
||||
String.format(OBJ_FIELD_GTE_0, "OrgPasswordPolicySettings", "storageLeaseSeconds", settings.getInvalidLoginsBeforeLockout()));
|
||||
assertNotNull(settings.getAccountLockoutIntervalMinutes(),
|
||||
String.format(OBJ_FIELD_REQ, "OrgPasswordPolicySettings", "accountLockoutIntervalMinutes"));
|
||||
assertTrue(settings.getAccountLockoutIntervalMinutes() >= 0,
|
||||
String.format(OBJ_FIELD_GTE_0, "OrgPasswordPolicySettings", "accountLockoutIntervalMinutes", settings.getAccountLockoutIntervalMinutes()));
|
||||
|
||||
// parent type
|
||||
checkResourceType(settings);
|
||||
|
@ -917,12 +928,12 @@ public class Checks {
|
|||
// Check optional fields
|
||||
// NOTE deleteOnStorageLeaseExpiration cannot be checked
|
||||
if (settings.getStorageLeaseSeconds() != null) {
|
||||
assertTrue(settings.getStorageLeaseSeconds() >= 0, String.format(
|
||||
OBJ_FIELD_GTE_0, "OrgLeaseSettings", "storageLeaseSeconds", settings.getStorageLeaseSeconds()));
|
||||
assertTrue(settings.getStorageLeaseSeconds() >= 0,
|
||||
String.format(OBJ_FIELD_GTE_0, "OrgLeaseSettings", "storageLeaseSeconds", settings.getStorageLeaseSeconds()));
|
||||
}
|
||||
if (settings.getDeploymentLeaseSeconds() != null) {
|
||||
assertTrue(settings.getDeploymentLeaseSeconds() >= 0, String.format(
|
||||
OBJ_FIELD_GTE_0, "OrgLeaseSettings", "deploymentLeaseSeconds", settings.getDeploymentLeaseSeconds()));
|
||||
assertTrue(settings.getDeploymentLeaseSeconds() >= 0,
|
||||
String.format(OBJ_FIELD_GTE_0, "OrgLeaseSettings", "deploymentLeaseSeconds", settings.getDeploymentLeaseSeconds()));
|
||||
}
|
||||
|
||||
// parent type
|
||||
|
@ -933,8 +944,8 @@ public class Checks {
|
|||
// Check optional fields
|
||||
// NOTE deleteOnStorageLeaseExpiration cannot be checked
|
||||
if (settings.getStorageLeaseSeconds() != null) {
|
||||
assertTrue(settings.getStorageLeaseSeconds() >= 0, String.format(
|
||||
OBJ_FIELD_GTE_0, "OrgVAppTemplateLeaseSettings", "storageLeaseSeconds", settings.getStorageLeaseSeconds()));
|
||||
assertTrue(settings.getStorageLeaseSeconds() >= 0,
|
||||
String.format(OBJ_FIELD_GTE_0, "OrgVAppTemplateLeaseSettings", "storageLeaseSeconds", settings.getStorageLeaseSeconds()));
|
||||
}
|
||||
|
||||
// parent type
|
||||
|
@ -965,12 +976,12 @@ public class Checks {
|
|||
checkEmailAddress(user.getAlertEmail());
|
||||
}
|
||||
if (user.getStoredVmQuota() != null) {
|
||||
assertTrue(user.getStoredVmQuota() >= 0, String.format(OBJ_FIELD_GTE_0,
|
||||
"User", "storedVmQuota", user.getStoredVmQuota()));
|
||||
assertTrue(user.getStoredVmQuota() >= 0,
|
||||
String.format(OBJ_FIELD_GTE_0, "User", "storedVmQuota", user.getStoredVmQuota()));
|
||||
}
|
||||
if (user.getDeployedVmQuota() != null) {
|
||||
assertTrue(user.getDeployedVmQuota() >= 0, String.format(OBJ_FIELD_GTE_0,
|
||||
"User", "deployedVmQuota", user.getDeployedVmQuota()));
|
||||
assertTrue(user.getDeployedVmQuota() >= 0,
|
||||
String.format(OBJ_FIELD_GTE_0, "User", "deployedVmQuota", user.getDeployedVmQuota()));
|
||||
}
|
||||
if (user.getRole() != null) {
|
||||
checkReferenceType(user.getRole());
|
||||
|
@ -986,99 +997,174 @@ public class Checks {
|
|||
}
|
||||
|
||||
public static void checkTelephone(String number) {
|
||||
// TODO: regex validate telephone
|
||||
// TODO regex validate telephone
|
||||
}
|
||||
|
||||
public static void checkCustomizationSection(CustomizationSection val) {
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJECT_FMT, "CustomizationSection", ""));
|
||||
public static void checkScreenTicket(ScreenTicket ticket) {
|
||||
// NOTE the value field cannot be checked
|
||||
}
|
||||
|
||||
public static void checkCustomizationSection(CustomizationSection section) {
|
||||
assertNotNull(section, String.format(NOT_NULL_OBJ_FMT, "CustomizationSection"));
|
||||
|
||||
// Check optional fields
|
||||
if (val.getLinks() != null) {
|
||||
for (Link link : val.getLinks()) {
|
||||
if (section.getLinks() != null) {
|
||||
for (Link link : section.getLinks()) {
|
||||
checkLink(link);
|
||||
}
|
||||
}
|
||||
if (val.getType() != null) {
|
||||
checkType(val.getType());
|
||||
}
|
||||
if (val.getHref() != null) {
|
||||
checkHref(val.getHref());
|
||||
if (section.getType() != null) checkType(section.getType());
|
||||
if (section.getHref() != null) checkHref(section.getHref());
|
||||
|
||||
// Check parent type
|
||||
checkOvfSectionType(section);
|
||||
}
|
||||
|
||||
checkOvfSectionType(val);
|
||||
}
|
||||
public static void checkProductSectionList(ProductSectionList sections) {
|
||||
assertNotNull(sections, String.format(NOT_NULL_OBJ_FMT, "ProductSectionList"));
|
||||
|
||||
public static void checkProductSectionList(ProductSectionList val) {
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJECT_FMT, "ProductSectionList", ""));
|
||||
|
||||
for (ProductSection productSection : val) {
|
||||
for (ProductSection productSection : sections) {
|
||||
checkOvfProductSection(productSection);
|
||||
}
|
||||
|
||||
checkResourceType(val);
|
||||
// Check parent type
|
||||
checkResourceType(sections);
|
||||
}
|
||||
|
||||
public static void checkGuestCustomizationSection(GuestCustomizationSection val) {
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJECT_FMT, "GuestCustomizationSection", ""));
|
||||
public static void checkGuestCustomizationSection(GuestCustomizationSection section) {
|
||||
assertNotNull(section, String.format(NOT_NULL_OBJ_FMT, "NetworkConfigSection"));
|
||||
|
||||
if (!val.isJoinDomainEnabled()) {
|
||||
assertFalse(val.isUseOrgSettings());
|
||||
assertNull(val.getDomainName());
|
||||
assertNull(val.getDomainUserName());
|
||||
assertNull(val.getDomainUserPassword());
|
||||
|
||||
if (!section.isJoinDomainEnabled()) {
|
||||
assertFalse(section.isUseOrgSettings());
|
||||
assertNull(section.getDomainName());
|
||||
assertNull(section.getDomainUserName());
|
||||
assertNull(section.getDomainUserPassword());
|
||||
}
|
||||
|
||||
if (!val.isAdminPasswordEnabled()) {
|
||||
assertFalse(val.isAdminPasswordAuto());
|
||||
assertFalse(val.isResetPasswordRequired());
|
||||
if (val.isAdminPasswordAuto()) {
|
||||
assertNull(val.getAdminPassword());
|
||||
if (!section.isAdminPasswordEnabled()) {
|
||||
assertFalse(section.isAdminPasswordAuto());
|
||||
assertFalse(section.isResetPasswordRequired());
|
||||
if (section.isAdminPasswordAuto()) {
|
||||
assertNull(section.getAdminPassword());
|
||||
}
|
||||
}
|
||||
|
||||
checkOvfSectionType(val);
|
||||
// Check parent type
|
||||
checkOvfSectionType(section);
|
||||
}
|
||||
|
||||
public static void checkLeaseSettingsSection(LeaseSettingsSection val) {
|
||||
if (val.getLinks() != null) {
|
||||
for (Link link : val.getLinks()) {
|
||||
public static void checkLeaseSettingsSection(LeaseSettingsSection section) {
|
||||
assertNotNull(section, String.format(NOT_NULL_OBJ_FMT, "LeaseSettingsSection"));
|
||||
|
||||
if (section.getLinks() != null) {
|
||||
for (Link link : section.getLinks()) {
|
||||
checkLink(link);
|
||||
}
|
||||
}
|
||||
|
||||
checkOvfSectionType(val);
|
||||
// Check parent type
|
||||
checkOvfSectionType(section);
|
||||
}
|
||||
|
||||
public static void checkNetworkConfigSection(NetworkConfigSection val) {
|
||||
if (val.getNetworkConfigs() != null) {
|
||||
for (VAppNetworkConfiguration networkConfig : val.getNetworkConfigs()) {
|
||||
public static void checkNetworkConfigSection(NetworkConfigSection section) {
|
||||
assertNotNull(section, String.format(NOT_NULL_OBJ_FMT, "NetworkConfigSection"));
|
||||
|
||||
if (section.getNetworkConfigs() != null) {
|
||||
for (VAppNetworkConfiguration networkConfig : section.getNetworkConfigs()) {
|
||||
checkVAppNetworkConfig(networkConfig);
|
||||
}
|
||||
}
|
||||
if (val.getLinks() != null) {
|
||||
for (Link link : val.getLinks()) {
|
||||
if (section.getLinks() != null) {
|
||||
for (Link link : section.getLinks()) {
|
||||
checkLink(link);
|
||||
}
|
||||
}
|
||||
if (val.getHref() != null) {
|
||||
checkHref(val.getHref());
|
||||
if (section.getHref() != null) {
|
||||
checkHref(section.getHref());
|
||||
}
|
||||
|
||||
checkOvfSectionType(val);
|
||||
// Check parent type
|
||||
checkOvfSectionType(section);
|
||||
}
|
||||
|
||||
public static void checkNetworkSection(NetworkSection section) {
|
||||
assertNotNull(section, String.format(NOT_NULL_OBJ_FMT, "NetworkSection"));
|
||||
|
||||
// Check optional fields
|
||||
if (section.getNetworks() != null) {
|
||||
for (Network network : section.getNetworks()) {
|
||||
checkNetwork(network);
|
||||
}
|
||||
}
|
||||
|
||||
// Check parent type
|
||||
checkOvfSectionType(section);
|
||||
}
|
||||
|
||||
public static void checkNetwork(Network network) {
|
||||
assertNotNull(network, String.format(NOT_NULL_OBJ_FMT, "Network"));
|
||||
|
||||
// Check optional fields
|
||||
// NOTE name field cannot be checked
|
||||
// NOTE description field cannot be checked
|
||||
}
|
||||
|
||||
public static void checkOperatingSystemSection(OperatingSystemSection section) {
|
||||
assertNotNull(section, String.format(NOT_NULL_OBJ_FMT, "OperatingSystemSection"));
|
||||
|
||||
// Check optional fields
|
||||
// NOTE id field cannot be checked
|
||||
// NOTE version field cannot be checked
|
||||
// NOTE description field cannot be checked
|
||||
|
||||
// Check parent type
|
||||
checkOvfSectionType(section);
|
||||
}
|
||||
|
||||
public static void checkRuntimeInfoSection(RuntimeInfoSection section) {
|
||||
assertNotNull(section, String.format(NOT_NULL_OBJ_FMT, "RuntimeInfoSection"));
|
||||
|
||||
// Check optional fields
|
||||
VMWareTools tools = section.getVMWareTools();
|
||||
if (tools != null) checkVMWareTools(tools);
|
||||
|
||||
// NOTE does this mean anything?
|
||||
for (Object any : section.getAny()) {
|
||||
assertNotNull(any);
|
||||
}
|
||||
|
||||
// Check parent type
|
||||
checkOvfSectionType(section);
|
||||
}
|
||||
|
||||
public static void checkVMWareTools(VMWareTools tools) {
|
||||
assertNotNull(tools, String.format(NOT_NULL_OBJ_FMT, "VMWareTools"));
|
||||
|
||||
// Check required fields
|
||||
assertNotNull(tools.getVersion(), String.format(NOT_NULL_OBJ_FIELD_FMT, "version", "VMWareTools"));
|
||||
assertFalse(tools.getVersion().isEmpty(), String.format(NOT_EMPTY_STRING_FMT, "VMWareTools.version"));
|
||||
}
|
||||
|
||||
public static void checkStartupSection(StartupSection section) {
|
||||
// TODO
|
||||
|
||||
// Check parent type
|
||||
checkOvfSectionType(section);
|
||||
}
|
||||
|
||||
private static void checkVAppNetworkConfig(VAppNetworkConfiguration val) {
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJECT_FMT, "VAppNetworkConfiguration", ""));
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJ_FMT, "VAppNetworkConfiguration"));
|
||||
|
||||
// required fields
|
||||
assertNotNull(val.getNetworkName(), String.format(NOT_NULL_OBJECT_FMT, "NetworkName", "VAppNetworkConfiguration"));
|
||||
assertNotNull(val.getNetworkName(), String.format(NOT_NULL_OBJ_FIELD_FMT, "NetworkName", "VAppNetworkConfiguration"));
|
||||
checkNetworkConfiguration(val.getConfiguration());
|
||||
|
||||
checkResourceType(val);
|
||||
}
|
||||
|
||||
public static void checkNetworkConnectionSection(NetworkConnectionSection val) {
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJECT_FMT, "VAppConnectionSection", ""));
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJ_FMT, "VAppConnectionSection"));
|
||||
|
||||
// Check optional fields
|
||||
if (val.getLinks() != null) {
|
||||
|
@ -1102,11 +1188,11 @@ public class Checks {
|
|||
}
|
||||
|
||||
private static void checkNetworkConnection(NetworkConnection val) {
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJECT_FMT, "NetworkConnection", ""));
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJ_FMT, "NetworkConnection"));
|
||||
|
||||
// Check required fields
|
||||
assertNotNull(val.getNetwork(), String.format(NOT_NULL_OBJECT_FMT, "Network", "NetworkConnection"));
|
||||
assertNotNull(val.getIpAddressAllocationMode(), String.format(NOT_NULL_OBJECT_FMT, "IpAddressAllocationMode", "NetworkConnection"));
|
||||
assertNotNull(val.getNetwork(), String.format(NOT_NULL_OBJ_FIELD_FMT, "Network", "NetworkConnection"));
|
||||
assertNotNull(val.getIpAddressAllocationMode(), String.format(NOT_NULL_OBJ_FIELD_FMT, "IpAddressAllocationMode", "NetworkConnection"));
|
||||
IpAddressAllocationMode mode = NetworkConnection.IpAddressAllocationMode.valueOf(val.getIpAddressAllocationMode());
|
||||
assertTrue(NetworkConnection.IpAddressAllocationMode.ALL.contains(mode),
|
||||
String.format(REQUIRED_VALUE_OBJECT_FMT, "IpAddressAllocationMode", "NetworkConnection", val.getIpAddressAllocationMode(), Iterables.toString(NetworkConnection.IpAddressAllocationMode.ALL)));
|
||||
|
@ -1122,17 +1208,28 @@ public class Checks {
|
|||
if (val.getMACAddress() != null) {
|
||||
checkMacAddress(val.getMACAddress());
|
||||
}
|
||||
}
|
||||
|
||||
// FIXME Missing?
|
||||
//val.getVCloudExtension();
|
||||
public static void checkRASD(RASD rasd) {
|
||||
// Check fields
|
||||
// TODO
|
||||
}
|
||||
|
||||
public static void checkRasdItemsList(RasdItemsList items) {
|
||||
// Check fields
|
||||
// TODO
|
||||
|
||||
for (RASD item : items.getItems()) {
|
||||
checkRASD(item);
|
||||
}
|
||||
}
|
||||
|
||||
public static void checkOvfSectionType(SectionType section) {
|
||||
assertNotNull(section, String.format(NOT_NULL_OBJECT_FMT, "SectionType", ""));
|
||||
assertNotNull(section, String.format(NOT_NULL_OBJ_FMT, "SectionType"));
|
||||
}
|
||||
|
||||
public static void checkOvfProductSection(ProductSection val) {
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJECT_FMT, "ProductSection", ""));
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJ_FMT, "ProductSection"));
|
||||
|
||||
if (val.getProperties() != null) {
|
||||
for (org.jclouds.vcloud.director.v1_5.domain.ovf.Property property : val.getProperties()) {
|
||||
|
@ -1140,15 +1237,16 @@ public class Checks {
|
|||
}
|
||||
}
|
||||
|
||||
// Check parent type
|
||||
checkOvfSectionType(val);
|
||||
}
|
||||
|
||||
private static void checkOvfProperty(org.jclouds.vcloud.director.v1_5.domain.ovf.Property val) {
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJECT_FMT, "Property", ""));
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJ_FMT, "Property"));
|
||||
}
|
||||
|
||||
public static void checkOvfNetworkSection(NetworkSection val) {
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJECT_FMT, "NetworkSection", ""));
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJ_FMT, "NetworkSection"));
|
||||
|
||||
if (val.getNetworks() != null) {
|
||||
for (Network network : val.getNetworks()) {
|
||||
|
@ -1160,11 +1258,11 @@ public class Checks {
|
|||
}
|
||||
|
||||
private static void checkOvfNetwork(Network val) {
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJECT_FMT, "Network", ""));
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJ_FMT, "Network"));
|
||||
}
|
||||
|
||||
public static void checkOvfEnvelope(Envelope val) {
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJECT_FMT, "Envelope", ""));
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJ_FMT, "Envelope"));
|
||||
|
||||
if (val.getDiskSections() != null) {
|
||||
for (DiskSection diskSection : val.getDiskSections()) {
|
||||
|
@ -1182,7 +1280,7 @@ public class Checks {
|
|||
}
|
||||
|
||||
private static void checkOvfVirtualSystem(VirtualSystem val) {
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJECT_FMT, "VirtualSystem", ""));
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJ_FMT, "VirtualSystem"));
|
||||
|
||||
if (val.getProductSections() != null) {
|
||||
for (ProductSection productSection : val.getProductSections()) {
|
||||
|
@ -1199,47 +1297,54 @@ public class Checks {
|
|||
}
|
||||
}
|
||||
|
||||
private static void checkOvfDiskSection(DiskSection val) {
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJECT_FMT, "DiskSection", ""));
|
||||
private static void checkOvfDiskSection(DiskSection section) {
|
||||
assertNotNull(section, String.format(NOT_NULL_OBJ_FMT, "DiskSection"));
|
||||
|
||||
if (val.getDisks() != null) {
|
||||
for (Disk disk : val.getDisks()) {
|
||||
if (section.getDisks() != null) {
|
||||
for (Disk disk : section.getDisks()) {
|
||||
checkOvfDisk(disk);
|
||||
}
|
||||
}
|
||||
|
||||
// Check parent type
|
||||
checkOvfSectionType(section);
|
||||
}
|
||||
|
||||
private static void checkOvfDisk(Disk val) {
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJECT_FMT, "Disk", ""));
|
||||
private static void checkOvfDisk(Disk disk) {
|
||||
assertNotNull(disk, String.format(NOT_NULL_OBJ_FMT, "Disk"));
|
||||
}
|
||||
|
||||
private static void checkOvfOperationSystemSection(OperatingSystemSection val) {
|
||||
checkOvfSectionType(val);
|
||||
private static void checkOvfOperationSystemSection(OperatingSystemSection section) {
|
||||
assertNotNull(section, String.format(NOT_NULL_OBJ_FMT, "OperatingSystemSection"));
|
||||
|
||||
// Check parent type
|
||||
checkOvfSectionType(section);
|
||||
}
|
||||
|
||||
private static void checkOvfVirtualHardwareSection(VirtualHardwareSection val) {
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJECT_FMT, "VirtualHardwareSection", ""));
|
||||
private static void checkOvfVirtualHardwareSection(VirtualHardwareSection section) {
|
||||
assertNotNull(section, String.format(NOT_NULL_OBJ_FMT, "VirtualHardwareSection"));
|
||||
|
||||
if (val.getItems() != null) {
|
||||
for (ResourceAllocationSettingData item : val.getItems()) {
|
||||
if (section.getItems() != null) {
|
||||
for (ResourceAllocationSettingData item : section.getItems()) {
|
||||
checkCimResourceAllocationSettingData(item);
|
||||
}
|
||||
}
|
||||
if (val.getSystem() != null) {
|
||||
checkCimVirtualSystemSettingData(val.getSystem());
|
||||
if (section.getSystem() != null) {
|
||||
checkCimVirtualSystemSettingData(section.getSystem());
|
||||
}
|
||||
|
||||
checkOvfSectionType(val);
|
||||
// Check parent type
|
||||
checkOvfSectionType(section);
|
||||
}
|
||||
|
||||
private static void checkCimVirtualSystemSettingData(VirtualSystemSettingData val) {
|
||||
// TODO Could do more assertions...
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJECT_FMT, "VirtualSystemSettingData", ""));
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJ_FMT, "VirtualSystemSettingData"));
|
||||
}
|
||||
|
||||
private static void checkCimResourceAllocationSettingData(ResourceAllocationSettingData val) {
|
||||
// TODO Could do more assertions...
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJECT_FMT, "ResouorceAllocatoinSettingData", ""));
|
||||
assertNotNull(val, String.format(NOT_NULL_OBJ_FMT, "ResouorceAllocatoinSettingData"));
|
||||
}
|
||||
|
||||
public static void checkAdminVdc(AdminVdc vdc) {
|
||||
|
|
|
@ -19,7 +19,6 @@
|
|||
package org.jclouds.vcloud.director.v1_5.features;
|
||||
|
||||
import static org.jclouds.vcloud.director.v1_5.VCloudDirectorLiveTestConstants.CONDITION_FMT;
|
||||
import static org.jclouds.vcloud.director.v1_5.VCloudDirectorLiveTestConstants.ENTITY_CONDITION;
|
||||
import static org.jclouds.vcloud.director.v1_5.VCloudDirectorLiveTestConstants.ENTITY_EQUAL;
|
||||
import static org.jclouds.vcloud.director.v1_5.VCloudDirectorLiveTestConstants.ENTITY_NON_NULL;
|
||||
import static org.jclouds.vcloud.director.v1_5.VCloudDirectorLiveTestConstants.OBJ_FIELD_EQ;
|
||||
|
@ -29,10 +28,18 @@ import static org.jclouds.vcloud.director.v1_5.VCloudDirectorMediaType.MEDIA;
|
|||
import static org.jclouds.vcloud.director.v1_5.domain.Checks.checkControlAccessParams;
|
||||
import static org.jclouds.vcloud.director.v1_5.domain.Checks.checkGuestCustomizationSection;
|
||||
import static org.jclouds.vcloud.director.v1_5.domain.Checks.checkLeaseSettingsSection;
|
||||
import static org.jclouds.vcloud.director.v1_5.domain.Checks.checkMetadataFor;
|
||||
import static org.jclouds.vcloud.director.v1_5.domain.Checks.checkNetworkConfigSection;
|
||||
import static org.jclouds.vcloud.director.v1_5.domain.Checks.checkNetworkConnectionSection;
|
||||
import static org.jclouds.vcloud.director.v1_5.domain.Checks.checkNetworkSection;
|
||||
import static org.jclouds.vcloud.director.v1_5.domain.Checks.checkOperatingSystemSection;
|
||||
import static org.jclouds.vcloud.director.v1_5.domain.Checks.checkOwner;
|
||||
import static org.jclouds.vcloud.director.v1_5.domain.Checks.checkProductSectionList;
|
||||
import static org.jclouds.vcloud.director.v1_5.domain.Checks.checkRASD;
|
||||
import static org.jclouds.vcloud.director.v1_5.domain.Checks.checkRasdItemsList;
|
||||
import static org.jclouds.vcloud.director.v1_5.domain.Checks.checkRuntimeInfoSection;
|
||||
import static org.jclouds.vcloud.director.v1_5.domain.Checks.checkScreenTicket;
|
||||
import static org.jclouds.vcloud.director.v1_5.domain.Checks.checkStartupSection;
|
||||
import static org.jclouds.vcloud.director.v1_5.domain.Checks.checkVApp;
|
||||
import static org.jclouds.vcloud.director.v1_5.domain.Checks.checkVirtualHardwareSection;
|
||||
import static org.testng.Assert.assertEquals;
|
||||
|
@ -43,6 +50,8 @@ import static org.testng.Assert.fail;
|
|||
|
||||
import java.io.IOException;
|
||||
import java.net.URI;
|
||||
import java.util.Calendar;
|
||||
import java.util.Date;
|
||||
import java.util.Map;
|
||||
import java.util.Random;
|
||||
import java.util.Set;
|
||||
|
@ -74,6 +83,7 @@ import org.jclouds.vcloud.director.v1_5.domain.Reference;
|
|||
import org.jclouds.vcloud.director.v1_5.domain.RelocateParams;
|
||||
import org.jclouds.vcloud.director.v1_5.domain.ResourceEntityType.Status;
|
||||
import org.jclouds.vcloud.director.v1_5.domain.RuntimeInfoSection;
|
||||
import org.jclouds.vcloud.director.v1_5.domain.ScreenTicket;
|
||||
import org.jclouds.vcloud.director.v1_5.domain.Task;
|
||||
import org.jclouds.vcloud.director.v1_5.domain.UndeployVAppParams;
|
||||
import org.jclouds.vcloud.director.v1_5.domain.VApp;
|
||||
|
@ -86,6 +96,8 @@ import org.jclouds.vcloud.director.v1_5.domain.ovf.OperatingSystemSection;
|
|||
import org.jclouds.vcloud.director.v1_5.domain.ovf.RASD;
|
||||
import org.jclouds.vcloud.director.v1_5.domain.ovf.StartupSection;
|
||||
import org.jclouds.vcloud.director.v1_5.domain.ovf.VirtualHardwareSection;
|
||||
import org.jclouds.vcloud.director.v1_5.domain.query.QueryResultRecordType;
|
||||
import org.jclouds.vcloud.director.v1_5.domain.query.QueryResultRecords;
|
||||
import org.jclouds.vcloud.director.v1_5.internal.BaseVCloudDirectorClientLiveTest;
|
||||
import org.jclouds.vcloud.director.v1_5.predicates.ReferenceTypePredicates;
|
||||
import org.jclouds.xml.internal.JAXBParser;
|
||||
|
@ -101,7 +113,6 @@ import com.google.common.base.Throwables;
|
|||
import com.google.common.collect.ImmutableMap;
|
||||
import com.google.common.collect.ImmutableSet;
|
||||
import com.google.common.collect.Iterables;
|
||||
import com.google.common.collect.Maps;
|
||||
|
||||
/**
|
||||
* Tests behavior of {@code VAppClient}
|
||||
|
@ -130,8 +141,6 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
* Objects shared between tests.
|
||||
*/
|
||||
|
||||
private JAXBParser parser;
|
||||
|
||||
private Vdc vdc;
|
||||
private VApp vApp;
|
||||
private VAppTemplate vAppTemplate;
|
||||
|
@ -147,8 +156,6 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
vAppTemplateClient = context.getApi().getVAppTemplateClient();
|
||||
vdcClient = context.getApi().getVdcClient();
|
||||
metadataClient = vAppClient.getMetadataClient();
|
||||
|
||||
parser = new JAXBParser();
|
||||
}
|
||||
|
||||
@BeforeClass(inheritGroups = true)
|
||||
|
@ -159,34 +166,7 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
vAppTemplate = vAppTemplateClient.getVAppTemplate(vAppTemplateURI);
|
||||
assertNotNull(vAppTemplate, String.format(ENTITY_NON_NULL, VAPP_TEMPLATE));
|
||||
|
||||
// Delete the test-vapp VApp if present
|
||||
Iterable<Reference> vApps = Iterables.filter(
|
||||
vdc.getResourceEntities().getResourceEntities(),
|
||||
Predicates.and(
|
||||
ReferenceTypePredicates.<Reference>typeEquals(VCloudDirectorMediaType.VAPP),
|
||||
Predicates.or(
|
||||
ReferenceTypePredicates.<Reference>nameEquals("test-vapp"),
|
||||
ReferenceTypePredicates.<Reference>nameEquals("new-name")
|
||||
)
|
||||
)
|
||||
);
|
||||
if (vApps != null && !Iterables.isEmpty(vApps)) {
|
||||
for (Reference each : vApps) {
|
||||
VApp found = vAppClient.getVApp(each.getHref());
|
||||
// debug(found);
|
||||
if (found.getStatus().equals(Status.POWERED_ON.getValue())) {
|
||||
Task shutdownTask = vAppClient.shutdown(found.getHref());
|
||||
retryTaskSuccess.apply(shutdownTask);
|
||||
}
|
||||
if (found.isDeployed()) {
|
||||
UndeployVAppParams params = UndeployVAppParams.builder().build();
|
||||
Task undeployTask = vAppClient.undeploy(vApp.getHref(), params);
|
||||
retryTaskSuccess.apply(undeployTask);
|
||||
}
|
||||
Task deleteTask = vAppClient.deleteVApp(found.getHref());
|
||||
retryTaskSuccess.apply(deleteTask);
|
||||
}
|
||||
}
|
||||
cleanUp();
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -205,10 +185,15 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
|
||||
// Check the retrieved object is well formed
|
||||
checkVApp(vApp);
|
||||
debug(vApp);
|
||||
|
||||
// Check the required fields are set
|
||||
assertEquals(vApp.isDeployed(), Boolean.FALSE, String.format(OBJ_FIELD_EQ, VAPP, "deployed", "FALSE", vApp.isDeployed().toString()));
|
||||
// TODO others
|
||||
assertEquals(vApp.getName(), "test-vapp", String.format(OBJ_FIELD_EQ, VAPP, "name", "test-vapp", vApp.getName()));
|
||||
assertEquals(vApp.getDescription(), "Test VApp", String.format(OBJ_FIELD_EQ, VAPP, "Description", "Test VApp", vApp.getDescription()));
|
||||
|
||||
// TODO instantiationParams instantiationParams()
|
||||
// TODO source.href vAppTemplateURI
|
||||
|
||||
// Check status
|
||||
Status poweredOffStatus = Status.POWERED_OFF;
|
||||
|
@ -284,8 +269,8 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
vApp = vAppClient.getVApp(vApp.getHref());
|
||||
|
||||
// Check status
|
||||
Status poweredOnStatus = Status.POWERED_ON;
|
||||
assertEquals(vApp.getStatus(), poweredOnStatus.getValue(), String.format(OBJ_FIELD_EQ, VAPP, "status", poweredOnStatus.toString(), Status.fromValue(vApp.getStatus()).toString()));
|
||||
Status poweredOffStatus = Status.POWERED_OFF;
|
||||
assertEquals(vApp.getStatus(), poweredOffStatus.getValue(), String.format(OBJ_FIELD_EQ, VAPP, "status", poweredOffStatus.toString(), Status.fromValue(vApp.getStatus()).toString()));
|
||||
}
|
||||
|
||||
@Test(testName = "POST /vApp/{id}/power/action/shutdown", dependsOnMethods = { "testReboot" })
|
||||
|
@ -381,7 +366,10 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
|
||||
// The method under test
|
||||
ControlAccessParams modified = vAppClient.controlAccess(vApp.getHref(), params);
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkControlAccessParams(modified);
|
||||
// Check the required fields are set
|
||||
assertEquals(modified, params, String.format(ENTITY_EQUAL, "ControlAccessParams"));
|
||||
}
|
||||
|
||||
|
@ -394,7 +382,11 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
|
||||
// The method under test
|
||||
ControlAccessParams modified = vAppClient.controlAccess(vApp.getHref(), params);
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkControlAccessParams(modified);
|
||||
|
||||
// Check entities are equal
|
||||
assertEquals(modified, params, String.format(ENTITY_EQUAL, "ControlAccessParams"));
|
||||
}
|
||||
|
||||
|
@ -445,8 +437,10 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
|
||||
@Test(testName = "POST /vApp/{id}/action/relocate", dependsOnMethods = { "testGetVApp" })
|
||||
public void testRelocate() {
|
||||
RelocateParams params = RelocateParams.builder()
|
||||
.build();
|
||||
// Relocate to the first available datastore
|
||||
QueryResultRecords records = context.getApi().getQueryClient().query("datastore", "fields==name");
|
||||
QueryResultRecordType datastore = Iterables.get(records.getRecords(), 0);
|
||||
RelocateParams params = RelocateParams.builder().datastore(Reference.builder().href(datastore.getHref()).build()).build();
|
||||
|
||||
// The method under test
|
||||
Task relocate = vAppClient.relocate(vApp.getHref(), params);
|
||||
|
@ -464,6 +458,8 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
public void testGetControlAccess() {
|
||||
// The method under test
|
||||
ControlAccessParams controlAccess = vAppClient.getControlAccess(vApp.getHref());
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkControlAccessParams(controlAccess);
|
||||
}
|
||||
|
||||
|
@ -471,63 +467,115 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
public void testGetGuestCustomizationSection() {
|
||||
// The method under test
|
||||
GuestCustomizationSection section = vAppClient.getGuestCustomizationSection(vApp.getHref());
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkGuestCustomizationSection(section);
|
||||
}
|
||||
|
||||
@Test(testName = "PUT /vApp/{id}/guestCustomizationSection", dependsOnMethods = { "testGetGuestCustomizationSection" })
|
||||
public void testModifyGuestCustomizationSection() {
|
||||
GuestCustomizationSection section = vAppClient.getGuestCustomizationSection(vApp.getHref());
|
||||
// section.setX()
|
||||
// Copy existing section and update fields
|
||||
GuestCustomizationSection oldSection = vAppClient.getGuestCustomizationSection(vApp.getHref());
|
||||
GuestCustomizationSection newSection = oldSection.toBuilder()
|
||||
.adminPassword("password")
|
||||
.build();
|
||||
|
||||
// The method under test
|
||||
Task modifyGuestCustomizationSection = vAppClient.modifyGuestCustomizationSection(vApp.getHref(), section);
|
||||
Task modifyGuestCustomizationSection = vAppClient.modifyGuestCustomizationSection(vApp.getHref(), newSection);
|
||||
assertTrue(retryTaskSuccess.apply(modifyGuestCustomizationSection), String.format(TASK_COMPLETE_TIMELY, "modifyGuestCustomizationSection"));
|
||||
|
||||
// Retrieve the modified section
|
||||
GuestCustomizationSection modified = vAppClient.getGuestCustomizationSection(vApp.getHref());
|
||||
// assertEquals(modified.getX, "");
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkGuestCustomizationSection(modified);
|
||||
|
||||
// Check the modified section fields are set correctly
|
||||
assertEquals(modified.getAdminPassword(), "password");
|
||||
assertEquals(modified, newSection);
|
||||
}
|
||||
|
||||
@Test(testName = "GET /vApp/{id}/leaseSettingsSection", dependsOnMethods = { "testGetVApp" })
|
||||
public void testGetLeaseSettingsSection() {
|
||||
// The method under test
|
||||
LeaseSettingsSection section = vAppClient.getLeaseSettingsSection(vApp.getHref());
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkLeaseSettingsSection(section);
|
||||
}
|
||||
|
||||
@Test(testName = "PUT /vApp/{id}/leaseSettingsSection", dependsOnMethods = { "testGetLeaseSettingsSection" })
|
||||
public void testModifyLeaseSettingsSection() {
|
||||
LeaseSettingsSection section = vAppClient.getLeaseSettingsSection(vApp.getHref());
|
||||
|
||||
// section.setX()
|
||||
// Copy existing section
|
||||
LeaseSettingsSection oldSection = vAppClient.getLeaseSettingsSection(vApp.getHref());
|
||||
LeaseSettingsSection newSection = oldSection.toBuilder().build();
|
||||
|
||||
// The method under test
|
||||
Task modifyLeaseSettingsSection = vAppClient.modifyLeaseSettingsSection(vApp.getHref(), section);
|
||||
Task modifyLeaseSettingsSection = vAppClient.modifyLeaseSettingsSection(vApp.getHref(), newSection);
|
||||
assertTrue(retryTaskSuccess.apply(modifyLeaseSettingsSection), String.format(TASK_COMPLETE_TIMELY, "modifyLeaseSettingsSection"));
|
||||
|
||||
// Retrieve the modified section
|
||||
LeaseSettingsSection modified = vAppClient.getLeaseSettingsSection(vApp.getHref());
|
||||
// assertEquals(modified.getX, "");
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkLeaseSettingsSection(modified);
|
||||
|
||||
// Check the date fields
|
||||
if (modified.getDeploymentLeaseExpiration() != null) {
|
||||
assertTrue(modified.getDeploymentLeaseExpiration().after(newSection.getDeploymentLeaseExpiration()),
|
||||
String.format("The new deploymentLeaseExpiration timestamp must be later than the original: %s > %s",
|
||||
dateService.iso8601DateFormat(modified.getDeploymentLeaseExpiration()),
|
||||
dateService.iso8601DateFormat(newSection.getDeploymentLeaseExpiration())));
|
||||
}
|
||||
if (modified.getStorageLeaseExpiration() != null) {
|
||||
assertTrue(modified.getStorageLeaseExpiration().after(newSection.getStorageLeaseExpiration()),
|
||||
String.format("The new storageLeaseExpiration timestamp must be later than the original: %s > %s",
|
||||
dateService.iso8601DateFormat(modified.getStorageLeaseExpiration()),
|
||||
dateService.iso8601DateFormat(newSection.getStorageLeaseExpiration())));
|
||||
}
|
||||
|
||||
// FIXME "Error: validation error : EntityRef has incorrect type, expected type is com.vmware.vcloud.entity.vm."
|
||||
@Test(testName = "PUT /vApp/{id}/media/action/insertMedia", dependsOnMethods = { "testGetVApp" })
|
||||
// Reset the date fields
|
||||
modified = modified.toBuilder()
|
||||
.deploymentLeaseExpiration(null)
|
||||
.storageLeaseExpiration(null)
|
||||
.build();
|
||||
newSection = newSection.toBuilder()
|
||||
.deploymentLeaseExpiration(null)
|
||||
.storageLeaseExpiration(null)
|
||||
.build();
|
||||
|
||||
// Check the section was modified correctly
|
||||
assertEquals(modified, newSection, String.format(ENTITY_EQUAL, "LeaseSettingsSection"));
|
||||
}
|
||||
|
||||
// FIXME "Error: The requested operation on media "com.vmware.vcloud.entity.media:abfcb4b7-809f-4b50-a0aa-8c97bf09a5b0" is not supported in the current state."
|
||||
@Test(testName = "PUT /vApp/{id}/media/action/insertMedia", dependsOnMethods = { "testPowerOnVApp" })
|
||||
public void testInsertMedia() {
|
||||
// Setup media params from configured media id
|
||||
MediaInsertOrEjectParams params = MediaInsertOrEjectParams.builder()
|
||||
.media(Reference.builder().href(mediaURI).type(MEDIA).build())
|
||||
.build();
|
||||
|
||||
// Get URI for child VM
|
||||
URI vmURI = Iterables.getOnlyElement(vApp.getChildren().getVms()).getHref();
|
||||
|
||||
// The method under test
|
||||
Task insertMedia = vAppClient.insertMedia(vApp.getHref(), params);
|
||||
Task insertMedia = vAppClient.insertMedia(vmURI, params);
|
||||
assertTrue(retryTaskSuccess.apply(insertMedia), String.format(TASK_COMPLETE_TIMELY, "insertMedia"));
|
||||
}
|
||||
|
||||
@Test(testName = "PUT /vApp/{id}/media/action/ejectMedia", dependsOnMethods = { "testInsertMedia" })
|
||||
public void testEjectMedia() {
|
||||
// Setup media params from configured media id
|
||||
MediaInsertOrEjectParams params = MediaInsertOrEjectParams.builder()
|
||||
.media(Reference.builder().href(mediaURI).type(MEDIA).build())
|
||||
.build();
|
||||
|
||||
// Get URI for child VM
|
||||
URI vmURI = Iterables.getOnlyElement(vApp.getChildren().getVms()).getHref();
|
||||
|
||||
// The method under test
|
||||
Task ejectMedia = vAppClient.ejectMedia(vApp.getHref(), params);
|
||||
Task ejectMedia = vAppClient.ejectMedia(vmURI, params);
|
||||
assertTrue(retryTaskSuccess.apply(ejectMedia), String.format(TASK_COMPLETE_TIMELY, "ejectMedia"));
|
||||
}
|
||||
|
||||
|
@ -535,76 +583,130 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
public void testGetNetworkConfigSection() {
|
||||
// The method under test
|
||||
NetworkConfigSection section = vAppClient.getNetworkConfigSection(vApp.getHref());
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkNetworkConfigSection(section);
|
||||
}
|
||||
|
||||
@Test(testName = "PUT /vApp/{id}/networkConfigSection", dependsOnMethods = { "testGetNetworkConfigSection" })
|
||||
public void testModifyNetworkConfigSection() {
|
||||
NetworkConfigSection section = vAppClient.getNetworkConfigSection(vApp.getHref());
|
||||
|
||||
// section.setX()
|
||||
// Copy existing section and update fields
|
||||
NetworkConfigSection oldSection = vAppClient.getNetworkConfigSection(vApp.getHref());
|
||||
NetworkConfigSection newSection = oldSection.toBuilder()
|
||||
.build();
|
||||
|
||||
// The method under test
|
||||
Task modifyNetworkConfigSection = vAppClient.modifyNetworkConfigSection(vApp.getHref(), section);
|
||||
Task modifyNetworkConfigSection = vAppClient.modifyNetworkConfigSection(vApp.getHref(), newSection);
|
||||
assertTrue(retryTaskSuccess.apply(modifyNetworkConfigSection), String.format(TASK_COMPLETE_TIMELY, "modifyNetworkConfigSection"));
|
||||
|
||||
// Retrieve the modified section
|
||||
NetworkConfigSection modified = vAppClient.getNetworkConfigSection(vApp.getHref());
|
||||
// assertEquals(modified.getX, "");
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkNetworkConfigSection(modified);
|
||||
|
||||
// Check the modified section fields are set correctly
|
||||
// assertEquals(modified.getX(), "");
|
||||
|
||||
// Check the section was modified correctly
|
||||
assertEquals(modified, newSection, String.format(ENTITY_EQUAL, "NetworkConfigSection"));
|
||||
}
|
||||
|
||||
@Test(testName = "GET /vApp/{id}/networkConnectionSection", dependsOnMethods = { "testGetVApp" })
|
||||
public void testGetNetworkConnectionSection() {
|
||||
// Get URI for child VM
|
||||
URI vmURI = Iterables.getOnlyElement(vApp.getChildren().getVms()).getHref();
|
||||
|
||||
// The method under test
|
||||
NetworkConnectionSection section = vAppClient.getNetworkConnectionSection(vApp.getHref());
|
||||
NetworkConnectionSection section = vAppClient.getNetworkConnectionSection(vmURI);
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkNetworkConnectionSection(section);
|
||||
}
|
||||
|
||||
@Test(testName = "PUT /vApp/{id}/networkConnectionSection", dependsOnMethods = { "testGetNetworkConnectionSection" })
|
||||
public void testModifyNetworkConnectionSection() {
|
||||
NetworkConnectionSection section = vAppClient.getNetworkConnectionSection(vApp.getHref());
|
||||
// Get URI for child VM
|
||||
URI vmURI = Iterables.getOnlyElement(vApp.getChildren().getVms()).getHref();
|
||||
|
||||
// section.setX()
|
||||
// Copy existing section and update fields
|
||||
NetworkConnectionSection oldSection = vAppClient.getNetworkConnectionSection(vmURI);
|
||||
NetworkConnectionSection newSection = oldSection.toBuilder()
|
||||
// .x("")
|
||||
.build();
|
||||
|
||||
// The method under test
|
||||
Task modifyNetworkConnectionSection = vAppClient.modifyNetworkConnectionSection(vApp.getHref(), section);
|
||||
Task modifyNetworkConnectionSection = vAppClient.modifyNetworkConnectionSection(vmURI, newSection);
|
||||
assertTrue(retryTaskSuccess.apply(modifyNetworkConnectionSection), String.format(TASK_COMPLETE_TIMELY, "modifyNetworkConnectionSection"));
|
||||
|
||||
NetworkConnectionSection modified = vAppClient.getNetworkConnectionSection(vApp.getHref());
|
||||
// assertEquals(modified.getX, "");
|
||||
// Retrieve the modified section
|
||||
NetworkConnectionSection modified = vAppClient.getNetworkConnectionSection(vmURI);
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkNetworkConnectionSection(modified);
|
||||
|
||||
// Check the modified section fields are set correctly
|
||||
// assertEquals(modified.getX(), "");
|
||||
|
||||
// Check the section was modified correctly
|
||||
assertEquals(modified, newSection, String.format(ENTITY_EQUAL, "NetworkConnectionSection"));
|
||||
}
|
||||
|
||||
@Test(testName = "GET /vApp/{id}/networkSection", dependsOnMethods = { "testGetVApp" })
|
||||
public void testGetNetworkSection() {
|
||||
// The method under test
|
||||
NetworkSection section = vAppClient.getNetworkSection(vApp.getHref());
|
||||
// checkNetworkSection(section);
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkNetworkSection(section);
|
||||
}
|
||||
|
||||
@Test(testName = "GET /vApp/{id}/operatingSystemSection", dependsOnMethods = { "testGetVApp" })
|
||||
public void testGetOperatingSystemSection() {
|
||||
// Get URI for child VM
|
||||
URI vmURI = Iterables.getOnlyElement(vApp.getChildren().getVms()).getHref();
|
||||
|
||||
// The method under test
|
||||
OperatingSystemSection section = vAppClient.getOperatingSystemSection(vApp.getHref());
|
||||
// checkOperatingSystemSection(section);
|
||||
OperatingSystemSection section = vAppClient.getOperatingSystemSection(vmURI);
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkOperatingSystemSection(section);
|
||||
}
|
||||
|
||||
@Test(testName = "PUT /vApp/{id}/operatingSystemSection", dependsOnMethods = { "testGetOperatingSystemSection" })
|
||||
public void testModifyOperatingSystemSection() {
|
||||
OperatingSystemSection section = vAppClient.getOperatingSystemSection(vApp.getHref());
|
||||
// Get URI for child VM
|
||||
URI vmURI = Iterables.getOnlyElement(vApp.getChildren().getVms()).getHref();
|
||||
|
||||
// section.setX()
|
||||
// Copy existing section and update fields
|
||||
OperatingSystemSection oldSection = vAppClient.getOperatingSystemSection(vmURI);
|
||||
OperatingSystemSection newSection = oldSection.toBuilder()
|
||||
.description("Changed OperatingSystemSection Description")
|
||||
.build();
|
||||
|
||||
// The method under test
|
||||
Task modifySection = vAppClient.modifyOperatingSystemSection(vApp.getHref(), section);
|
||||
assertTrue(retryTaskSuccess.apply(modifySection), String.format(TASK_COMPLETE_TIMELY, "modifySection"));
|
||||
Task modifyOperatingSystemSection = vAppClient.modifyOperatingSystemSection(vmURI, newSection);
|
||||
assertTrue(retryTaskSuccess.apply(modifyOperatingSystemSection), String.format(TASK_COMPLETE_TIMELY, "modifyOperatingSystemSection"));
|
||||
|
||||
OperatingSystemSection modified = vAppClient.getOperatingSystemSection(vApp.getHref());
|
||||
// assertEquals(modified.getX, "");
|
||||
// Retrieve the modified section
|
||||
OperatingSystemSection modified = vAppClient.getOperatingSystemSection(vmURI);
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkOperatingSystemSection(modified);
|
||||
|
||||
// Check the modified section fields are set correctly
|
||||
assertEquals(modified.getDescription(), newSection.getDescription());
|
||||
|
||||
// Check the section was modified correctly
|
||||
assertEquals(modified, newSection, String.format(ENTITY_EQUAL, "OperatingSystemSection"));
|
||||
}
|
||||
|
||||
@Test(testName = "GET /vApp/{id}/owner", dependsOnMethods = { "testGetVApp" })
|
||||
public void testGetOwner() {
|
||||
// The method under test
|
||||
Owner owner = vAppClient.getOwner(vApp.getHref());
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkOwner(owner);
|
||||
}
|
||||
|
||||
|
@ -617,7 +719,10 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
// The method under test
|
||||
vAppClient.modifyOwner(vApp.getHref(), newOwner);
|
||||
|
||||
// Get the new VApp owner
|
||||
Owner modified = vAppClient.getOwner(vApp.getHref());
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkOwner(modified);
|
||||
|
||||
// Check the href fields match
|
||||
|
@ -628,6 +733,8 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
public void testGetProductSections() {
|
||||
// The method under test
|
||||
ProductSectionList sectionList = vAppClient.getProductSections(vApp.getHref());
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkProductSectionList(sectionList);
|
||||
}
|
||||
|
||||
|
@ -650,6 +757,8 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
// TODO how to test?
|
||||
// The method under test
|
||||
VmPendingQuestion question = vAppClient.getPendingQuestion(vApp.getHref());
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
// checkQuestion(question);
|
||||
}
|
||||
|
||||
|
@ -668,69 +777,102 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
public void testGetRuntimeInfoSection() {
|
||||
// The method under test
|
||||
RuntimeInfoSection section = vAppClient.getRuntimeInfoSection(vApp.getHref());
|
||||
// checkRuntimeInfoSection(section);
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkRuntimeInfoSection(section);
|
||||
}
|
||||
|
||||
@Test(testName = "GET /vApp/{id}/screen", dependsOnMethods = { "testGetVApp" })
|
||||
public void testGetScreenImage() {
|
||||
// The method under test
|
||||
byte[] image = vAppClient.getScreenImage(vApp.getHref());
|
||||
// TODO how to check?
|
||||
|
||||
// Check returned bytes against PNG header magic number
|
||||
byte[] pngHeaderBytes = new byte[] { (byte) 0x89, 0x50, 0x4E, 0x47, 0x0D, 0x0A, 0x1A, 0x0A };
|
||||
assertNotNull(image);
|
||||
assertTrue(image.length > pngHeaderBytes.length);
|
||||
for (int i = 0; i < pngHeaderBytes.length; i++) {
|
||||
assertEquals(image[i], pngHeaderBytes[i], String.format("Image differs from PNG format at byte %d of header", i));
|
||||
}
|
||||
}
|
||||
|
||||
@Test(testName = "GET /vApp/{id}/screen/action/acquireTicket", dependsOnMethods = { "testGetVApp" })
|
||||
public void testGetScreenTicket() {
|
||||
// The method under test
|
||||
byte[] image = vAppClient.getScreenImage(vApp.getHref());
|
||||
// TODO how to check?
|
||||
ScreenTicket ticket = vAppClient.getScreenTicket(vApp.getHref());
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkScreenTicket(ticket);
|
||||
}
|
||||
|
||||
@Test(testName = "GET /vApp/{id}/startupSection", dependsOnMethods = { "testGetVApp" })
|
||||
public void testGetStartupSection() {
|
||||
// The method under test
|
||||
StartupSection section = vAppClient.getStartupSection(vApp.getHref());
|
||||
// checkStartupSection(section);
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkStartupSection(section);
|
||||
}
|
||||
|
||||
@Test(testName = "PUT /vApp/{id}/startupSection", dependsOnMethods = { "testGetStartupSection" })
|
||||
public void testModifyStartupSection() {
|
||||
StartupSection section = vAppClient.getStartupSection(vApp.getHref());
|
||||
|
||||
// section.setX()
|
||||
// Copy existing section and update fields
|
||||
StartupSection oldSection = vAppClient.getStartupSection(vApp.getHref());
|
||||
StartupSection newSection = oldSection.toBuilder()
|
||||
// .x("")
|
||||
.build();
|
||||
|
||||
// The method under test
|
||||
Task modifyStartupSection = vAppClient.modifyStartupSection(vApp.getHref(), section);
|
||||
Task modifyStartupSection = vAppClient.modifyStartupSection(vApp.getHref(), newSection);
|
||||
assertTrue(retryTaskSuccess.apply(modifyStartupSection), String.format(TASK_COMPLETE_TIMELY, "modifyStartupSection"));
|
||||
|
||||
// Retrieve the modified section
|
||||
StartupSection modified = vAppClient.getStartupSection(vApp.getHref());
|
||||
// assertEquals(modified.getX, "");
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkStartupSection(modified);
|
||||
|
||||
// Check the modified section fields are set correctly
|
||||
// assertEquals(modified.getX(), "");
|
||||
assertEquals(modified, newSection);
|
||||
}
|
||||
|
||||
@Test(testName = "GET /vApp/{id}/virtualHardwareSection", dependsOnMethods = { "testGetVApp" })
|
||||
public void testGetVirtualHardwareSection() {
|
||||
// Method under test
|
||||
VirtualHardwareSection hardware = vAppClient.getVirtualHardwareSection(vApp.getHref());
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkVirtualHardwareSection(hardware);
|
||||
}
|
||||
|
||||
@Test(testName = "PUT /vApp/{id}/virtualHardwareSection", dependsOnMethods = { "testGetVirtualHardwareSection" })
|
||||
public void testModifyVirtualHardwareSection() {
|
||||
VirtualHardwareSection hardware = vAppClient.getVirtualHardwareSection(vApp.getHref());
|
||||
hardware.setInfo("New Info");
|
||||
// Copy existing section and update fields
|
||||
VirtualHardwareSection oldSection = vAppClient.getVirtualHardwareSection(vApp.getHref());
|
||||
VirtualHardwareSection newSection = oldSection.toBuilder()
|
||||
// .x("")
|
||||
.build();
|
||||
|
||||
// Method under test
|
||||
Task modifyVirtualHardwareSection = vAppClient.modifyVirtualHardwareSection(vApp.getHref(), hardware);
|
||||
// The method under test
|
||||
Task modifyVirtualHardwareSection = vAppClient.modifyVirtualHardwareSection(vApp.getHref(), newSection);
|
||||
assertTrue(retryTaskSuccess.apply(modifyVirtualHardwareSection), String.format(TASK_COMPLETE_TIMELY, "modifyVirtualHardwareSection"));
|
||||
|
||||
// Retrieve the modified section
|
||||
VirtualHardwareSection modified = vAppClient.getVirtualHardwareSection(vApp.getHref());
|
||||
assertEquals(modified.getInfo(), "New Info");
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkVirtualHardwareSection(modified);
|
||||
|
||||
// Check the modified section fields are set correctly
|
||||
// assertEquals(modified.getX(), "");
|
||||
assertEquals(modified, newSection);
|
||||
}
|
||||
|
||||
@Test(testName = "GET /vApp/{id}/virtualHardwareSection/cpu", dependsOnMethods = { "testGetVirtualHardwareSection" })
|
||||
public void testGetVirtualHardwareSectionCpu() {
|
||||
RASD rasd = vAppClient.getVirtualHardwareSectionCpu(vApp.getHref());
|
||||
// checkRASD(rasd);
|
||||
checkRASD(rasd);
|
||||
}
|
||||
|
||||
@Test(testName = "PUT /vApp/{id}/virtualHardwareSection/cpu", dependsOnMethods = { "testGetVirtualHardwareSectionCpu" })
|
||||
|
@ -742,40 +884,60 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
Task modifyVirtualHardwareSectionCpu = vAppClient.modifyVirtualHardwareSectionCpu(vApp.getHref(), rasd);
|
||||
assertTrue(retryTaskSuccess.apply(modifyVirtualHardwareSectionCpu), String.format(TASK_COMPLETE_TIMELY, "modifyVirtualHardwareSectionCpu"));
|
||||
|
||||
// Retrieve the modified section
|
||||
RASD modified = vAppClient.getVirtualHardwareSectionCpu(vApp.getHref());
|
||||
// assertEquals(modified.getInfo(), "New Info");
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkRASD(modified);
|
||||
|
||||
// assertEquals(modified.getInfo(), "New Info");
|
||||
}
|
||||
|
||||
@Test(testName = "GET /vApp/{id}/virtualHardwareSection/disks", dependsOnMethods = { "testGetVirtualHardwareSection" })
|
||||
public void testGetVirtualHardwareSectionDisks() {
|
||||
RasdItemsList rasdItems = vAppClient.getVirtualHardwareSectionDisks(vApp.getHref());
|
||||
// checkRasdItemsList(rasdItems);
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkRasdItemsList(rasdItems);
|
||||
}
|
||||
|
||||
@Test(testName = "PUT /vApp/{id}/virtualHardwareSection/disks", dependsOnMethods = { "testGetVirtualHardwareSectionDisks" })
|
||||
public void testModifyVirtualHardwareSectionDisks() {
|
||||
RasdItemsList rasdItems = vAppClient.getVirtualHardwareSectionDisks(vApp.getHref());
|
||||
// rasd.setX("New Info");
|
||||
// Copy the existing items list and add a new item
|
||||
RasdItemsList oldRasdItems = vAppClient.getVirtualHardwareSectionDisks(vApp.getHref());
|
||||
RASD item = RASD.builder().build();
|
||||
RasdItemsList newRasdItems = oldRasdItems.toBuilder().item(item).build();
|
||||
|
||||
// Method under test
|
||||
Task modifyVirtualHardwareSectionDisks = vAppClient.modifyVirtualHardwareSectionDisks(vApp.getHref(), rasdItems);
|
||||
Task modifyVirtualHardwareSectionDisks = vAppClient.modifyVirtualHardwareSectionDisks(vApp.getHref(), newRasdItems);
|
||||
assertTrue(retryTaskSuccess.apply(modifyVirtualHardwareSectionDisks), String.format(TASK_COMPLETE_TIMELY, "modifyVirtualHardwareSectionDisks"));
|
||||
|
||||
// Retrieve the modified section
|
||||
RasdItemsList modified = vAppClient.getVirtualHardwareSectionDisks(vApp.getHref());
|
||||
// assertEquals(modified.getInfo(), "New Info");
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkRasdItemsList(modified);
|
||||
|
||||
// Check the modified items list
|
||||
// assertEquals(modified.getX(), "");
|
||||
assertTrue(modified.getItems().contains(item));
|
||||
assertEquals(modified, newRasdItems);
|
||||
}
|
||||
|
||||
@Test(testName = "GET /vApp/{id}/virtualHardwareSection/media", dependsOnMethods = { "testGetVirtualHardwareSection" })
|
||||
public void testGetVirtualHardwareSectionMedia() {
|
||||
RasdItemsList rasdItems = vAppClient.getVirtualHardwareSectionMedia(vApp.getHref());
|
||||
// checkRasdItemsList(rasdItems);
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkRasdItemsList(rasdItems);
|
||||
}
|
||||
|
||||
@Test(testName = "GET /vApp/{id}/virtualHardwareSection/memory", dependsOnMethods = { "testGetVirtualHardwareSection" })
|
||||
public void testGetVirtualHardwareSectionMemory() {
|
||||
RASD rasd = vAppClient.getVirtualHardwareSectionCpu(vApp.getHref());
|
||||
// checkRASD(rasd);
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkRASD(rasd);
|
||||
}
|
||||
|
||||
@Test(testName = "PUT /vApp/{id}/virtualHardwareSection/memory", dependsOnMethods = { "testGetVirtualHardwareSectionMemory" })
|
||||
|
@ -794,65 +956,92 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
@Test(testName = "GET /vApp/{id}/virtualHardwareSection/networkCards", dependsOnMethods = { "testGetVirtualHardwareSection" })
|
||||
public void testGetVirtualHardwareSectionNetworkCards() {
|
||||
RasdItemsList rasdItems = vAppClient.getVirtualHardwareSectionNetworkCards(vApp.getHref());
|
||||
// checkRasdItemsList(rasdItems);
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkRasdItemsList(rasdItems);
|
||||
}
|
||||
|
||||
@Test(testName = "PUT /vApp/{id}/virtualHardwareSection/networkCards", dependsOnMethods = { "testGetVirtualHardwareSectionNetworkCards" })
|
||||
public void testModifyVirtualHardwareSectionNetworkCards() {
|
||||
RasdItemsList rasdItems = vAppClient.getVirtualHardwareSectionNetworkCards(vApp.getHref());
|
||||
// rasd.setX("New Info");
|
||||
// Copy the existing items list and add a new item
|
||||
RasdItemsList oldRasdItems = vAppClient.getVirtualHardwareSectionNetworkCards(vApp.getHref());
|
||||
RASD item = RASD.builder().build();
|
||||
RasdItemsList newRasdItems = oldRasdItems.toBuilder().item(item).build();
|
||||
|
||||
// Method under test
|
||||
Task modifyVirtualHardwareSectionNetworkCards = vAppClient.modifyVirtualHardwareSectionNetworkCards(vApp.getHref(), rasdItems);
|
||||
Task modifyVirtualHardwareSectionNetworkCards = vAppClient.modifyVirtualHardwareSectionNetworkCards(vApp.getHref(), newRasdItems);
|
||||
assertTrue(retryTaskSuccess.apply(modifyVirtualHardwareSectionNetworkCards), String.format(TASK_COMPLETE_TIMELY, "modifyVirtualHardwareSectionNetworkCards"));
|
||||
|
||||
// Retrieve the modified section
|
||||
RasdItemsList modified = vAppClient.getVirtualHardwareSectionNetworkCards(vApp.getHref());
|
||||
// assertEquals(modified.getInfo(), "New Info");
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkRasdItemsList(modified);
|
||||
|
||||
// Check the modified items list
|
||||
// assertEquals(modified.getX(), "");
|
||||
assertTrue(modified.getItems().contains(item));
|
||||
assertEquals(modified, newRasdItems);
|
||||
}
|
||||
|
||||
@Test(testName = "GET /vApp/{id}/virtualHardwareSection/serialPorts", dependsOnMethods = { "testGetVirtualHardwareSection" })
|
||||
public void testGetVirtualHardwareSectionSerialPorts() {
|
||||
RasdItemsList rasdItems = vAppClient.getVirtualHardwareSectionSerialPorts(vApp.getHref());
|
||||
// checkRasdItemsList(rasdItems);
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkRasdItemsList(rasdItems);
|
||||
}
|
||||
|
||||
@Test(testName = "PUT /vApp/{id}/virtualHardwareSection/serialPorts", dependsOnMethods = { "testGetVirtualHardwareSectionSerialPorts" })
|
||||
public void testModifyVirtualHardwareSectionSerialPorts() {
|
||||
RasdItemsList rasdItems = vAppClient.getVirtualHardwareSectionSerialPorts(vApp.getHref());
|
||||
// rasd.setX("New Info");
|
||||
// Copy the existing items list and add a new item
|
||||
RasdItemsList oldRasdItems = vAppClient.getVirtualHardwareSectionSerialPorts(vApp.getHref());
|
||||
RASD item = RASD.builder().build();
|
||||
RasdItemsList newRasdItems = oldRasdItems.toBuilder().item(item).build();
|
||||
|
||||
// Method under test
|
||||
Task modifyVirtualHardwareSectionSerialPorts = vAppClient.modifyVirtualHardwareSectionSerialPorts(vApp.getHref(), rasdItems);
|
||||
Task modifyVirtualHardwareSectionSerialPorts = vAppClient.modifyVirtualHardwareSectionSerialPorts(vApp.getHref(), newRasdItems);
|
||||
assertTrue(retryTaskSuccess.apply(modifyVirtualHardwareSectionSerialPorts), String.format(TASK_COMPLETE_TIMELY, "modifyVirtualHardwareSectionSerialPorts"));
|
||||
|
||||
// Retrieve the modified section
|
||||
RasdItemsList modified = vAppClient.getVirtualHardwareSectionSerialPorts(vApp.getHref());
|
||||
// assertEquals(modified.getInfo(), "New Info");
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
checkRasdItemsList(modified);
|
||||
|
||||
// Check the modified items list
|
||||
// assertEquals(modified.getX(), "");
|
||||
assertTrue(modified.getItems().contains(item));
|
||||
assertEquals(modified, newRasdItems);
|
||||
}
|
||||
|
||||
@Test(testName = "GET /vApp/{id}/metadata", dependsOnMethods = { "testGetVApp" })
|
||||
public void testGetMetadata() {
|
||||
Metadata metadata = metadataClient.getMetadata(vApp.getHref());
|
||||
|
||||
Checks.checkMetadataFor(VAPP, metadata);
|
||||
// Check the retrieved object is well formed
|
||||
checkMetadataFor(VAPP, metadata);
|
||||
}
|
||||
|
||||
@Test(testName = "PUT & GET /vApp/{id}/metadata", dependsOnMethods = { "testGetMetadata" })
|
||||
public void testSetAndGetMetadataValue() {
|
||||
// Store a value
|
||||
String key = ""+random.nextInt();
|
||||
String value = ""+random.nextInt();
|
||||
String key = Integer.toString(random.nextInt());
|
||||
String value = Integer.toString(random.nextInt());
|
||||
MetadataValue metadataValue = MetadataValue.builder().value(value).build();
|
||||
metadataClient.setMetadata(vApp.getHref(), key, metadataValue);
|
||||
|
||||
// Retrieve the value, and assert it was set correctly
|
||||
MetadataValue newMetadataValue = metadataClient.getMetadataValue(vApp.getHref(), key);
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
Checks.checkMetadataValueFor(VAPP, newMetadataValue, value);
|
||||
}
|
||||
|
||||
@Test(testName = "DELETE /vApp/{id}/metadata/{key}", dependsOnMethods = { "testSetAndGetMetadataValue" })
|
||||
public void testDeleteMetadataEntry() {
|
||||
// Store a value, to be deleted
|
||||
String key = ""+random.nextInt();
|
||||
String key = Integer.toString(random.nextInt());
|
||||
MetadataValue metadataValue = MetadataValue.builder().value("myval").build();
|
||||
metadataClient.setMetadata(vApp.getHref(), key, metadataValue);
|
||||
|
||||
|
@ -862,32 +1051,33 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
|
||||
// Confirm the entry has been deleted
|
||||
Metadata newMetadata = metadataClient.getMetadata(vApp.getHref());
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
Checks.checkMetadataKeyAbsentFor(VAPP, newMetadata, key);
|
||||
}
|
||||
|
||||
@Test(testName = "POST /vApp/{id}/metadata", dependsOnMethods = { "testGetMetadata" })
|
||||
public void testMergeMetadata() {
|
||||
Metadata oldMetadata = metadataClient.getMetadata(vApp.getHref());
|
||||
Map<String,String> oldMetadataMap = Checks.metadataToMap(oldMetadata);
|
||||
Map<String, String> oldMetadataMap = Checks.metadataToMap(oldMetadata);
|
||||
|
||||
// Store a value, to be deleted
|
||||
String key = ""+random.nextInt();
|
||||
String value = ""+random.nextInt();
|
||||
String key = Integer.toString(random.nextInt());
|
||||
String value = Integer.toString(random.nextInt());
|
||||
Metadata addedMetadata = Metadata.builder()
|
||||
.entry(MetadataEntry.builder()
|
||||
.key(key)
|
||||
.value(value)
|
||||
.build())
|
||||
.entry(MetadataEntry.builder().key(key).value(value).build())
|
||||
.build();
|
||||
Task task = metadataClient.mergeMetadata(vApp.getHref(), addedMetadata);
|
||||
retryTaskSuccess.apply(task);
|
||||
|
||||
// Confirm the entry contains everything that was there, and everything that was being added
|
||||
Metadata newMetadata = metadataClient.getMetadata(vApp.getHref());
|
||||
Map<String,String> expectedMetadataMap = ImmutableMap.<String,String>builder()
|
||||
Map<String, String> expectedMetadataMap = ImmutableMap.<String, String> builder()
|
||||
.putAll(oldMetadataMap)
|
||||
.put(key, value)
|
||||
.build();
|
||||
|
||||
// Check the retrieved object is well formed
|
||||
Checks.checkMetadataFor(VAPP, newMetadata, expectedMetadataMap);
|
||||
}
|
||||
|
||||
|
@ -909,14 +1099,52 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
}
|
||||
}
|
||||
|
||||
@AfterClass(groups = { "live" })
|
||||
// NOTE This method is also called by the BeforeClass method setupRequiredClients
|
||||
@AfterClass(alwaysRun = true, description = "Clean up the environment by deleting created VApps named 'test-vapp' or 'new-name'")
|
||||
public void cleanUp() {
|
||||
if (vApp != null) {
|
||||
Task deleteVApp = vAppClient.deleteVApp(vApp.getHref());
|
||||
retryTaskSuccess.apply(deleteVApp);
|
||||
// Find references in the Vdc with the VApp type and named 'test-vapp' or 'new-name'
|
||||
Iterable<Reference> vApps = Iterables.filter(
|
||||
vdc.getResourceEntities().getResourceEntities(),
|
||||
Predicates.and(
|
||||
ReferenceTypePredicates.<Reference>typeEquals(VCloudDirectorMediaType.VAPP),
|
||||
Predicates.or(
|
||||
ReferenceTypePredicates.<Reference>nameEquals("test-vapp"),
|
||||
ReferenceTypePredicates.<Reference>nameEquals("new-name")
|
||||
)
|
||||
)
|
||||
);
|
||||
|
||||
// If we found any references, delete the VApp they point to
|
||||
if (vApps != null && !Iterables.isEmpty(vApps)) {
|
||||
for (Reference each : vApps) {
|
||||
VApp found = vAppClient.getVApp(each.getHref());
|
||||
// debug(found);
|
||||
|
||||
// Shutdown and power off the VApp if necessary
|
||||
if (found.getStatus().equals(Status.POWERED_ON.getValue())) {
|
||||
Task shutdownTask = vAppClient.shutdown(found.getHref());
|
||||
retryTaskSuccess.apply(shutdownTask);
|
||||
}
|
||||
|
||||
// Undeploy the VApp if necessary
|
||||
if (found.isDeployed()) {
|
||||
UndeployVAppParams params = UndeployVAppParams.builder().build();
|
||||
Task undeployTask = vAppClient.undeploy(found.getHref(), params);
|
||||
retryTaskSuccess.apply(undeployTask);
|
||||
}
|
||||
|
||||
// Delete the VApp
|
||||
Task deleteTask = vAppClient.deleteVApp(found.getHref());
|
||||
retryTaskSuccess.apply(deleteTask);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Instantiate a {@link VApp} in a {@link Vdc} using the {@link VAppTemplate} we have configured for the tests.
|
||||
*
|
||||
* @return the VApp that is being instantiated
|
||||
*/
|
||||
private VApp instantiateVApp() {
|
||||
InstantiateVAppTemplateParams instantiate = InstantiateVAppTemplateParams.builder()
|
||||
.name("test-vapp")
|
||||
|
@ -926,7 +1154,6 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
.instantiationParams(instantiationParams())
|
||||
.source(Reference.builder().href(vAppTemplateURI).build())
|
||||
.build();
|
||||
|
||||
// debug(instantiate);
|
||||
|
||||
VApp vAppInstantiated = vdcClient.instantiateVApp(vdcURI, instantiate);
|
||||
|
@ -935,6 +1162,7 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
return vAppInstantiated;
|
||||
}
|
||||
|
||||
/** Build an {@link InstantiationParams} object. */
|
||||
private InstantiationParams instantiationParams() {
|
||||
InstantiationParams instantiationParams = InstantiationParams.builder()
|
||||
.sections(ImmutableSet.of(networkConfigSection()))
|
||||
|
@ -943,6 +1171,7 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
return instantiationParams;
|
||||
}
|
||||
|
||||
/** Build a {@link NetworkConfigSection} object. */
|
||||
private NetworkConfigSection networkConfigSection() {
|
||||
NetworkConfigSection networkConfigSection = NetworkConfigSection.builder()
|
||||
.info("Configuration parameters for logical networks")
|
||||
|
@ -956,8 +1185,11 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
return networkConfigSection;
|
||||
}
|
||||
|
||||
/** Build a {@link NetworkConfiguration} object. */
|
||||
private NetworkConfiguration networkConfiguration() {
|
||||
Set<Reference> networks = vdc.getAvailableNetworks().getNetworks();
|
||||
|
||||
// Look up the network in the Vdc with the id configured for the tests
|
||||
Optional<Reference> parentNetwork = Iterables.tryFind(
|
||||
networks, new Predicate<Reference>() {
|
||||
@Override
|
||||
|
@ -966,10 +1198,12 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
}
|
||||
});
|
||||
|
||||
// Check we actually found a network reference
|
||||
if (!parentNetwork.isPresent()) {
|
||||
fail(String.format("Could not find network %s in vdc", networkURI.toASCIIString()));
|
||||
}
|
||||
|
||||
// Build the configuration object
|
||||
NetworkConfiguration networkConfiguration = NetworkConfiguration.builder()
|
||||
.parentNetwork(parentNetwork.get())
|
||||
.fenceMode("bridged")
|
||||
|
@ -984,9 +1218,9 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
|||
* The XML is output on {@link System#err}.
|
||||
*/
|
||||
private void debug(Object object) {
|
||||
String xml;
|
||||
JAXBParser parser = new JAXBParser();
|
||||
try {
|
||||
xml = parser.toXML(object);
|
||||
String xml = parser.toXML(object);
|
||||
|
||||
System.err.println(Strings.repeat("-", 80));
|
||||
System.err.println(xml);
|
||||
|
|
|
@ -18,12 +18,15 @@
|
|||
*/
|
||||
package org.jclouds.vcloud.director.v1_5.internal;
|
||||
|
||||
import static org.testng.Assert.assertNotNull;
|
||||
|
||||
import java.net.URI;
|
||||
import java.util.Properties;
|
||||
|
||||
import javax.inject.Inject;
|
||||
|
||||
import org.jclouds.compute.BaseVersionedServiceLiveTest;
|
||||
import org.jclouds.date.DateService;
|
||||
import org.jclouds.logging.log4j.config.Log4JLoggingModule;
|
||||
import org.jclouds.predicates.RetryablePredicate;
|
||||
import org.jclouds.rest.RestContext;
|
||||
|
@ -41,6 +44,7 @@ import org.jclouds.vcloud.director.v1_5.domain.Task;
|
|||
import org.jclouds.vcloud.director.v1_5.predicates.ReferenceTypePredicates;
|
||||
import org.jclouds.vcloud.director.v1_5.predicates.TaskSuccess;
|
||||
import org.testng.annotations.BeforeClass;
|
||||
import org.testng.annotations.BeforeGroups;
|
||||
import org.testng.annotations.Listeners;
|
||||
import org.testng.annotations.Test;
|
||||
|
||||
|
@ -50,6 +54,7 @@ import com.google.common.base.Strings;
|
|||
import com.google.common.collect.ImmutableSet;
|
||||
import com.google.common.collect.Iterables;
|
||||
import com.google.common.collect.Lists;
|
||||
import com.google.inject.Guice;
|
||||
import com.google.inject.Module;
|
||||
|
||||
/**
|
||||
|
@ -69,6 +74,14 @@ public abstract class BaseVCloudDirectorClientLiveTest extends BaseVersionedServ
|
|||
provider = "vcloud-director";
|
||||
}
|
||||
|
||||
protected static DateService dateService;
|
||||
|
||||
@BeforeGroups("live")
|
||||
protected static void setupDateService() {
|
||||
dateService = Guice.createInjector().getInstance(DateService.class);
|
||||
assertNotNull(dateService);
|
||||
}
|
||||
|
||||
// NOTE Implement as required to populate xxxClient fields, or NOP
|
||||
public abstract void setupRequiredClients() throws Exception;
|
||||
|
||||
|
|
|
@ -54,7 +54,7 @@ public class BaseVCloudDirectorRestClientExpectTest extends BaseRestClientExpect
|
|||
protected static DateService dateService;
|
||||
|
||||
@BeforeGroups("unit")
|
||||
protected static void setUpInjector() {
|
||||
protected static void setupDateService() {
|
||||
dateService = Guice.createInjector().getInstance(DateService.class);
|
||||
assertNotNull(dateService);
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue