JCLOUDS-1125: Azure list other blobs

Some BlobProperties fields become nullable due to these new blob types.
This commit is contained in:
Andrew Gaul 2016-06-10 18:31:39 -07:00
parent c1ce819f61
commit 61ab28cc50
5 changed files with 86 additions and 3 deletions

View File

@ -0,0 +1,33 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF 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.azureblob.domain;
public enum ListBlobsInclude {
COPY,
METADATA,
SNAPSHOTS,
UNCOMMITTEDBLOBS;
public static ListBlobsInclude fromValue(String symbol) {
return ListBlobsInclude.valueOf(symbol.toUpperCase());
}
@Override
public String toString() {
return name().toLowerCase();
}
}

View File

@ -47,7 +47,7 @@ public class BlobPropertiesImpl implements BlobProperties {
private final BaseImmutableContentMetadata contentMetadata; private final BaseImmutableContentMetadata contentMetadata;
// TODO: should this take Cache-Control as well? // TODO: should this take Cache-Control as well?
public BlobPropertiesImpl(BlobType type, String name, String container, URI url, Date lastModified, String eTag, public BlobPropertiesImpl(BlobType type, String name, String container, URI url, @Nullable Date lastModified, @Nullable String eTag,
long size, String contentType, @Nullable byte[] contentMD5, @Nullable String contentMetadata, long size, String contentType, @Nullable byte[] contentMD5, @Nullable String contentMetadata,
@Nullable String contentLanguage, @Nullable Date currentExpires, LeaseStatus leaseStatus, @Nullable String contentLanguage, @Nullable Date currentExpires, LeaseStatus leaseStatus,
Map<String, String> metadata) { Map<String, String> metadata) {
@ -56,8 +56,8 @@ public class BlobPropertiesImpl implements BlobProperties {
this.name = checkNotNull(name, "name"); this.name = checkNotNull(name, "name");
this.container = checkNotNull(container, "container"); this.container = checkNotNull(container, "container");
this.url = checkNotNull(url, "url"); this.url = checkNotNull(url, "url");
this.lastModified = checkNotNull(lastModified, "lastModified"); this.lastModified = lastModified;
this.eTag = checkNotNull(eTag, "eTag"); this.eTag = eTag;
this.contentMetadata = new BaseImmutableContentMetadata(contentType, size, contentMD5, null, contentLanguage, this.contentMetadata = new BaseImmutableContentMetadata(contentType, size, contentMD5, null, contentLanguage,
contentMetadata, currentExpires); contentMetadata, currentExpires);
this.metadata.putAll(checkNotNull(metadata, "metadata")); this.metadata.putAll(checkNotNull(metadata, "metadata"));

View File

@ -16,7 +16,13 @@
*/ */
package org.jclouds.azureblob.options; package org.jclouds.azureblob.options;
import java.util.Set;
import org.jclouds.azure.storage.options.ListOptions; import org.jclouds.azure.storage.options.ListOptions;
import org.jclouds.azureblob.domain.ListBlobsInclude;
import com.google.common.base.Joiner;
import com.google.common.collect.ImmutableSet;
/** /**
* Contains options supported in the REST API for the List Blobs operation. <h2> * Contains options supported in the REST API for the List Blobs operation. <h2>
@ -35,6 +41,7 @@ import org.jclouds.azure.storage.options.ListOptions;
* @see <a href="http://msdn.microsoft.com/en-us/library/dd179466.aspx" /> * @see <a href="http://msdn.microsoft.com/en-us/library/dd179466.aspx" />
*/ */
public class ListBlobsOptions extends ListOptions { public class ListBlobsOptions extends ListOptions {
private Set<String> datasets;
/** /**
* When the request includes this parameter, the operation returns a {@code BlobPrefix} element * When the request includes this parameter, the operation returns a {@code BlobPrefix} element
@ -94,6 +101,11 @@ public class ListBlobsOptions extends ListOptions {
ListBlobsOptions options = new ListBlobsOptions(); ListBlobsOptions options = new ListBlobsOptions();
return options.maxResults(maxKeys); return options.maxResults(maxKeys);
} }
public static ListBlobsOptions include(Set<ListBlobsInclude> datasets) {
ListBlobsOptions options = new ListBlobsOptions();
return options.include(datasets);
}
} }
/** /**
@ -127,4 +139,14 @@ public class ListBlobsOptions extends ListOptions {
public ListBlobsOptions prefix(String prefix) { public ListBlobsOptions prefix(String prefix) {
return (ListBlobsOptions) super.prefix(prefix); return (ListBlobsOptions) super.prefix(prefix);
} }
public ListBlobsOptions include(Set<ListBlobsInclude> datasets) {
datasets = ImmutableSet.copyOf(datasets);
this.queryParameters.put("include", Joiner.on(",").join(datasets));
return this;
}
public Set<String> getInclude() {
return datasets;
}
} }

View File

@ -31,6 +31,7 @@ import java.net.URI;
import java.security.SecureRandom; import java.security.SecureRandom;
import java.util.Arrays; import java.util.Arrays;
import java.util.Date; import java.util.Date;
import java.util.EnumSet;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
@ -41,6 +42,7 @@ import org.jclouds.azureblob.domain.AzureBlob;
import org.jclouds.azureblob.domain.BlobProperties; import org.jclouds.azureblob.domain.BlobProperties;
import org.jclouds.azureblob.domain.ContainerProperties; import org.jclouds.azureblob.domain.ContainerProperties;
import org.jclouds.azureblob.domain.ListBlobBlocksResponse; import org.jclouds.azureblob.domain.ListBlobBlocksResponse;
import org.jclouds.azureblob.domain.ListBlobsInclude;
import org.jclouds.azureblob.domain.ListBlobsResponse; import org.jclouds.azureblob.domain.ListBlobsResponse;
import org.jclouds.azureblob.domain.PublicAccess; import org.jclouds.azureblob.domain.PublicAccess;
import org.jclouds.azureblob.options.CopyBlobOptions; import org.jclouds.azureblob.options.CopyBlobOptions;
@ -349,11 +351,20 @@ public class AzureBlobClientLiveTest extends BaseBlobStoreIntegrationTest {
String blockIdA = BaseEncoding.base64().encode((blockBlob + "-" + A).getBytes()); String blockIdA = BaseEncoding.base64().encode((blockBlob + "-" + A).getBytes());
String blockIdB = BaseEncoding.base64().encode((blockBlob + "-" + B).getBytes()); String blockIdB = BaseEncoding.base64().encode((blockBlob + "-" + B).getBytes());
String blockIdC = BaseEncoding.base64().encode((blockBlob + "-" + C).getBytes()); String blockIdC = BaseEncoding.base64().encode((blockBlob + "-" + C).getBytes());
getApi().createContainer(blockContainer); getApi().createContainer(blockContainer);
getApi().putBlock(blockContainer, blockBlob, blockIdA, Payloads.newByteArrayPayload(A.getBytes())); getApi().putBlock(blockContainer, blockBlob, blockIdA, Payloads.newByteArrayPayload(A.getBytes()));
getApi().putBlock(blockContainer, blockBlob, blockIdB, Payloads.newByteArrayPayload(B.getBytes())); getApi().putBlock(blockContainer, blockBlob, blockIdB, Payloads.newByteArrayPayload(B.getBytes()));
getApi().putBlock(blockContainer, blockBlob, blockIdC, Payloads.newByteArrayPayload(C.getBytes())); getApi().putBlock(blockContainer, blockBlob, blockIdC, Payloads.newByteArrayPayload(C.getBytes()));
ListBlobsResponse blobs = getApi().listBlobs(blockContainer);
assertThat(blobs).isEmpty();
blobs = getApi().listBlobs(blockContainer, new ListBlobsOptions().include(EnumSet.allOf(ListBlobsInclude.class)));
assertThat(blobs).hasSize(1);
getApi().putBlockList(blockContainer, blockBlob, Arrays.asList(blockIdA, blockIdB, blockIdC)); getApi().putBlockList(blockContainer, blockBlob, Arrays.asList(blockIdA, blockIdB, blockIdC));
ListBlobBlocksResponse blocks = getApi().getBlockList(blockContainer, blockBlob); ListBlobBlocksResponse blocks = getApi().getBlockList(blockContainer, blockBlob);
assertEquals(3, blocks.getBlocks().size()); assertEquals(3, blocks.getBlocks().size());
assertEquals(blockIdA, blocks.getBlocks().get(0).getBlockName()); assertEquals(blockIdA, blocks.getBlocks().get(0).getBlockName());
@ -362,6 +373,7 @@ public class AzureBlobClientLiveTest extends BaseBlobStoreIntegrationTest {
assertEquals(1, blocks.getBlocks().get(0).getContentLength()); assertEquals(1, blocks.getBlocks().get(0).getContentLength());
assertEquals(1, blocks.getBlocks().get(1).getContentLength()); assertEquals(1, blocks.getBlocks().get(1).getContentLength());
assertEquals(1, blocks.getBlocks().get(2).getContentLength()); assertEquals(1, blocks.getBlocks().get(2).getContentLength());
getApi().deleteContainer(blockContainer); getApi().deleteContainer(blockContainer);
} }

View File

@ -24,6 +24,7 @@ import static org.testng.Assert.assertEquals;
import java.io.IOException; import java.io.IOException;
import java.net.URI; import java.net.URI;
import java.util.Date; import java.util.Date;
import java.util.EnumSet;
import java.util.Map; import java.util.Map;
import org.jclouds.ContextBuilder; import org.jclouds.ContextBuilder;
@ -33,6 +34,7 @@ import org.jclouds.azure.storage.filters.SharedKeyLiteAuthentication;
import org.jclouds.azure.storage.options.ListOptions; import org.jclouds.azure.storage.options.ListOptions;
import org.jclouds.azureblob.AzureBlobFallbacks.FalseIfContainerAlreadyExists; import org.jclouds.azureblob.AzureBlobFallbacks.FalseIfContainerAlreadyExists;
import org.jclouds.azureblob.domain.AzureBlob; import org.jclouds.azureblob.domain.AzureBlob;
import org.jclouds.azureblob.domain.ListBlobsInclude;
import org.jclouds.azureblob.domain.PublicAccess; import org.jclouds.azureblob.domain.PublicAccess;
import org.jclouds.azureblob.functions.ParseBlobFromHeadersAndHttpContent; import org.jclouds.azureblob.functions.ParseBlobFromHeadersAndHttpContent;
import org.jclouds.azureblob.functions.ParseContainerPropertiesFromHeaders; import org.jclouds.azureblob.functions.ParseContainerPropertiesFromHeaders;
@ -205,6 +207,20 @@ public class AzureBlobClientTest extends BaseRestAnnotationProcessingTest<AzureB
assertFallbackClassEquals(method, null); assertFallbackClassEquals(method, null);
} }
public void testListBlobsWithOptions() throws SecurityException, NoSuchMethodException, IOException {
Invokable<?, ?> method = method(AzureBlobClient.class, "listBlobs", String.class, ListBlobsOptions[].class);
GeneratedHttpRequest request = processor.createRequest(method, ImmutableList.<Object> of("container", new ListBlobsOptions().include(EnumSet.allOf(ListBlobsInclude.class))));
assertRequestLineEquals(request,
"GET https://identity.blob.core.windows.net/container?restype=container&comp=list&include=copy,metadata,snapshots,uncommittedblobs HTTP/1.1");
assertNonPayloadHeadersEqual(request, "x-ms-version: 2013-08-15\n");
assertPayloadEquals(request, null, null, false);
assertResponseParserClassEquals(method, request, ParseSax.class);
assertSaxResponseParserClassEquals(method, ContainerNameEnumerationResultsHandler.class);
assertFallbackClassEquals(method, null);
}
public void testListRootBlobs() throws SecurityException, NoSuchMethodException, IOException { public void testListRootBlobs() throws SecurityException, NoSuchMethodException, IOException {
Invokable<?, ?> method = method(AzureBlobClient.class, "listBlobs", ListBlobsOptions[].class); Invokable<?, ?> method = method(AzureBlobClient.class, "listBlobs", ListBlobsOptions[].class);
GeneratedHttpRequest request = processor.createRequest(method, ImmutableList.of()); GeneratedHttpRequest request = processor.createRequest(method, ImmutableList.of());