EMMA Coverage Report (generated Mon Oct 17 05:41:20 EDT 2011)
[all classes][org.jclouds.azure.storage.handlers]

COVERAGE SUMMARY FOR SOURCE FILE [AzureStorageClientErrorRetryHandler.java]

nameclass, %method, %block, %line, %
AzureStorageClientErrorRetryHandler.java0%   (0/1)0%   (0/2)0%   (0/111)0%   (0/24)

COVERAGE BREAKDOWN BY CLASS AND METHOD

nameclass, %method, %block, %line, %
     
class AzureStorageClientErrorRetryHandler0%   (0/1)0%   (0/2)0%   (0/111)0%   (0/24)
AzureStorageClientErrorRetryHandler (BackoffLimitedRetryHandler, AzureStorage... 0%   (0/1)0%   (0/15)0%   (0/6)
shouldRetryRequest (HttpCommand, HttpResponse): boolean 0%   (0/1)0%   (0/96)0%   (0/18)

1/**
2 * Licensed to jclouds, Inc. (jclouds) under one or more
3 * contributor license agreements.  See the NOTICE file
4 * distributed with this work for additional information
5 * regarding copyright ownership.  jclouds licenses this file
6 * to you under the Apache License, Version 2.0 (the
7 * "License"); you may not use this file except in compliance
8 * with the License.  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,
13 * software distributed under the License is distributed on an
14 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15 * KIND, either express or implied.  See the License for the
16 * specific language governing permissions and limitations
17 * under the License.
18 */
19package org.jclouds.azure.storage.handlers;
20 
21import java.io.ByteArrayInputStream;
22 
23import javax.annotation.Resource;
24import javax.inject.Named;
25 
26import org.jclouds.Constants;
27import org.jclouds.azure.storage.domain.AzureStorageError;
28import org.jclouds.azure.storage.util.AzureStorageUtils;
29import org.jclouds.http.HttpCommand;
30import org.jclouds.http.HttpException;
31import org.jclouds.http.HttpResponse;
32import org.jclouds.http.HttpRetryHandler;
33import org.jclouds.http.HttpUtils;
34import org.jclouds.http.handlers.BackoffLimitedRetryHandler;
35import org.jclouds.logging.Logger;
36 
37import com.google.inject.Inject;
38 
39/**
40 * Handles Retryable responses with error codes in the 4xx range
41 * 
42 * @author Adrian Cole
43 */
44public class AzureStorageClientErrorRetryHandler implements HttpRetryHandler {
45 
46   @Inject(optional = true)
47   @Named(Constants.PROPERTY_MAX_RETRIES)
48   private int retryCountLimit = 5;
49 
50   private final AzureStorageUtils utils;
51   private final BackoffLimitedRetryHandler backoffHandler;
52 
53   @Resource
54   protected Logger logger = Logger.NULL;
55 
56   @Inject
57   public AzureStorageClientErrorRetryHandler(BackoffLimitedRetryHandler backoffHandler,
58            AzureStorageUtils utils) {
59      this.backoffHandler = backoffHandler;
60      this.utils = utils;
61   }
62 
63   public boolean shouldRetryRequest(HttpCommand command, HttpResponse response) {
64      byte[] content = HttpUtils.closeClientButKeepContentStream(response);
65      command.incrementFailureCount();
66      if (!command.isReplayable()) {
67         logger.warn("Cannot retry after server error, command is not replayable: %1$s", command);
68         return false;
69      } else if (command.getFailureCount() > retryCountLimit) {
70         logger.warn(
71                  "Cannot retry after server error, command has exceeded retry limit %1$d: %2$s",
72                  retryCountLimit, command);
73         return false;
74      } else if (response.getStatusCode() == 409) {
75         // Content can be null in the case of HEAD requests
76         if (content != null) {
77            try {
78               AzureStorageError error = utils.parseAzureStorageErrorFromContent(command, response,
79                        new ByteArrayInputStream(content));
80               if ("ContainerBeingDeleted".equals(error.getCode())) {
81                  backoffHandler.imposeBackoffExponentialDelay(100L, 3, retryCountLimit, command
82                           .getFailureCount(), command.toString());
83                  return true;
84               }
85            } catch (HttpException e) {
86               logger.warn(e, "error parsing response: %s", new String(content));
87            }
88         }
89      }
90      return false;
91   }
92 
93}

[all classes][org.jclouds.azure.storage.handlers]
EMMA 2.0.5312 (C) Vladimir Roubtsov