mirror of https://github.com/apache/jclouds.git
Issue 623:clean up exception messages when templateBuilder fails to match an image
This commit is contained in:
parent
6e2cf793b2
commit
5f54110a47
|
@ -69,9 +69,9 @@ public class EC2TemplateBuilderImpl extends TemplateBuilderImpl {
|
||||||
try {
|
try {
|
||||||
return imageMap.get(key);
|
return imageMap.get(key);
|
||||||
} catch (NullPointerException nex) {
|
} catch (NullPointerException nex) {
|
||||||
throw new NoSuchElementException(String.format("image %s/%s not found", key.getRegion(), key.getName()));
|
throw new NoSuchElementException(String.format("imageId(%s/%s) not found", key.getRegion(), key.getName()));
|
||||||
} catch (ComputationException nex) {
|
} catch (ComputationException nex) {
|
||||||
throw new NoSuchElementException(String.format("image %s/%s not found", key.getRegion(), key.getName()));
|
throw new NoSuchElementException(String.format("imageId(%s/%s) not found", key.getRegion(), key.getName()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
|
|
|
@ -57,7 +57,7 @@ import com.google.common.collect.Sets;
|
||||||
*
|
*
|
||||||
* @author Adrian Cole
|
* @author Adrian Cole
|
||||||
*/
|
*/
|
||||||
@Test(groups = "unit", sequential = true)
|
@Test(groups = "unit", singleThreaded = true)
|
||||||
public class EC2TemplateBuilderImplTest extends TemplateBuilderImplTest {
|
public class EC2TemplateBuilderImplTest extends TemplateBuilderImplTest {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -21,11 +21,14 @@ package org.jclouds.compute.domain.internal;
|
||||||
import static com.google.common.base.Preconditions.checkNotNull;
|
import static com.google.common.base.Preconditions.checkNotNull;
|
||||||
import static com.google.common.base.Predicates.and;
|
import static com.google.common.base.Predicates.and;
|
||||||
import static com.google.common.collect.Iterables.filter;
|
import static com.google.common.collect.Iterables.filter;
|
||||||
|
import static com.google.common.collect.Iterables.find;
|
||||||
|
import static com.google.common.collect.Iterables.size;
|
||||||
|
import static com.google.common.collect.Iterables.transform;
|
||||||
import static com.google.common.collect.Lists.newArrayList;
|
import static com.google.common.collect.Lists.newArrayList;
|
||||||
import static org.jclouds.compute.util.ComputeServiceUtils.getCores;
|
import static org.jclouds.compute.util.ComputeServiceUtils.getCores;
|
||||||
import static org.jclouds.compute.util.ComputeServiceUtils.getCoresAndSpeed;
|
import static org.jclouds.compute.util.ComputeServiceUtils.getCoresAndSpeed;
|
||||||
import static org.jclouds.compute.util.ComputeServiceUtils.getSpace;
|
import static org.jclouds.compute.util.ComputeServiceUtils.getSpace;
|
||||||
|
import static java.lang.String.format;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.NoSuchElementException;
|
import java.util.NoSuchElementException;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
@ -50,6 +53,7 @@ import org.jclouds.logging.Logger;
|
||||||
import org.jclouds.util.Lists2;
|
import org.jclouds.util.Lists2;
|
||||||
|
|
||||||
import com.google.common.annotations.VisibleForTesting;
|
import com.google.common.annotations.VisibleForTesting;
|
||||||
|
import com.google.common.base.Function;
|
||||||
import com.google.common.base.Predicate;
|
import com.google.common.base.Predicate;
|
||||||
import com.google.common.base.Predicates;
|
import com.google.common.base.Predicates;
|
||||||
import com.google.common.base.Supplier;
|
import com.google.common.base.Supplier;
|
||||||
|
@ -145,7 +149,7 @@ public class TemplateBuilderImpl implements TemplateBuilder {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "location(" + location + ")";
|
return location == null ? "anyLocation()" : "locationEqualsOrChildOf(" + location.getId() + ")";
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -500,7 +504,7 @@ public class TemplateBuilderImpl implements TemplateBuilder {
|
||||||
public TemplateBuilder locationId(final String locationId) {
|
public TemplateBuilder locationId(final String locationId) {
|
||||||
Set<? extends Location> locations = this.locations.get();
|
Set<? extends Location> locations = this.locations.get();
|
||||||
try {
|
try {
|
||||||
this.location = Iterables.find(locations, new Predicate<Location>() {
|
this.location = find(locations, new Predicate<Location>() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean apply(Location input) {
|
public boolean apply(Location input) {
|
||||||
|
@ -514,7 +518,7 @@ public class TemplateBuilderImpl implements TemplateBuilder {
|
||||||
|
|
||||||
});
|
});
|
||||||
} catch (NoSuchElementException e) {
|
} catch (NoSuchElementException e) {
|
||||||
throw new NoSuchElementException(String.format("location id %s not found in: %s", locationId, locations));
|
throw new NoSuchElementException(format("location id %s not found in: %s", locationId, locations));
|
||||||
}
|
}
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
@ -528,6 +532,15 @@ public class TemplateBuilderImpl implements TemplateBuilder {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static final Function<Image, String> imageToId = new Function<Image, String>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String apply(Image arg0) {
|
||||||
|
return arg0.getId();
|
||||||
|
}
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
|
@ -547,9 +560,14 @@ public class TemplateBuilderImpl implements TemplateBuilder {
|
||||||
Set<? extends Image> images = getImages();
|
Set<? extends Image> images = getImages();
|
||||||
Predicate<Image> imagePredicate = buildImagePredicate();
|
Predicate<Image> imagePredicate = buildImagePredicate();
|
||||||
Iterable<? extends Image> supportedImages = filter(images, buildImagePredicate());
|
Iterable<? extends Image> supportedImages = filter(images, buildImagePredicate());
|
||||||
if (Iterables.size(supportedImages) == 0)
|
if (size(supportedImages) == 0) {
|
||||||
throw new NoSuchElementException(String.format(
|
if (imagePredicate == idPredicate) {
|
||||||
"no image matched predicate %s images that didn't match below:\n%s", imagePredicate, images));
|
throw new NoSuchElementException(format("%s not found", idPredicate));
|
||||||
|
} else {
|
||||||
|
throwNoSuchElementExceptionAfterLoggingImageIds(format("no image matched predicate: %s", imagePredicate),
|
||||||
|
images);
|
||||||
|
}
|
||||||
|
}
|
||||||
Hardware hardware = resolveSize(hardwareSorter(), supportedImages);
|
Hardware hardware = resolveSize(hardwareSorter(), supportedImages);
|
||||||
Image image = resolveImage(hardware, supportedImages);
|
Image image = resolveImage(hardware, supportedImages);
|
||||||
logger.debug("<< matched image(%s)", image);
|
logger.debug("<< matched image(%s)", image);
|
||||||
|
@ -557,6 +575,13 @@ public class TemplateBuilderImpl implements TemplateBuilder {
|
||||||
return new TemplateImpl(image, hardware, location, options);
|
return new TemplateImpl(image, hardware, location, options);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void throwNoSuchElementExceptionAfterLoggingImageIds(String message, Iterable<? extends Image> images) {
|
||||||
|
NoSuchElementException exception = new NoSuchElementException(message);
|
||||||
|
if (logger.isTraceEnabled())
|
||||||
|
logger.warn(exception, "image ids that didn't match: %s", transform(images, imageToId));
|
||||||
|
throw exception;
|
||||||
|
}
|
||||||
|
|
||||||
protected Hardware resolveSize(Ordering<Hardware> hardwareOrdering, final Iterable<? extends Image> images) {
|
protected Hardware resolveSize(Ordering<Hardware> hardwareOrdering, final Iterable<? extends Image> images) {
|
||||||
Set<? extends Hardware> hardwarel = hardwares.get();
|
Set<? extends Hardware> hardwarel = hardwares.get();
|
||||||
Hardware hardware;
|
Hardware hardware;
|
||||||
|
@ -583,8 +608,11 @@ public class TemplateBuilderImpl implements TemplateBuilder {
|
||||||
});
|
});
|
||||||
hardware = hardwareOrdering.max(filter(hardwaresThatAreCompatibleWithOurImages, hardwarePredicate));
|
hardware = hardwareOrdering.max(filter(hardwaresThatAreCompatibleWithOurImages, hardwarePredicate));
|
||||||
} catch (NoSuchElementException exception) {
|
} catch (NoSuchElementException exception) {
|
||||||
throw new NoSuchElementException("hardware don't support any images: " + toString() + "\n" + hardwarel
|
String message = format("no hardware profiles support images matching params: %s", toString());
|
||||||
+ "\n" + images);
|
exception = new NoSuchElementException(message);
|
||||||
|
if (logger.isTraceEnabled())
|
||||||
|
logger.warn(exception, "hardware profiles %s\nimage ids %s", hardwarel, transform(images, imageToId));
|
||||||
|
throw exception;
|
||||||
}
|
}
|
||||||
logger.debug("<< matched hardware(%s)", hardware);
|
logger.debug("<< matched hardware(%s)", hardware);
|
||||||
return hardware;
|
return hardware;
|
||||||
|
@ -622,13 +650,16 @@ public class TemplateBuilderImpl implements TemplateBuilder {
|
||||||
try {
|
try {
|
||||||
Iterable<? extends Image> matchingImages = filter(supportedImages, imagePredicate);
|
Iterable<? extends Image> matchingImages = filter(supportedImages, imagePredicate);
|
||||||
if (logger.isTraceEnabled())
|
if (logger.isTraceEnabled())
|
||||||
logger.trace("<< matched images(%s)", matchingImages);
|
logger.trace("<< matched images(%s)", transform(matchingImages, imageToId));
|
||||||
List<? extends Image> maxImages = Lists2.multiMax(DEFAULT_IMAGE_ORDERING, matchingImages);
|
List<? extends Image> maxImages = Lists2.multiMax(DEFAULT_IMAGE_ORDERING, matchingImages);
|
||||||
if (logger.isTraceEnabled())
|
if (logger.isTraceEnabled())
|
||||||
logger.trace("<< best images(%s)", maxImages);
|
logger.trace("<< best images(%s)", transform(maxImages, imageToId));
|
||||||
return maxImages.get(maxImages.size() - 1);
|
return maxImages.get(maxImages.size() - 1);
|
||||||
} catch (NoSuchElementException exception) {
|
} catch (NoSuchElementException exception) {
|
||||||
throw new NoSuchElementException("image didn't match: " + toString() + "\n" + supportedImages);
|
throwNoSuchElementExceptionAfterLoggingImageIds(format("no image matched params: %s", toString()),
|
||||||
|
supportedImages);
|
||||||
|
assert false;
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -651,7 +682,7 @@ public class TemplateBuilderImpl implements TemplateBuilder {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "location(" + location + ")";
|
return locationPredicate.toString();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -668,19 +699,20 @@ public class TemplateBuilderImpl implements TemplateBuilder {
|
||||||
osPredicates.add(os64BitPredicate);
|
osPredicates.add(os64BitPredicate);
|
||||||
if (osArch != null)
|
if (osArch != null)
|
||||||
osPredicates.add(osArchPredicate);
|
osPredicates.add(osArchPredicate);
|
||||||
predicates.add(new Predicate<Image>() {
|
if (osPredicates.size() > 0)
|
||||||
|
predicates.add(new Predicate<Image>() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean apply(Image input) {
|
public boolean apply(Image input) {
|
||||||
return Predicates.and(osPredicates).apply(input.getOperatingSystem());
|
return and(osPredicates).apply(input.getOperatingSystem());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return Predicates.and(osPredicates).toString();
|
return and(osPredicates).toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
if (imageVersion != null)
|
if (imageVersion != null)
|
||||||
predicates.add(imageVersionPredicate);
|
predicates.add(imageVersionPredicate);
|
||||||
if (imageName != null)
|
if (imageName != null)
|
||||||
|
|
|
@ -46,4 +46,5 @@ public class StubTemplateBuilderIntegrationTest extends BaseTemplateBuilderLiveT
|
||||||
protected Set<String> getIso3166Codes() {
|
protected Set<String> getIso3166Codes() {
|
||||||
return ImmutableSet.<String> of();
|
return ImmutableSet.<String> of();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -274,6 +274,10 @@ public class TemplateBuilderImplTest {
|
||||||
template.imageId("notImageId").build();
|
template.imageId("notImageId").build();
|
||||||
assert false;
|
assert false;
|
||||||
} catch (NoSuchElementException e) {
|
} catch (NoSuchElementException e) {
|
||||||
|
// make sure big data is not in the exception message
|
||||||
|
assertEquals(
|
||||||
|
e.getMessage(),
|
||||||
|
"no hardware profiles support images matching params: [biggest=false, fastest=false, imageName=null, imageDescription=null, imageId=notImageId, imageVersion=null, location=EasyMock for interface org.jclouds.domain.Location, minCores=0.0, minRam=0, osFamily=null, osName=null, osDescription=null, osVersion=null, osArch=null, os64Bit=false, hardwareId=null]");
|
||||||
verify(image);
|
verify(image);
|
||||||
verify(os);
|
verify(os);
|
||||||
verify(defaultTemplate);
|
verify(defaultTemplate);
|
||||||
|
@ -523,7 +527,47 @@ public class TemplateBuilderImplTest {
|
||||||
template.imageId("region/ami").build();
|
template.imageId("region/ami").build();
|
||||||
assert false;
|
assert false;
|
||||||
} catch (NoSuchElementException e) {
|
} catch (NoSuchElementException e) {
|
||||||
|
// make sure big data is not in the exception message
|
||||||
|
assertEquals(e.getMessage(), "imageId(region/ami) not found");
|
||||||
|
}
|
||||||
|
|
||||||
|
verify(defaultOptions);
|
||||||
|
verify(defaultLocation);
|
||||||
|
verify(optionsProvider);
|
||||||
|
verify(templateBuilderProvider);
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
@Test
|
||||||
|
public void testDefaultLocationWithUnmatchedPredicateExceptionMessage() {
|
||||||
|
Supplier<Set<? extends Location>> locations = Suppliers.<Set<? extends Location>> ofInstance(ImmutableSet
|
||||||
|
.<Location> of());
|
||||||
|
Supplier<Set<? extends Image>> images = Suppliers.<Set<? extends Image>> ofInstance(ImmutableSet.<Image> of());
|
||||||
|
Supplier<Set<? extends Hardware>> hardwares = Suppliers.<Set<? extends Hardware>> ofInstance(ImmutableSet
|
||||||
|
.<Hardware> of());
|
||||||
|
Location defaultLocation = createMock(Location.class);
|
||||||
|
Provider<TemplateOptions> optionsProvider = createMock(Provider.class);
|
||||||
|
Provider<TemplateBuilder> templateBuilderProvider = createMock(Provider.class);
|
||||||
|
TemplateOptions defaultOptions = createMock(TemplateOptions.class);
|
||||||
|
|
||||||
|
expect(defaultLocation.getId()).andReturn("us-east-1");
|
||||||
|
|
||||||
|
expect(optionsProvider.get()).andReturn(defaultOptions);
|
||||||
|
|
||||||
|
replay(defaultOptions);
|
||||||
|
replay(defaultLocation);
|
||||||
|
replay(optionsProvider);
|
||||||
|
replay(templateBuilderProvider);
|
||||||
|
|
||||||
|
TemplateBuilderImpl template = createTemplateBuilder(null, locations, images, hardwares, defaultLocation,
|
||||||
|
optionsProvider, templateBuilderProvider);
|
||||||
|
|
||||||
|
try {
|
||||||
|
template.imageDescriptionMatches("region/ami").build();
|
||||||
|
assert false;
|
||||||
|
} catch (NoSuchElementException e) {
|
||||||
|
// make sure big data is not in the exception message
|
||||||
|
assertEquals(e.getMessage(), "no image matched predicate: And(locationEqualsOrChildOf(us-east-1),imageDescription(region/ami))");
|
||||||
}
|
}
|
||||||
|
|
||||||
verify(defaultOptions);
|
verify(defaultOptions);
|
||||||
|
|
Loading…
Reference in New Issue