diff --git a/google-cloud-core/pom.xml b/google-cloud-core/pom.xml
index 176fe2a18b..e297d4633b 100644
--- a/google-cloud-core/pom.xml
+++ b/google-cloud-core/pom.xml
@@ -65,7 +65,7 @@
com.google.http-client
- google-http-client-jackson2
+ google-http-client-gson
com.google.protobuf
diff --git a/google-cloud-core/src/main/java/com/google/cloud/ServiceOptions.java b/google-cloud-core/src/main/java/com/google/cloud/ServiceOptions.java
index 2a84403af0..7891088d34 100644
--- a/google-cloud-core/src/main/java/com/google/cloud/ServiceOptions.java
+++ b/google-cloud-core/src/main/java/com/google/cloud/ServiceOptions.java
@@ -30,8 +30,7 @@
import com.google.api.client.json.GenericJson;
import com.google.api.client.json.JsonFactory;
import com.google.api.client.json.JsonObjectParser;
-import com.google.api.client.json.jackson2.JacksonFactory;
-import com.google.api.client.util.Charsets;
+import com.google.api.client.json.gson.GsonFactory;
import com.google.api.core.ApiClock;
import com.google.api.core.BetaApi;
import com.google.api.core.CurrentMillisClock;
@@ -61,6 +60,7 @@
import java.io.ObjectInputStream;
import java.io.Serializable;
import java.nio.charset.Charset;
+import java.nio.charset.StandardCharsets;
import java.util.Locale;
import java.util.Map;
import java.util.Objects;
@@ -516,19 +516,18 @@ protected static String getServiceAccountProjectId() {
@InternalApi("Visible for testing")
static String getValueFromCredentialsFile(String credentialsPath, String key) {
- String value = null;
if (credentialsPath != null) {
try (InputStream credentialsStream = new FileInputStream(credentialsPath)) {
- JsonFactory jsonFactory = JacksonFactory.getDefaultInstance();
+ JsonFactory jsonFactory = GsonFactory.getDefaultInstance();
JsonObjectParser parser = new JsonObjectParser(jsonFactory);
GenericJson fileContents =
- parser.parseAndClose(credentialsStream, Charsets.UTF_8, GenericJson.class);
- value = (String) fileContents.get(key);
- } catch (IOException e) {
- // ignore
+ parser.parseAndClose(credentialsStream, StandardCharsets.UTF_8, GenericJson.class);
+ return (String) fileContents.get(key);
+ } catch (IOException | IllegalArgumentException ex) {
+ return null;
}
}
- return value;
+ return null;
}
/**
diff --git a/google-cloud-core/src/test/java/com/google/cloud/ServiceOptionsTest.java b/google-cloud-core/src/test/java/com/google/cloud/ServiceOptionsTest.java
index 6f8763c84b..bf75fca161 100644
--- a/google-cloud-core/src/test/java/com/google/cloud/ServiceOptionsTest.java
+++ b/google-cloud-core/src/test/java/com/google/cloud/ServiceOptionsTest.java
@@ -45,6 +45,7 @@
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
+import java.nio.charset.StandardCharsets;
import java.util.Map;
import java.util.Set;
import java.util.regex.Pattern;
@@ -441,9 +442,11 @@ public void testGetServiceAccountProjectId() throws Exception {
public void testGetServiceAccountProjectId_badJson() throws Exception {
File credentialsFile = File.createTempFile("credentials", ".json");
credentialsFile.deleteOnExit();
- Files.write("asdfghj".getBytes(), credentialsFile);
+ Files.write("asdfghj".getBytes(StandardCharsets.UTF_8), credentialsFile);
- assertNull(ServiceOptions.getValueFromCredentialsFile(credentialsFile.getPath(), "project_id"));
+ String valueFromCredentialsFile =
+ ServiceOptions.getValueFromCredentialsFile(credentialsFile.getPath(), "project_id");
+ assertNull(valueFromCredentialsFile);
}
@Test