From d8b3f332ef2adcfc7bc80b87189f08f1e1f6d655 Mon Sep 17 00:00:00 2001 From: Tanguy Leroux Date: Fri, 29 Jun 2018 13:52:31 +0200 Subject: [PATCH] Remove extra check for object existence in repository-gcs read object (#31661) --- .../gcs/GoogleCloudStorageBlobStore.java | 16 +++++++++----- .../repositories/gcs/MockStorage.java | 22 ++++++++++++++++++- .../ESBlobStoreContainerTestCase.java | 6 ++++- 3 files changed, 36 insertions(+), 8 deletions(-) diff --git a/plugins/repository-gcs/src/main/java/org/elasticsearch/repositories/gcs/GoogleCloudStorageBlobStore.java b/plugins/repository-gcs/src/main/java/org/elasticsearch/repositories/gcs/GoogleCloudStorageBlobStore.java index c20b9979008..2bfb3afc7d3 100644 --- a/plugins/repository-gcs/src/main/java/org/elasticsearch/repositories/gcs/GoogleCloudStorageBlobStore.java +++ b/plugins/repository-gcs/src/main/java/org/elasticsearch/repositories/gcs/GoogleCloudStorageBlobStore.java @@ -54,6 +54,7 @@ import java.util.List; import java.util.Map; import java.util.stream.Collectors; +import static java.net.HttpURLConnection.HTTP_NOT_FOUND; import static java.net.HttpURLConnection.HTTP_PRECON_FAILED; class GoogleCloudStorageBlobStore extends AbstractComponent implements BlobStore { @@ -163,16 +164,19 @@ class GoogleCloudStorageBlobStore extends AbstractComponent implements BlobStore */ InputStream readBlob(String blobName) throws IOException { final BlobId blobId = BlobId.of(bucketName, blobName); - final Blob blob = SocketAccess.doPrivilegedIOException(() -> client().get(blobId)); - if (blob == null) { - throw new NoSuchFileException("Blob [" + blobName + "] does not exit"); - } - final ReadChannel readChannel = SocketAccess.doPrivilegedIOException(blob::reader); + final ReadChannel readChannel = SocketAccess.doPrivilegedIOException(() -> client().reader(blobId)); return Channels.newInputStream(new ReadableByteChannel() { @SuppressForbidden(reason = "Channel is based of a socket not a file") @Override public int read(ByteBuffer dst) throws IOException { - return SocketAccess.doPrivilegedIOException(() -> readChannel.read(dst)); + try { + return SocketAccess.doPrivilegedIOException(() -> readChannel.read(dst)); + } catch (StorageException e) { + if (e.getCode() == HTTP_NOT_FOUND) { + throw new NoSuchFileException("Blob [" + blobName + "] does not exist"); + } + throw e; + } } @Override diff --git a/plugins/repository-gcs/src/test/java/org/elasticsearch/repositories/gcs/MockStorage.java b/plugins/repository-gcs/src/test/java/org/elasticsearch/repositories/gcs/MockStorage.java index 605d1798ee8..cf7395ea1f1 100644 --- a/plugins/repository-gcs/src/test/java/org/elasticsearch/repositories/gcs/MockStorage.java +++ b/plugins/repository-gcs/src/test/java/org/elasticsearch/repositories/gcs/MockStorage.java @@ -167,7 +167,27 @@ class MockStorage implements Storage { public ReadChannel reader(BlobId blob, BlobSourceOption... options) { if (bucketName.equals(blob.getBucket())) { final byte[] bytes = blobs.get(blob.getName()); - final ReadableByteChannel readableByteChannel = Channels.newChannel(new ByteArrayInputStream(bytes)); + + final ReadableByteChannel readableByteChannel; + if (bytes != null) { + readableByteChannel = Channels.newChannel(new ByteArrayInputStream(bytes)); + } else { + readableByteChannel = new ReadableByteChannel() { + @Override + public int read(ByteBuffer dst) throws IOException { + throw new StorageException(404, "Object not found"); + } + + @Override + public boolean isOpen() { + return false; + } + + @Override + public void close() throws IOException { + } + }; + } return new ReadChannel() { @Override public void close() { diff --git a/test/framework/src/main/java/org/elasticsearch/repositories/ESBlobStoreContainerTestCase.java b/test/framework/src/main/java/org/elasticsearch/repositories/ESBlobStoreContainerTestCase.java index 13f9e9debc9..43a62bbe662 100644 --- a/test/framework/src/main/java/org/elasticsearch/repositories/ESBlobStoreContainerTestCase.java +++ b/test/framework/src/main/java/org/elasticsearch/repositories/ESBlobStoreContainerTestCase.java @@ -49,7 +49,11 @@ public abstract class ESBlobStoreContainerTestCase extends ESTestCase { public void testReadNonExistingPath() throws IOException { try(BlobStore store = newBlobStore()) { final BlobContainer container = store.blobContainer(new BlobPath()); - expectThrows(NoSuchFileException.class, () -> container.readBlob("non-existing")); + expectThrows(NoSuchFileException.class, () -> { + try (InputStream is = container.readBlob("non-existing")) { + is.read(); + } + }); } }