EMMA Coverage Report (generated Wed Jun 22 19:47:49 EDT 2011)
[all classes][org.jclouds.blobstore.strategy.internal]

COVERAGE SUMMARY FOR SOURCE FILE [FetchBlobMetadata.java]

nameclass, %method, %block, %line, %
FetchBlobMetadata.java0%   (0/3)0%   (0/8)0%   (0/95)0%   (0/15)

COVERAGE BREAKDOWN BY CLASS AND METHOD

nameclass, %method, %block, %line, %
     
class FetchBlobMetadata0%   (0/1)0%   (0/4)0%   (0/65)0%   (0/12)
FetchBlobMetadata (ExecutorService, AsyncBlobStore, BackoffLimitedRetryHandle... 0%   (0/1)0%   (0/15)0%   (0/6)
access$000 (FetchBlobMetadata): String 0%   (0/1)0%   (0/3)0%   (0/1)
apply (PageSet): PageSet 0%   (0/1)0%   (0/42)0%   (0/3)
setContainerName (String): FetchBlobMetadata 0%   (0/1)0%   (0/5)0%   (0/2)
     
class FetchBlobMetadata$10%   (0/1)0%   (0/2)0%   (0/14)0%   (0/2)
FetchBlobMetadata$1 (FetchBlobMetadata): void 0%   (0/1)0%   (0/6)0%   (0/1)
apply (StorageMetadata): boolean 0%   (0/1)0%   (0/8)0%   (0/1)
     
class FetchBlobMetadata$20%   (0/1)0%   (0/2)0%   (0/16)0%   (0/2)
FetchBlobMetadata$2 (FetchBlobMetadata): void 0%   (0/1)0%   (0/6)0%   (0/1)
apply (StorageMetadata): Future 0%   (0/1)0%   (0/10)0%   (0/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.blobstore.strategy.internal;
20 
21import static com.google.common.base.Preconditions.checkState;
22import static org.jclouds.concurrent.FutureIterables.transformParallel;
23 
24import java.util.concurrent.ExecutorService;
25import java.util.concurrent.Future;
26 
27import javax.annotation.Resource;
28import javax.annotation.concurrent.NotThreadSafe;
29import javax.inject.Named;
30 
31import org.jclouds.Constants;
32import org.jclouds.blobstore.AsyncBlobStore;
33import org.jclouds.blobstore.domain.BlobMetadata;
34import org.jclouds.blobstore.domain.PageSet;
35import org.jclouds.blobstore.domain.StorageMetadata;
36import org.jclouds.blobstore.domain.StorageType;
37import org.jclouds.blobstore.domain.internal.PageSetImpl;
38import org.jclouds.blobstore.reference.BlobStoreConstants;
39import org.jclouds.http.handlers.BackoffLimitedRetryHandler;
40import org.jclouds.logging.Logger;
41 
42import com.google.common.base.Function;
43import com.google.common.base.Predicate;
44import com.google.common.collect.Iterables;
45import com.google.inject.Inject;
46 
47/**
48 * Retrieves all blobmetadata in the list as efficiently as possible
49 * 
50 * @author Adrian Cole
51 */
52@NotThreadSafe
53public class FetchBlobMetadata implements Function<PageSet<? extends StorageMetadata>, PageSet<? extends StorageMetadata>> {
54 
55   protected final BackoffLimitedRetryHandler retryHandler;
56   protected final AsyncBlobStore ablobstore;
57   protected final ExecutorService userExecutor;
58   @Resource
59   @Named(BlobStoreConstants.BLOBSTORE_LOGGER)
60   protected Logger logger = Logger.NULL;
61 
62   private String container;
63   /**
64    * maximum duration of an blob Request
65    */
66   @Inject(optional = true)
67   @Named(Constants.PROPERTY_REQUEST_TIMEOUT)
68   protected Long maxTime;
69 
70   @Inject
71   FetchBlobMetadata(@Named(Constants.PROPERTY_USER_THREADS) ExecutorService userExecutor, AsyncBlobStore ablobstore,
72            BackoffLimitedRetryHandler retryHandler) {
73      this.userExecutor = userExecutor;
74      this.ablobstore = ablobstore;
75      this.retryHandler = retryHandler;
76   }
77 
78   public FetchBlobMetadata setContainerName(String container) {
79      this.container = container;
80      return this;
81   }
82 
83   public PageSet<? extends StorageMetadata> apply(PageSet<? extends StorageMetadata> in) {
84      checkState(container != null, "container name should be initialized");
85 
86      Iterable<BlobMetadata> returnv = transformParallel(Iterables.filter(in, new Predicate<StorageMetadata>() {
87 
88         @Override
89         public boolean apply(StorageMetadata input) {
90            return input.getType() == StorageType.BLOB;
91         }
92 
93      }), new Function<StorageMetadata, Future<BlobMetadata>>() {
94 
95         @Override
96         public Future<BlobMetadata> apply(StorageMetadata from) {
97            return ablobstore.blobMetadata(container, from.getName());
98         }
99 
100      }, userExecutor, maxTime, logger, String.format("getting metadata from containerName: %s", container));
101 
102      return new PageSetImpl<BlobMetadata>(returnv, in.getNextMarker());
103   }
104}

[all classes][org.jclouds.blobstore.strategy.internal]
EMMA 2.0.5312 (C) Vladimir Roubtsov