mirror of https://github.com/apache/jclouds.git
Issues 158: iso3166Code: use country only if state is missing. Whitespace trimming and null checking
This commit is contained in:
parent
e7dce95ace
commit
a655d8ab25
|
@ -22,6 +22,7 @@ import static com.google.common.base.Preconditions.checkNotNull;
|
||||||
|
|
||||||
import javax.inject.Inject;
|
import javax.inject.Inject;
|
||||||
|
|
||||||
|
import static com.google.common.base.Strings.nullToEmpty;
|
||||||
import org.jclouds.domain.Location;
|
import org.jclouds.domain.Location;
|
||||||
import org.jclouds.domain.LocationBuilder;
|
import org.jclouds.domain.LocationBuilder;
|
||||||
import org.jclouds.domain.LocationScope;
|
import org.jclouds.domain.LocationScope;
|
||||||
|
@ -58,7 +59,16 @@ public class DatacenterToLocation implements Function<Datacenter,Location> {
|
||||||
}
|
}
|
||||||
|
|
||||||
private Iterable<String> createIso3166Codes(Address address) {
|
private Iterable<String> createIso3166Codes(Address address) {
|
||||||
return address != null ? ImmutableSet.<String> of("" + address.getCountry() + "-" + address.getState())
|
if (address== null) return ImmutableSet.<String> of();
|
||||||
: ImmutableSet.<String> of();
|
|
||||||
|
final String country = nullToEmpty(address.getCountry()).trim();
|
||||||
|
if (country.isEmpty()) return ImmutableSet.<String> of();
|
||||||
|
|
||||||
|
final String state = nullToEmpty(address.getState()).trim();
|
||||||
|
if (state.isEmpty()) return ImmutableSet.<String> of(address.getCountry());
|
||||||
|
|
||||||
|
return ImmutableSet.<String> of("" + country + "-" + state);
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,6 +18,9 @@
|
||||||
*/
|
*/
|
||||||
package org.jclouds.softlayer.domain;
|
package org.jclouds.softlayer.domain;
|
||||||
|
|
||||||
|
import static com.google.common.base.Strings.emptyToNull;
|
||||||
|
import static com.google.common.base.Preconditions.checkNotNull;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author Jason King
|
* @author Jason King
|
||||||
|
@ -79,7 +82,7 @@ public class Address implements Comparable<Address> {
|
||||||
|
|
||||||
public Address(long id, String country, String state, String description) {
|
public Address(long id, String country, String state, String description) {
|
||||||
this.id = id;
|
this.id = id;
|
||||||
this.country = country;
|
this.country = checkNotNull(emptyToNull(country),"country cannot be null or empty:"+country);
|
||||||
this.state = state;
|
this.state = state;
|
||||||
this.description = description;
|
this.description = description;
|
||||||
}
|
}
|
||||||
|
|
|
@ -50,12 +50,19 @@ public class DatacenterToLocationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testDatacenterToLocation() {
|
public void testDatacenterToLocation() {
|
||||||
Datacenter address = Datacenter.builder().id(1).longName("This is Texas!").locationAddress(
|
Address address = Address.builder().country("US")
|
||||||
Address.builder().country("US").state("TX").description("This is Texas!").build()).build();
|
.state("TX")
|
||||||
|
.description("This is Texas!")
|
||||||
|
.build();
|
||||||
|
|
||||||
Location location = function.apply(address);
|
Datacenter datacenter = Datacenter.builder().id(1)
|
||||||
|
.longName("Texas Datacenter")
|
||||||
|
.locationAddress(address)
|
||||||
|
.build();
|
||||||
|
|
||||||
assertEquals(location.getId(), Long.toString(address.getId()));
|
Location location = function.apply(datacenter);
|
||||||
|
|
||||||
|
assertEquals(location.getId(), Long.toString(datacenter.getId()));
|
||||||
Set<String> iso3166Codes = location.getIso3166Codes();
|
Set<String> iso3166Codes = location.getIso3166Codes();
|
||||||
assertEquals(iso3166Codes.size(), 1);
|
assertEquals(iso3166Codes.size(), 1);
|
||||||
assertTrue(iso3166Codes.contains("US-TX"));
|
assertTrue(iso3166Codes.contains("US-TX"));
|
||||||
|
@ -63,11 +70,53 @@ public class DatacenterToLocationTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testGetIso3166CodeNoCountryAndState() {
|
public void testGetIso3166CodeNoCountryAndState() {
|
||||||
Datacenter address = Datacenter.builder().id(1).longName("Nowhere").build();
|
Datacenter datacenter = Datacenter.builder().id(1)
|
||||||
Location location = function.apply(address);
|
.longName("Nowhere")
|
||||||
|
.build();
|
||||||
|
|
||||||
assertEquals(location.getId(), Long.toString(address.getId()));
|
Location location = function.apply(datacenter);
|
||||||
|
|
||||||
|
assertEquals(location.getId(), Long.toString(datacenter.getId()));
|
||||||
Set<String> iso3166Codes = location.getIso3166Codes();
|
Set<String> iso3166Codes = location.getIso3166Codes();
|
||||||
assertEquals(iso3166Codes.size(), 0);
|
assertEquals(iso3166Codes.size(), 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGetIso3166CodeCountryOnly() {
|
||||||
|
Address address = Address.builder().country("US")
|
||||||
|
.description("This is North America!")
|
||||||
|
.build();
|
||||||
|
|
||||||
|
Datacenter datacenter = Datacenter.builder().id(1)
|
||||||
|
.longName("Nowhere")
|
||||||
|
.locationAddress(address)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
Location location = function.apply(datacenter);
|
||||||
|
|
||||||
|
assertEquals(location.getId(), Long.toString(datacenter.getId()));
|
||||||
|
Set<String> iso3166Codes = location.getIso3166Codes();
|
||||||
|
assertEquals(iso3166Codes.size(), 1);
|
||||||
|
assertTrue(iso3166Codes.contains("US"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGetIso3166CodeWhitespaceTrimmer() {
|
||||||
|
Address address = Address.builder().country(" US ")
|
||||||
|
.state(" TX ")
|
||||||
|
.description("This is spaced out Texas")
|
||||||
|
.build();
|
||||||
|
|
||||||
|
Datacenter datacenter = Datacenter.builder().id(1)
|
||||||
|
.longName("Nowhere")
|
||||||
|
.locationAddress(address)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
Location location = function.apply(datacenter);
|
||||||
|
|
||||||
|
assertEquals(location.getId(), Long.toString(datacenter.getId()));
|
||||||
|
Set<String> iso3166Codes = location.getIso3166Codes();
|
||||||
|
assertEquals(iso3166Codes.size(), 1);
|
||||||
|
assertTrue(iso3166Codes.contains("US-TX"));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,40 @@
|
||||||
|
/**
|
||||||
|
* 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.softlayer.domain;
|
||||||
|
|
||||||
|
import org.testng.annotations.Test;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests {@code Address}
|
||||||
|
*
|
||||||
|
* @author Jason King
|
||||||
|
*/
|
||||||
|
@Test(singleThreaded = true, groups = "unit")
|
||||||
|
public class AddressTest {
|
||||||
|
|
||||||
|
@Test(expectedExceptions = java.lang.NullPointerException.class )
|
||||||
|
public void testConstructionWithEmpty() {
|
||||||
|
Address.builder().country(null).build();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(expectedExceptions = java.lang.NullPointerException.class )
|
||||||
|
public void testConstructionWithNoCountry() {
|
||||||
|
Address.builder().country("").build();
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue