From 8760be118ae1820e6db5957392c07dedad53a06e Mon Sep 17 00:00:00 2001 From: Martin Derka Date: Mon, 11 Jan 2016 14:59:48 -0800 Subject: [PATCH 1/3] Fixed #478 - Make DatastoreException informative. Makes DatastoreException message more informative by preserving a cause. Fixes #478 --- .../src/main/java/com/google/gcloud/spi/DatastoreRpc.java | 8 ++++---- .../java/com/google/gcloud/spi/DefaultDatastoreRpc.java | 4 ++-- .../google/gcloud/datastore/DatastoreExceptionTest.java | 5 ++++- .../java/com/google/gcloud/datastore/DatastoreTest.java | 4 ++-- 4 files changed, 12 insertions(+), 9 deletions(-) diff --git a/gcloud-java-datastore/src/main/java/com/google/gcloud/spi/DatastoreRpc.java b/gcloud-java-datastore/src/main/java/com/google/gcloud/spi/DatastoreRpc.java index dffcc3f0e16f..3e875ff2b8ba 100644 --- a/gcloud-java-datastore/src/main/java/com/google/gcloud/spi/DatastoreRpc.java +++ b/gcloud-java-datastore/src/main/java/com/google/gcloud/spi/DatastoreRpc.java @@ -79,12 +79,12 @@ public int httpStatus() { private final int httpStatus; private final boolean retryable; - public DatastoreRpcException(Reason reason) { - this(reason.name(), reason.httpStatus, reason.retryable, reason.description); + public DatastoreRpcException(Reason reason, Throwable cause) { + this(reason.name(), reason.httpStatus, reason.retryable, reason.description, cause); } - public DatastoreRpcException(String reason, int httpStatus, boolean retryable, String message) { - super(message); + public DatastoreRpcException(String reason, int httpStatus, boolean retryable, String message, Throwable cause) { + super(message, cause); this.reason = reason; this.httpStatus = httpStatus; this.retryable = retryable; diff --git a/gcloud-java-datastore/src/main/java/com/google/gcloud/spi/DefaultDatastoreRpc.java b/gcloud-java-datastore/src/main/java/com/google/gcloud/spi/DefaultDatastoreRpc.java index 4771895eec99..fa993c508a0b 100644 --- a/gcloud-java-datastore/src/main/java/com/google/gcloud/spi/DefaultDatastoreRpc.java +++ b/gcloud-java-datastore/src/main/java/com/google/gcloud/spi/DefaultDatastoreRpc.java @@ -124,7 +124,7 @@ private static DatastoreRpcException translate(DatastoreException exception) { reason = HTTP_STATUS_TO_REASON.get(exception.getCode()); } if (reason != null) { - return new DatastoreRpcException(reason); + return new DatastoreRpcException(reason, exception); } else { boolean retryable = false; reasonStr = "Unknown"; @@ -132,7 +132,7 @@ private static DatastoreRpcException translate(DatastoreException exception) { retryable = true; reasonStr = "Request timeout"; } - return new DatastoreRpcException(reasonStr, exception.getCode(), retryable, message); + return new DatastoreRpcException(reasonStr, exception.getCode(), retryable, message, exception); } } diff --git a/gcloud-java-datastore/src/test/java/com/google/gcloud/datastore/DatastoreExceptionTest.java b/gcloud-java-datastore/src/test/java/com/google/gcloud/datastore/DatastoreExceptionTest.java index 9ad836b15a4e..9f28dccd4930 100644 --- a/gcloud-java-datastore/src/test/java/com/google/gcloud/datastore/DatastoreExceptionTest.java +++ b/gcloud-java-datastore/src/test/java/com/google/gcloud/datastore/DatastoreExceptionTest.java @@ -42,12 +42,15 @@ public void testDatastoreError() throws Exception { @Test public void testTranslateAndThrow() throws Exception { + DatastoreRpcException toTranslate = null; // this should be preserved as a cause for (Reason reason : Reason.values()) { try { - DatastoreException.translateAndThrow(new DatastoreRpcException(reason)); + toTranslate = new DatastoreRpcException(reason, null); + DatastoreException.translateAndThrow(toTranslate); fail("Exception expected"); } catch (DatastoreException ex) { assertEquals(reason.name(), ex.datastoreError().name()); + assertEquals(toTranslate, ex.getCause()); } } } diff --git a/gcloud-java-datastore/src/test/java/com/google/gcloud/datastore/DatastoreTest.java b/gcloud-java-datastore/src/test/java/com/google/gcloud/datastore/DatastoreTest.java index 029b161c1c38..9874054f5744 100644 --- a/gcloud-java-datastore/src/test/java/com/google/gcloud/datastore/DatastoreTest.java +++ b/gcloud-java-datastore/src/test/java/com/google/gcloud/datastore/DatastoreTest.java @@ -734,7 +734,7 @@ public void testRetryableException() throws Exception { EasyMock.expect(rpcFactoryMock.create(EasyMock.anyObject(DatastoreOptions.class))) .andReturn(rpcMock); EasyMock.expect(rpcMock.lookup(requestPb)) - .andThrow(new DatastoreRpc.DatastoreRpcException(Reason.UNAVAILABLE)) + .andThrow(new DatastoreRpc.DatastoreRpcException(Reason.UNAVAILABLE, null)) .andReturn(responsePb); EasyMock.replay(rpcFactoryMock, rpcMock); DatastoreOptions options = this.options.toBuilder() @@ -756,7 +756,7 @@ public void testNonRetryableException() throws Exception { EasyMock.expect(rpcFactoryMock.create(EasyMock.anyObject(DatastoreOptions.class))) .andReturn(rpcMock); EasyMock.expect(rpcMock.lookup(requestPb)) - .andThrow(new DatastoreRpc.DatastoreRpcException(Reason.PERMISSION_DENIED)) + .andThrow(new DatastoreRpc.DatastoreRpcException(Reason.PERMISSION_DENIED, null)) .times(1); EasyMock.replay(rpcFactoryMock, rpcMock); RetryParams retryParams = RetryParams.builder().retryMinAttempts(2).build(); From 25ad65fb01377cbeddce941413bde05b99b88f4a Mon Sep 17 00:00:00 2001 From: Martin Derka Date: Mon, 11 Jan 2016 14:59:48 -0800 Subject: [PATCH 2/3] Fixed #478 - Make DatastoreException informative. Makes DatastoreException message more informative by preserving a cause. Fixes #478 --- .../src/main/java/com/google/gcloud/spi/DatastoreRpc.java | 8 ++++---- .../java/com/google/gcloud/spi/DefaultDatastoreRpc.java | 4 ++-- .../google/gcloud/datastore/DatastoreExceptionTest.java | 5 ++++- .../java/com/google/gcloud/datastore/DatastoreTest.java | 4 ++-- 4 files changed, 12 insertions(+), 9 deletions(-) diff --git a/gcloud-java-datastore/src/main/java/com/google/gcloud/spi/DatastoreRpc.java b/gcloud-java-datastore/src/main/java/com/google/gcloud/spi/DatastoreRpc.java index dffcc3f0e16f..3e875ff2b8ba 100644 --- a/gcloud-java-datastore/src/main/java/com/google/gcloud/spi/DatastoreRpc.java +++ b/gcloud-java-datastore/src/main/java/com/google/gcloud/spi/DatastoreRpc.java @@ -79,12 +79,12 @@ public int httpStatus() { private final int httpStatus; private final boolean retryable; - public DatastoreRpcException(Reason reason) { - this(reason.name(), reason.httpStatus, reason.retryable, reason.description); + public DatastoreRpcException(Reason reason, Throwable cause) { + this(reason.name(), reason.httpStatus, reason.retryable, reason.description, cause); } - public DatastoreRpcException(String reason, int httpStatus, boolean retryable, String message) { - super(message); + public DatastoreRpcException(String reason, int httpStatus, boolean retryable, String message, Throwable cause) { + super(message, cause); this.reason = reason; this.httpStatus = httpStatus; this.retryable = retryable; diff --git a/gcloud-java-datastore/src/main/java/com/google/gcloud/spi/DefaultDatastoreRpc.java b/gcloud-java-datastore/src/main/java/com/google/gcloud/spi/DefaultDatastoreRpc.java index 4771895eec99..fa993c508a0b 100644 --- a/gcloud-java-datastore/src/main/java/com/google/gcloud/spi/DefaultDatastoreRpc.java +++ b/gcloud-java-datastore/src/main/java/com/google/gcloud/spi/DefaultDatastoreRpc.java @@ -124,7 +124,7 @@ private static DatastoreRpcException translate(DatastoreException exception) { reason = HTTP_STATUS_TO_REASON.get(exception.getCode()); } if (reason != null) { - return new DatastoreRpcException(reason); + return new DatastoreRpcException(reason, exception); } else { boolean retryable = false; reasonStr = "Unknown"; @@ -132,7 +132,7 @@ private static DatastoreRpcException translate(DatastoreException exception) { retryable = true; reasonStr = "Request timeout"; } - return new DatastoreRpcException(reasonStr, exception.getCode(), retryable, message); + return new DatastoreRpcException(reasonStr, exception.getCode(), retryable, message, exception); } } diff --git a/gcloud-java-datastore/src/test/java/com/google/gcloud/datastore/DatastoreExceptionTest.java b/gcloud-java-datastore/src/test/java/com/google/gcloud/datastore/DatastoreExceptionTest.java index 9ad836b15a4e..9f28dccd4930 100644 --- a/gcloud-java-datastore/src/test/java/com/google/gcloud/datastore/DatastoreExceptionTest.java +++ b/gcloud-java-datastore/src/test/java/com/google/gcloud/datastore/DatastoreExceptionTest.java @@ -42,12 +42,15 @@ public void testDatastoreError() throws Exception { @Test public void testTranslateAndThrow() throws Exception { + DatastoreRpcException toTranslate = null; // this should be preserved as a cause for (Reason reason : Reason.values()) { try { - DatastoreException.translateAndThrow(new DatastoreRpcException(reason)); + toTranslate = new DatastoreRpcException(reason, null); + DatastoreException.translateAndThrow(toTranslate); fail("Exception expected"); } catch (DatastoreException ex) { assertEquals(reason.name(), ex.datastoreError().name()); + assertEquals(toTranslate, ex.getCause()); } } } diff --git a/gcloud-java-datastore/src/test/java/com/google/gcloud/datastore/DatastoreTest.java b/gcloud-java-datastore/src/test/java/com/google/gcloud/datastore/DatastoreTest.java index 029b161c1c38..9874054f5744 100644 --- a/gcloud-java-datastore/src/test/java/com/google/gcloud/datastore/DatastoreTest.java +++ b/gcloud-java-datastore/src/test/java/com/google/gcloud/datastore/DatastoreTest.java @@ -734,7 +734,7 @@ public void testRetryableException() throws Exception { EasyMock.expect(rpcFactoryMock.create(EasyMock.anyObject(DatastoreOptions.class))) .andReturn(rpcMock); EasyMock.expect(rpcMock.lookup(requestPb)) - .andThrow(new DatastoreRpc.DatastoreRpcException(Reason.UNAVAILABLE)) + .andThrow(new DatastoreRpc.DatastoreRpcException(Reason.UNAVAILABLE, null)) .andReturn(responsePb); EasyMock.replay(rpcFactoryMock, rpcMock); DatastoreOptions options = this.options.toBuilder() @@ -756,7 +756,7 @@ public void testNonRetryableException() throws Exception { EasyMock.expect(rpcFactoryMock.create(EasyMock.anyObject(DatastoreOptions.class))) .andReturn(rpcMock); EasyMock.expect(rpcMock.lookup(requestPb)) - .andThrow(new DatastoreRpc.DatastoreRpcException(Reason.PERMISSION_DENIED)) + .andThrow(new DatastoreRpc.DatastoreRpcException(Reason.PERMISSION_DENIED, null)) .times(1); EasyMock.replay(rpcFactoryMock, rpcMock); RetryParams retryParams = RetryParams.builder().retryMinAttempts(2).build(); From 04d8eef4043a32bd5887cc95bdea9c55ada8b31d Mon Sep 17 00:00:00 2001 From: Martin Derka Date: Mon, 11 Jan 2016 15:28:26 -0800 Subject: [PATCH 3/3] Fixed #478 - Make DatastoreException informative. Makes DatastoreException message more informative by preserving a cause. Fixes #478 --- .../com/google/gcloud/datastore/DatastoreExceptionTest.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gcloud-java-datastore/src/test/java/com/google/gcloud/datastore/DatastoreExceptionTest.java b/gcloud-java-datastore/src/test/java/com/google/gcloud/datastore/DatastoreExceptionTest.java index 9f28dccd4930..019d69cb737b 100644 --- a/gcloud-java-datastore/src/test/java/com/google/gcloud/datastore/DatastoreExceptionTest.java +++ b/gcloud-java-datastore/src/test/java/com/google/gcloud/datastore/DatastoreExceptionTest.java @@ -42,7 +42,7 @@ public void testDatastoreError() throws Exception { @Test public void testTranslateAndThrow() throws Exception { - DatastoreRpcException toTranslate = null; // this should be preserved as a cause + DatastoreRpcException toTranslate = null; // should be preserved as a cause for (Reason reason : Reason.values()) { try { toTranslate = new DatastoreRpcException(reason, null);