mirror of https://github.com/apache/jclouds.git
Issue 830: Fix get/modifyOperatingSystemSection tests
This commit is contained in:
parent
f90135097f
commit
2af8ec527f
|
@ -28,6 +28,8 @@ public class VCloudDirectorConstants {
|
||||||
/** The XML namespace used by the clients. */
|
/** The XML namespace used by the clients. */
|
||||||
public static final String VCLOUD_1_5_NS = "http://www.vmware.com/vcloud/v1.5";
|
public static final String VCLOUD_1_5_NS = "http://www.vmware.com/vcloud/v1.5";
|
||||||
|
|
||||||
|
public static final String VCLOUD_VMW_NS = "ihttp://www.vmware.com/schema/ovf";
|
||||||
|
|
||||||
public static final String VCLOUD_OVF_NS = "http://schemas.dmtf.org/ovf/envelope/1";
|
public static final String VCLOUD_OVF_NS = "http://schemas.dmtf.org/ovf/envelope/1";
|
||||||
|
|
||||||
public static final String VCLOUD_OVF_ENV_NS = "http://schemas.dmtf.org/ovf/environment/1";
|
public static final String VCLOUD_OVF_ENV_NS = "http://schemas.dmtf.org/ovf/environment/1";
|
||||||
|
|
|
@ -18,11 +18,24 @@
|
||||||
*/
|
*/
|
||||||
package org.jclouds.vcloud.director.v1_5.domain.ovf;
|
package org.jclouds.vcloud.director.v1_5.domain.ovf;
|
||||||
|
|
||||||
|
import static com.google.common.base.Objects.equal;
|
||||||
|
import static com.google.common.base.Preconditions.checkNotNull;
|
||||||
|
import static org.jclouds.vcloud.director.v1_5.VCloudDirectorConstants.VCLOUD_1_5_NS;
|
||||||
|
import static org.jclouds.vcloud.director.v1_5.VCloudDirectorConstants.VCLOUD_VMW_NS;
|
||||||
|
|
||||||
|
import java.net.URI;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
import javax.xml.bind.annotation.XmlAttribute;
|
import javax.xml.bind.annotation.XmlAttribute;
|
||||||
import javax.xml.bind.annotation.XmlElement;
|
import javax.xml.bind.annotation.XmlElement;
|
||||||
import javax.xml.bind.annotation.XmlRootElement;
|
import javax.xml.bind.annotation.XmlRootElement;
|
||||||
|
|
||||||
|
import org.jclouds.vcloud.director.v1_5.domain.Link;
|
||||||
|
|
||||||
import com.google.common.base.Objects;
|
import com.google.common.base.Objects;
|
||||||
|
import com.google.common.collect.ImmutableSet;
|
||||||
|
import com.google.common.collect.Sets;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An OperatingSystemSection specifies the operating system installed on a virtual machine.
|
* An OperatingSystemSection specifies the operating system installed on a virtual machine.
|
||||||
|
@ -48,6 +61,10 @@ public class OperatingSystemSection extends SectionType {
|
||||||
private Integer id;
|
private Integer id;
|
||||||
private String description;
|
private String description;
|
||||||
private String version;
|
private String version;
|
||||||
|
private String osType;
|
||||||
|
private URI href;
|
||||||
|
private String type;
|
||||||
|
private Set<Link> links;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @see OperatingSystemSection#getId()
|
* @see OperatingSystemSection#getId()
|
||||||
|
@ -73,6 +90,48 @@ public class OperatingSystemSection extends SectionType {
|
||||||
return self();
|
return self();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @see OperatingSystemSection#getOsType()
|
||||||
|
*/
|
||||||
|
public B osType(String osType) {
|
||||||
|
this.osType = osType;
|
||||||
|
return self();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @see OperatingSystemSection#getHref()
|
||||||
|
*/
|
||||||
|
public B href(URI href) {
|
||||||
|
this.href = href;
|
||||||
|
return self();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @see OperatingSystemSection#getType()
|
||||||
|
*/
|
||||||
|
public B type(String type) {
|
||||||
|
this.type = type;
|
||||||
|
return self();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @see OperatingSystemSection#getLinks()
|
||||||
|
*/
|
||||||
|
public B links(Set<Link> links) {
|
||||||
|
this.links = Sets.newLinkedHashSet(checkNotNull(links, "links"));
|
||||||
|
return self();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @see ResourceType#getLinks()
|
||||||
|
*/
|
||||||
|
public B link(Link link) {
|
||||||
|
if (links == null)
|
||||||
|
links = Sets.newLinkedHashSet();
|
||||||
|
this.links.add(checkNotNull(link, "link"));
|
||||||
|
return self();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
|
@ -82,22 +141,35 @@ public class OperatingSystemSection extends SectionType {
|
||||||
}
|
}
|
||||||
|
|
||||||
public B fromOperatingSystemSection(OperatingSystemSection in) {
|
public B fromOperatingSystemSection(OperatingSystemSection in) {
|
||||||
return id(in.getId()).info(in.getInfo()).description(in.getDescription());
|
return fromSectionType(in).id(in.getId()).version(in.getVersion()).description(in.getDescription())
|
||||||
|
.osType(in.getOsType()).href(in.getHref()).type(in.getType()).links(in.getLinks());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@XmlAttribute
|
@XmlAttribute(required = true)
|
||||||
protected Integer id;
|
protected Integer id;
|
||||||
@XmlAttribute
|
@XmlAttribute
|
||||||
protected String version;
|
protected String version;
|
||||||
@XmlElement
|
@XmlElement
|
||||||
protected String description;
|
protected String description;
|
||||||
|
@XmlAttribute(namespace = VCLOUD_VMW_NS)
|
||||||
|
protected String osType;
|
||||||
|
@XmlAttribute(namespace = VCLOUD_1_5_NS)
|
||||||
|
private URI href;
|
||||||
|
@XmlAttribute(namespace = VCLOUD_1_5_NS)
|
||||||
|
private String type;
|
||||||
|
@XmlElement(name = "Link", namespace = VCLOUD_1_5_NS)
|
||||||
|
private Set<Link> links;
|
||||||
|
|
||||||
public OperatingSystemSection(Builder<?> builder) {
|
public OperatingSystemSection(Builder<?> builder) {
|
||||||
super(builder);
|
super(builder);
|
||||||
this.id = builder.id;
|
this.id = builder.id;
|
||||||
this.description = builder.description;
|
this.description = builder.description;
|
||||||
this.version = builder.version;
|
this.version = builder.version;
|
||||||
|
this.osType = builder.osType;
|
||||||
|
this.href = builder.href;
|
||||||
|
this.type = builder.type;
|
||||||
|
this.links = builder.links;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected OperatingSystemSection() {
|
protected OperatingSystemSection() {
|
||||||
|
@ -105,29 +177,65 @@ public class OperatingSystemSection extends SectionType {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* Gets the OVF id
|
||||||
*
|
*
|
||||||
* @return ovf id
|
|
||||||
* @see org.jclouds.vcloud.director.v1_5.domain.cim.OSType#getCode()
|
* @see org.jclouds.vcloud.director.v1_5.domain.cim.OSType#getCode()
|
||||||
*/
|
*/
|
||||||
public Integer getId() {
|
public Integer getId() {
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the version
|
||||||
|
*/
|
||||||
public String getVersion() {
|
public String getVersion() {
|
||||||
return version;
|
return version;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
* Gets the description or null
|
||||||
* @return description or null
|
|
||||||
*/
|
*/
|
||||||
public String getDescription() {
|
public String getDescription() {
|
||||||
return description;
|
return description;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the osType
|
||||||
|
*/
|
||||||
|
public String getOsType() {
|
||||||
|
return osType;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Contains the URI to the entity.
|
||||||
|
*
|
||||||
|
* @see ResourceType#getHref()
|
||||||
|
*/
|
||||||
|
public URI getHref() {
|
||||||
|
return href;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Contains the type of the the entity.
|
||||||
|
*
|
||||||
|
* @see ResourceType#getType()
|
||||||
|
*/
|
||||||
|
public String getType() {
|
||||||
|
return type;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set of optional links to an entity or operation associated with this object.
|
||||||
|
*
|
||||||
|
* @see ResourceType#getLinks()
|
||||||
|
*/
|
||||||
|
public Set<Link> getLinks() {
|
||||||
|
return links == null ? ImmutableSet.<Link>of() : Collections.unmodifiableSet(links);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int hashCode() {
|
public int hashCode() {
|
||||||
return Objects.hashCode(super.hashCode(), description);
|
return Objects.hashCode(super.hashCode(), id, version, description, osType, href, type, links);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -136,13 +244,15 @@ public class OperatingSystemSection extends SectionType {
|
||||||
if (obj == null) return false;
|
if (obj == null) return false;
|
||||||
if (getClass() != obj.getClass()) return false;
|
if (getClass() != obj.getClass()) return false;
|
||||||
|
|
||||||
OperatingSystemSection other = (OperatingSystemSection) obj;
|
OperatingSystemSection that = (OperatingSystemSection) obj;
|
||||||
return super.equals(other) && Objects.equal(description, other.description);
|
return super.equals(that) &&
|
||||||
|
equal(this.id, that.id) && equal(this.version, that.version) && equal(this.description, that.description) &&
|
||||||
|
equal(this.osType, that.osType) && equal(this.href, that.href) && equal(this.links, that.links) && equal(this.type, that.type);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected Objects.ToStringHelper string() {
|
protected Objects.ToStringHelper string() {
|
||||||
return super.string().add("description", description);
|
return super.string().add("id", id).add("version", version).add("description", description).add("osType", osType)
|
||||||
|
.add("href", href).add("links", links).add("type", type);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -23,6 +23,7 @@ import static org.jclouds.vcloud.director.v1_5.VCloudDirectorConstants.VCLOUD_OV
|
||||||
import javax.xml.bind.annotation.XmlAttribute;
|
import javax.xml.bind.annotation.XmlAttribute;
|
||||||
import javax.xml.bind.annotation.XmlElement;
|
import javax.xml.bind.annotation.XmlElement;
|
||||||
import javax.xml.bind.annotation.XmlSeeAlso;
|
import javax.xml.bind.annotation.XmlSeeAlso;
|
||||||
|
import javax.xml.bind.annotation.XmlType;
|
||||||
|
|
||||||
import org.jclouds.vcloud.director.v1_5.domain.CustomizationSection;
|
import org.jclouds.vcloud.director.v1_5.domain.CustomizationSection;
|
||||||
import org.jclouds.vcloud.director.v1_5.domain.GuestCustomizationSection;
|
import org.jclouds.vcloud.director.v1_5.domain.GuestCustomizationSection;
|
||||||
|
@ -41,6 +42,7 @@ import com.google.common.base.Objects;
|
||||||
* @author Adrian Cole
|
* @author Adrian Cole
|
||||||
* @author Adam Lowe
|
* @author Adam Lowe
|
||||||
*/
|
*/
|
||||||
|
@XmlType(name = "Section_Type")
|
||||||
@XmlSeeAlso({
|
@XmlSeeAlso({
|
||||||
CustomizationSection.class,
|
CustomizationSection.class,
|
||||||
DeploymentOptionSection.class,
|
DeploymentOptionSection.class,
|
||||||
|
@ -85,6 +87,22 @@ public abstract class SectionType {
|
||||||
return self();
|
return self();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @see SectionType#isRequired()
|
||||||
|
*/
|
||||||
|
public B required() {
|
||||||
|
this.required = Boolean.TRUE;
|
||||||
|
return self();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @see SectionType#isRequired()
|
||||||
|
*/
|
||||||
|
public B notRequired() {
|
||||||
|
this.required = Boolean.FALSE;
|
||||||
|
return self();
|
||||||
|
}
|
||||||
|
|
||||||
public B fromSectionType(SectionType in) {
|
public B fromSectionType(SectionType in) {
|
||||||
return info(in.getInfo()).required(in.isRequired());
|
return info(in.getInfo()).required(in.isRequired());
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
package org.jclouds.vcloud.director.v1_5.domain.ovf;
|
package org.jclouds.vcloud.director.v1_5.domain.ovf;
|
||||||
|
|
||||||
import static com.google.common.base.Objects.equal;
|
import static com.google.common.base.Objects.equal;
|
||||||
|
import static com.google.common.base.Preconditions.checkNotNull;
|
||||||
|
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
@ -54,14 +55,22 @@ public class StartupSection extends SectionType {
|
||||||
|
|
||||||
public static class Builder<B extends Builder<B>> extends SectionType.Builder<B> {
|
public static class Builder<B extends Builder<B>> extends SectionType.Builder<B> {
|
||||||
|
|
||||||
private List<StartupSectionItem> item = Collections.emptyList();
|
private List<StartupSectionItem> items = Collections.emptyList();
|
||||||
private List<Object> any = Collections.emptyList();
|
private List<Object> any = Collections.emptyList();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @see StartupSection#getItem()
|
* @see StartupSection#getItem()
|
||||||
*/
|
*/
|
||||||
public B item(List<StartupSectionItem> item) {
|
public B items(List<StartupSectionItem> items) {
|
||||||
this.item = item;
|
this.items = checkNotNull(items, "items");
|
||||||
|
return self();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @see StartupSection#getItem()
|
||||||
|
*/
|
||||||
|
public B item(StartupSectionItem item) {
|
||||||
|
this.items.add(checkNotNull(item, "item"));
|
||||||
return self();
|
return self();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -79,7 +88,7 @@ public class StartupSection extends SectionType {
|
||||||
}
|
}
|
||||||
|
|
||||||
public B fromStartupSection(StartupSection in) {
|
public B fromStartupSection(StartupSection in) {
|
||||||
return fromSectionType(in).item(item).any(any);
|
return fromSectionType(in).items(items).any(any);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -94,7 +103,7 @@ public class StartupSection extends SectionType {
|
||||||
|
|
||||||
public StartupSection(Builder<?> builder) {
|
public StartupSection(Builder<?> builder) {
|
||||||
super(builder);
|
super(builder);
|
||||||
this.items = (items != null) ? ImmutableList.<StartupSectionItem>copyOf(builder.item) : Collections.<StartupSectionItem>emptyList();
|
this.items = (items != null) ? ImmutableList.<StartupSectionItem>copyOf(builder.items) : Collections.<StartupSectionItem>emptyList();
|
||||||
this.any = (any != null) ? ImmutableList.<Object>copyOf(builder.any) : Collections.<Object>emptyList();
|
this.any = (any != null) ? ImmutableList.<Object>copyOf(builder.any) : Collections.<Object>emptyList();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -130,6 +139,6 @@ public class StartupSection extends SectionType {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ToStringHelper string() {
|
public ToStringHelper string() {
|
||||||
return super.string().add("item", items).add("any", any);
|
return super.string().add("items", items).add("any", any);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -402,7 +402,7 @@ public interface VAppAsyncClient {
|
||||||
* @see VAppClient#modifyNetworkConnectionSection(URI, NetworkConnectionSection)
|
* @see VAppClient#modifyNetworkConnectionSection(URI, NetworkConnectionSection)
|
||||||
*/
|
*/
|
||||||
@PUT
|
@PUT
|
||||||
@Path("/networkConfigSection")
|
@Path("/networkConnectionSection")
|
||||||
@Produces(NETWORK_CONFIG_SECTION)
|
@Produces(NETWORK_CONFIG_SECTION)
|
||||||
@Consumes(TASK)
|
@Consumes(TASK)
|
||||||
@JAXBResponseParser
|
@JAXBResponseParser
|
||||||
|
|
|
@ -480,6 +480,7 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
||||||
GuestCustomizationSection oldSection = vAppClient.getGuestCustomizationSection(vmURI);
|
GuestCustomizationSection oldSection = vAppClient.getGuestCustomizationSection(vmURI);
|
||||||
GuestCustomizationSection newSection = oldSection.toBuilder()
|
GuestCustomizationSection newSection = oldSection.toBuilder()
|
||||||
.computerName("newComputerName")
|
.computerName("newComputerName")
|
||||||
|
.adminPassword(null) // Not allowed
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
// The method under test
|
// The method under test
|
||||||
|
@ -689,6 +690,8 @@ public class VAppClientLiveTest extends BaseVCloudDirectorClientLiveTest {
|
||||||
.info("Changed OperatingSystemSection Description")
|
.info("Changed OperatingSystemSection Description")
|
||||||
.description("Changed OperatingSystemSection Description")
|
.description("Changed OperatingSystemSection Description")
|
||||||
.build();
|
.build();
|
||||||
|
debug(newSection);
|
||||||
|
assertNotNull(newSection.getId());
|
||||||
|
|
||||||
// The method under test
|
// The method under test
|
||||||
Task modifyOperatingSystemSection = vAppClient.modifyOperatingSystemSection(vmURI, newSection);
|
Task modifyOperatingSystemSection = vAppClient.modifyOperatingSystemSection(vmURI, newSection);
|
||||||
|
|
Loading…
Reference in New Issue