mirror of https://github.com/apache/jclouds.git
Issue 695: Created builder for links and fixed order of constructor args
This commit is contained in:
parent
ca69fbf0f7
commit
e2d7b66b0c
|
@ -123,7 +123,7 @@ public class Link extends BaseNamedResource<Link> {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Link build() {
|
public Link build() {
|
||||||
return new Link(href, name, type, rel);
|
return new Link(href, type, name, rel);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Builder fromLink(Link in) {
|
public Builder fromLink(Link in) {
|
||||||
|
|
|
@ -25,6 +25,8 @@ import java.util.Collections;
|
||||||
import java.util.LinkedHashSet;
|
import java.util.LinkedHashSet;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
import static com.google.common.base.Preconditions.checkNotNull;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Wraps individual Link elements.
|
* Wraps individual Link elements.
|
||||||
* Needed because parsing is done with JAXB and it does not handle Generic collections
|
* Needed because parsing is done with JAXB and it does not handle Generic collections
|
||||||
|
@ -32,36 +34,75 @@ import java.util.Set;
|
||||||
*/
|
*/
|
||||||
public class Links {
|
public class Links {
|
||||||
|
|
||||||
private LinkedHashSet<Link> links = Sets.newLinkedHashSet();
|
@SuppressWarnings("unchecked")
|
||||||
|
public static Builder builder() {
|
||||||
|
return new Builder();
|
||||||
|
}
|
||||||
|
|
||||||
@XmlElement(name = "Link")
|
public Builder toBuilder() {
|
||||||
public void setLink(Link link) {
|
return new Builder().fromLinks(this);
|
||||||
this.links.add(link);
|
}
|
||||||
}
|
|
||||||
|
|
||||||
public Set<Link> getLinks() {
|
public static class Builder {
|
||||||
return Collections.unmodifiableSet(links);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
private Set<Link> links = Sets.newLinkedHashSet();
|
||||||
public boolean equals(Object o) {
|
|
||||||
if (this == o) return true;
|
|
||||||
if (o == null || getClass() != o.getClass()) return false;
|
|
||||||
|
|
||||||
Links links1 = (Links) o;
|
/**
|
||||||
|
* @see Links#getLinks
|
||||||
|
*/
|
||||||
|
public Builder links(Set<Link> links) {
|
||||||
|
this.links = Sets.newLinkedHashSet(checkNotNull(links, "links"));
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
if (!links.equals(links1.links)) return false;
|
public Builder addLink(Link link) {
|
||||||
|
links.add(checkNotNull(link,"link"));
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
public Links build() {
|
||||||
}
|
return new Links(links);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
public Builder fromLinks(Links in) {
|
||||||
public int hashCode() {
|
return links(in.getLinks());
|
||||||
return links.hashCode();
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public String toString() {
|
@XmlElement(name = "Link")
|
||||||
return "["+ links.toString()+"]";
|
private LinkedHashSet<Link> links = Sets.newLinkedHashSet();
|
||||||
}
|
|
||||||
|
private Links() {
|
||||||
|
//For JAXB
|
||||||
|
}
|
||||||
|
|
||||||
|
private Links(Set<Link> links) {
|
||||||
|
this.links = Sets.newLinkedHashSet(links);
|
||||||
|
}
|
||||||
|
|
||||||
|
public Set<Link> getLinks() {
|
||||||
|
return Collections.unmodifiableSet(links);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object o) {
|
||||||
|
if (this == o) return true;
|
||||||
|
if (o == null || getClass() != o.getClass()) return false;
|
||||||
|
|
||||||
|
Links links1 = (Links) o;
|
||||||
|
|
||||||
|
if (!links.equals(links1.links)) return false;
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return links.hashCode();
|
||||||
|
}
|
||||||
|
|
||||||
|
public String toString() {
|
||||||
|
return "["+ links.toString()+"]";
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -62,7 +62,7 @@ public class VirtualMachine extends BaseNamedResource<VirtualMachine> {
|
||||||
|
|
||||||
public static class Builder extends BaseNamedResource.Builder<VirtualMachine> {
|
public static class Builder extends BaseNamedResource.Builder<VirtualMachine> {
|
||||||
//TODO There are some more fields
|
//TODO There are some more fields
|
||||||
private Links links = new Links();
|
private Links links = Links.builder().build();
|
||||||
private Actions actions = Actions.builder().build();
|
private Actions actions = Actions.builder().build();
|
||||||
private Tasks tasks = new Tasks();
|
private Tasks tasks = new Tasks();
|
||||||
private String description;
|
private String description;
|
||||||
|
@ -81,8 +81,7 @@ public class VirtualMachine extends BaseNamedResource<VirtualMachine> {
|
||||||
* @see VirtualMachine#getLinks
|
* @see VirtualMachine#getLinks
|
||||||
*/
|
*/
|
||||||
public Builder links(Set<Link> links) {
|
public Builder links(Set<Link> links) {
|
||||||
checkNotNull(links,"links");
|
this.links = Links.builder().links(checkNotNull(links,"links")).build();
|
||||||
for(Link link:links) this.links.setLink(link);
|
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -269,7 +268,7 @@ public class VirtualMachine extends BaseNamedResource<VirtualMachine> {
|
||||||
}
|
}
|
||||||
|
|
||||||
@XmlElement(name = "Links", required = true)
|
@XmlElement(name = "Links", required = true)
|
||||||
private Links links = new Links();
|
private Links links = Links.builder().build();
|
||||||
|
|
||||||
@XmlElement(name = "Tasks", required = true)
|
@XmlElement(name = "Tasks", required = true)
|
||||||
private Tasks tasks = new Tasks();
|
private Tasks tasks = new Tasks();
|
||||||
|
|
|
@ -0,0 +1,58 @@
|
||||||
|
/**
|
||||||
|
* 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.tmrk.enterprisecloud.domain;
|
||||||
|
|
||||||
|
import org.testng.annotations.BeforeMethod;
|
||||||
|
import org.testng.annotations.Test;
|
||||||
|
|
||||||
|
import java.net.URI;
|
||||||
|
import java.net.URISyntaxException;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
import static org.jclouds.tmrk.enterprisecloud.domain.Link.Relationship;
|
||||||
|
import static org.testng.Assert.assertEquals;
|
||||||
|
import static org.testng.Assert.assertTrue;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Jason King
|
||||||
|
*/
|
||||||
|
@Test(groups = "unit", testName = "LinksTest")
|
||||||
|
public class LinksTest {
|
||||||
|
|
||||||
|
private Link link;
|
||||||
|
private Links links;
|
||||||
|
|
||||||
|
@BeforeMethod()
|
||||||
|
public void setUp() throws URISyntaxException {
|
||||||
|
link = Link.builder().href(new URI("/1")).name("my link").type("test link").rel(Relationship.FIRST).build();
|
||||||
|
links = Links.builder().addLink(link).build();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testAddAction() throws URISyntaxException {
|
||||||
|
Link link2 = Link.builder().href(new URI("/2")).name("my link 2").type("test link").rel(Relationship.LAST).build();
|
||||||
|
Links twoLinks = links.toBuilder().addLink(link2).build();
|
||||||
|
Set<Link> linkSet = twoLinks.getLinks();
|
||||||
|
|
||||||
|
assertEquals(2, linkSet.size());
|
||||||
|
assertTrue(linkSet.contains(link));
|
||||||
|
assertTrue(linkSet.contains(link2));
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue