EMMA Coverage Report (generated Wed Jun 22 19:47:49 EDT 2011)
[all classes][org.jclouds.ec2.compute.functions]

COVERAGE SUMMARY FOR SOURCE FILE [RegionAndIdToImage.java]

nameclass, %method, %block, %line, %
RegionAndIdToImage.java100% (1/1)100% (3/3)87%  (81/93)82%  (14/17)

COVERAGE BREAKDOWN BY CLASS AND METHOD

nameclass, %method, %block, %line, %
     
class RegionAndIdToImage100% (1/1)100% (3/3)87%  (81/93)82%  (14/17)
apply (RegionAndName): Image 100% (1/1)80%  (49/61)73%  (8/11)
RegionAndIdToImage (EC2ImageParser, EC2Client): void 100% (1/1)100% (12/12)100% (5/5)
message (RegionAndName, Exception): String 100% (1/1)100% (20/20)100% (1/1)

1/**
2 *
3 * Copyright (C) 2011 Cloud Conscious, LLC. <info@cloudconscious.com>
4 *
5 * ====================================================================
6 * Licensed under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
9 *
10 * http://www.apache.org/licenses/LICENSE-2.0
11 *
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
17 * ====================================================================
18 */
19package org.jclouds.ec2.compute.functions;
20 
21import static org.jclouds.ec2.options.DescribeImagesOptions.Builder.imageIds;
22 
23import java.util.NoSuchElementException;
24 
25import javax.annotation.Resource;
26import javax.inject.Inject;
27import javax.inject.Singleton;
28 
29import org.jclouds.ec2.EC2Client;
30import org.jclouds.ec2.compute.domain.RegionAndName;
31import org.jclouds.compute.domain.Image;
32import org.jclouds.logging.Logger;
33import org.jclouds.rest.ResourceNotFoundException;
34 
35import com.google.common.base.Function;
36import com.google.common.collect.Iterables;
37 
38/**
39 * 
40 * @author Adrian Cole
41 */
42@Singleton
43public final class RegionAndIdToImage implements Function<RegionAndName, Image> {
44   @Resource
45   protected Logger logger = Logger.NULL;
46 
47   private final EC2ImageParser parser;
48   private final EC2Client sync;
49 
50   @Inject
51   public RegionAndIdToImage(EC2ImageParser parser, EC2Client sync) {
52      this.parser = parser;
53      this.sync = sync;
54   }
55 
56   public Image apply(RegionAndName key) {
57      try {
58         org.jclouds.ec2.domain.Image image = Iterables.getOnlyElement(sync.getAMIServices()
59               .describeImagesInRegion(key.getRegion(), imageIds(key.getName())));
60         return parser.apply(image);
61      } catch (NoSuchElementException e) {
62         logger.debug(message(key, e));
63         return null;
64      } catch (ResourceNotFoundException e) {
65         logger.debug(message(key, e));
66         return null;
67      } catch (Exception e) {
68         logger.warn(e, message(key, e));
69         return null;
70      }
71   }
72 
73   public static String message(RegionAndName key, Exception e) {
74      return String.format("could not find image %s/%s: %s", key.getRegion(), key.getName(), e.getMessage());
75   }
76}

[all classes][org.jclouds.ec2.compute.functions]
EMMA 2.0.5312 (C) Vladimir Roubtsov