Issue 320: removed some other tie-ins to Gson

This commit is contained in:
Adrian Cole 2010-07-28 11:53:27 -07:00
parent 57ba278cbb
commit ad4ae74066
9 changed files with 56 additions and 66 deletions

View File

@ -9,11 +9,11 @@ import org.jclouds.chef.domain.DataBagItem;
import org.jclouds.http.HttpResponse; import org.jclouds.http.HttpResponse;
import org.jclouds.http.functions.ParseJson; import org.jclouds.http.functions.ParseJson;
import org.jclouds.io.Payloads; import org.jclouds.io.Payloads;
import org.jclouds.json.Json;
import org.jclouds.json.config.GsonModule; import org.jclouds.json.config.GsonModule;
import org.testng.annotations.BeforeTest; import org.testng.annotations.BeforeTest;
import org.testng.annotations.Test; import org.testng.annotations.Test;
import com.google.gson.Gson;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector; import com.google.inject.Injector;
import com.google.inject.Key; import com.google.inject.Key;
@ -25,14 +25,14 @@ import com.google.inject.TypeLiteral;
@Test(groups = "unit", testName = "chef.ParseDataBagItemFromJsonTest") @Test(groups = "unit", testName = "chef.ParseDataBagItemFromJsonTest")
public class ParseDataBagItemFromJsonTest { public class ParseDataBagItemFromJsonTest {
private ParseJson<DataBagItem> handler; private ParseJson<DataBagItem> handler;
private Gson mapper; private Json mapper;
@BeforeTest @BeforeTest
protected void setUpInjector() throws IOException { protected void setUpInjector() throws IOException {
Injector injector = Guice.createInjector(new ChefParserModule(), new GsonModule()); Injector injector = Guice.createInjector(new ChefParserModule(), new GsonModule());
handler = injector.getInstance(Key.get(new TypeLiteral<ParseJson<DataBagItem>>() { handler = injector.getInstance(Key.get(new TypeLiteral<ParseJson<DataBagItem>>() {
})); }));
mapper = injector.getInstance(Gson.class); mapper = injector.getInstance(Json.class);
} }
public void test1() { public void test1() {

View File

@ -20,9 +20,9 @@ package org.jclouds.http.functions;
import static org.jclouds.http.HttpUtils.releasePayload; import static org.jclouds.http.HttpUtils.releasePayload;
import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.io.InputStreamReader; import java.lang.reflect.Type;
import java.io.UnsupportedEncodingException;
import javax.annotation.Resource; import javax.annotation.Resource;
import javax.inject.Inject; import javax.inject.Inject;
@ -30,10 +30,11 @@ import javax.inject.Singleton;
import org.jclouds.http.HttpResponse; import org.jclouds.http.HttpResponse;
import org.jclouds.http.HttpResponseException; import org.jclouds.http.HttpResponseException;
import org.jclouds.json.Json;
import org.jclouds.logging.Logger; import org.jclouds.logging.Logger;
import org.jclouds.util.Utils;
import com.google.common.base.Function; import com.google.common.base.Function;
import com.google.gson.Gson;
import com.google.inject.TypeLiteral; import com.google.inject.TypeLiteral;
/** /**
@ -47,12 +48,12 @@ public class ParseJson<T> implements Function<HttpResponse, T> {
@Resource @Resource
protected Logger logger = Logger.NULL; protected Logger logger = Logger.NULL;
protected final Gson gson; protected final Json json;
protected final TypeLiteral<T> type; protected final TypeLiteral<T> type;
@Inject @Inject
public ParseJson(Gson gson, TypeLiteral<T> type) { public ParseJson(Json json, TypeLiteral<T> type) {
this.gson = gson; this.json = json;
this.type = type; this.type = type;
} }
@ -67,8 +68,7 @@ public class ParseJson<T> implements Function<HttpResponse, T> {
StringBuilder message = new StringBuilder(); StringBuilder message = new StringBuilder();
message.append("Error parsing input"); message.append("Error parsing input");
logger.error(e, message.toString()); logger.error(e, message.toString());
throw new HttpResponseException(message.toString() + "\n" + from, throw new HttpResponseException(message.toString() + "\n" + from, null, from, e);
null, from, e);
} finally { } finally {
releasePayload(from); releasePayload(from);
} }
@ -76,12 +76,17 @@ public class ParseJson<T> implements Function<HttpResponse, T> {
} }
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
public T apply(InputStream stream) { public T apply(InputStream stream) throws IOException {
return (T) apply(stream, type.getType());
}
@SuppressWarnings("unchecked")
public <V> V apply(InputStream stream, Type type) throws IOException {
try { try {
return (T) gson.fromJson(new InputStreamReader(stream, "UTF-8"), type return (V) json.fromJson(Utils.toStringAndClose(stream), type);
.getType()); } finally {
} catch (UnsupportedEncodingException e) { if (stream != null)
throw new RuntimeException("jclouds requires UTF-8 encoding", e); stream.close();
} }
} }
} }

View File

@ -27,6 +27,7 @@ import org.jclouds.http.HttpResponse;
import org.jclouds.ibmdev.config.IBMDeveloperCloudParserModule; import org.jclouds.ibmdev.config.IBMDeveloperCloudParserModule;
import org.jclouds.ibmdev.domain.Address; import org.jclouds.ibmdev.domain.Address;
import org.jclouds.io.Payloads; import org.jclouds.io.Payloads;
import org.jclouds.json.config.GsonModule;
import org.testng.annotations.BeforeTest; import org.testng.annotations.BeforeTest;
import org.testng.annotations.Test; import org.testng.annotations.Test;
@ -45,7 +46,7 @@ public class ParseAddressFromJsonTest {
@BeforeTest @BeforeTest
protected void setUpInjector() throws IOException { protected void setUpInjector() throws IOException {
Injector injector = Guice.createInjector(new IBMDeveloperCloudParserModule()); Injector injector = Guice.createInjector(new IBMDeveloperCloudParserModule(), new GsonModule());
handler = injector.getInstance(ParseAddressFromJson.class); handler = injector.getInstance(ParseAddressFromJson.class);
} }

View File

@ -26,6 +26,7 @@ import org.jclouds.http.HttpResponse;
import org.jclouds.ibmdev.config.IBMDeveloperCloudParserModule; import org.jclouds.ibmdev.config.IBMDeveloperCloudParserModule;
import org.jclouds.ibmdev.domain.Address; import org.jclouds.ibmdev.domain.Address;
import org.jclouds.io.Payloads; import org.jclouds.io.Payloads;
import org.jclouds.json.config.GsonModule;
import org.testng.annotations.BeforeTest; import org.testng.annotations.BeforeTest;
import org.testng.annotations.Test; import org.testng.annotations.Test;
@ -44,7 +45,7 @@ public class ParseAddressesFromJsonTest {
@BeforeTest @BeforeTest
protected void setUpInjector() throws IOException { protected void setUpInjector() throws IOException {
Injector injector = Guice.createInjector(new IBMDeveloperCloudParserModule()); Injector injector = Guice.createInjector(new IBMDeveloperCloudParserModule(), new GsonModule());
handler = injector.getInstance(ParseAddressesFromJson.class); handler = injector.getInstance(ParseAddressesFromJson.class);
} }

View File

@ -25,8 +25,8 @@ import java.net.UnknownHostException;
import java.util.Map; import java.util.Map;
import org.jclouds.http.HttpResponse; import org.jclouds.http.HttpResponse;
import org.jclouds.http.functions.config.SaxParserModule;
import org.jclouds.io.Payloads; import org.jclouds.io.Payloads;
import org.jclouds.json.config.GsonModule;
import org.testng.annotations.Test; import org.testng.annotations.Test;
import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableMap;
@ -41,16 +41,13 @@ import com.google.inject.Injector;
@Test(groups = "unit", testName = "sdn.ParseMetadataFromJsonResponseTest") @Test(groups = "unit", testName = "sdn.ParseMetadataFromJsonResponseTest")
public class ParseMetadataFromJsonResponseTest { public class ParseMetadataFromJsonResponseTest {
Injector i = Guice.createInjector(new SaxParserModule()); Injector i = Guice.createInjector(new GsonModule());
public void testApplyInputStreamDetails() throws UnknownHostException { public void testApplyInputStreamDetails() throws UnknownHostException {
InputStream is = getClass().getResourceAsStream("/metadata.json"); InputStream is = getClass().getResourceAsStream("/metadata.json");
ParseMetadataFromJsonResponse parser = i ParseMetadataFromJsonResponse parser = i.getInstance(ParseMetadataFromJsonResponse.class);
.getInstance(ParseMetadataFromJsonResponse.class); Map<String, String> response = parser.apply(new HttpResponse(200, "ok", Payloads.newInputStreamPayload(is)));
Map<String, String> response = parser.apply(new HttpResponse(200, "ok", assertEquals(response, ImmutableMap.of("MD5", "IGPBYI1uC6+AJJxC4r5YBA==", "test", "1"));
Payloads.newInputStreamPayload(is)));
assertEquals(response, ImmutableMap.of("MD5", "IGPBYI1uC6+AJJxC4r5YBA==",
"test", "1"));
} }
} }

View File

@ -24,8 +24,8 @@ import java.io.InputStream;
import java.net.UnknownHostException; import java.net.UnknownHostException;
import org.jclouds.http.HttpResponse; import org.jclouds.http.HttpResponse;
import org.jclouds.http.functions.config.SaxParserModule;
import org.jclouds.io.Payloads; import org.jclouds.io.Payloads;
import org.jclouds.json.config.GsonModule;
import org.testng.annotations.Test; import org.testng.annotations.Test;
import com.google.inject.Guice; import com.google.inject.Guice;
@ -39,15 +39,13 @@ import com.google.inject.Injector;
@Test(groups = "unit", testName = "sdn.ParseSessionTokenFromJsonResponseTest") @Test(groups = "unit", testName = "sdn.ParseSessionTokenFromJsonResponseTest")
public class ParseSessionTokenFromJsonResponseTest { public class ParseSessionTokenFromJsonResponseTest {
Injector i = Guice.createInjector(new SaxParserModule()); Injector i = Guice.createInjector(new GsonModule());
public void testApplyInputStreamDetails() throws UnknownHostException { public void testApplyInputStreamDetails() throws UnknownHostException {
InputStream is = getClass().getResourceAsStream("/login.json"); InputStream is = getClass().getResourceAsStream("/login.json");
ParseSessionTokenFromJsonResponse parser = i ParseSessionTokenFromJsonResponse parser = i.getInstance(ParseSessionTokenFromJsonResponse.class);
.getInstance(ParseSessionTokenFromJsonResponse.class); String response = parser.apply(new HttpResponse(200, "ok", Payloads.newInputStreamPayload(is)));
String response = parser.apply(new HttpResponse(200, "ok", Payloads
.newInputStreamPayload(is)));
assertEquals(response, "e4b08449-4501-4b7a-af6a-d4e1e1bd7919"); assertEquals(response, "e4b08449-4501-4b7a-af6a-d4e1e1bd7919");
} }

View File

@ -25,8 +25,8 @@ import java.net.URI;
import java.net.UnknownHostException; import java.net.UnknownHostException;
import org.jclouds.http.HttpResponse; import org.jclouds.http.HttpResponse;
import org.jclouds.http.functions.config.SaxParserModule;
import org.jclouds.io.Payloads; import org.jclouds.io.Payloads;
import org.jclouds.json.config.GsonModule;
import org.jclouds.nirvanix.sdn.domain.UploadInfo; import org.jclouds.nirvanix.sdn.domain.UploadInfo;
import org.testng.annotations.Test; import org.testng.annotations.Test;
@ -41,18 +41,15 @@ import com.google.inject.Injector;
@Test(groups = "unit", testName = "sdn.ParseUploadInfoFromJsonResponse") @Test(groups = "unit", testName = "sdn.ParseUploadInfoFromJsonResponse")
public class ParseUploadInfoFromJsonResponseTest { public class ParseUploadInfoFromJsonResponseTest {
Injector i = Guice.createInjector(new SaxParserModule()); Injector i = Guice.createInjector(new GsonModule());
public void testApplyInputStreamDetails() throws UnknownHostException { public void testApplyInputStreamDetails() throws UnknownHostException {
InputStream is = getClass().getResourceAsStream("/authtoken.json"); InputStream is = getClass().getResourceAsStream("/authtoken.json");
ParseUploadInfoFromJsonResponse parser = i ParseUploadInfoFromJsonResponse parser = i.getInstance(ParseUploadInfoFromJsonResponse.class);
.getInstance(ParseUploadInfoFromJsonResponse.class); UploadInfo response = parser.apply(new HttpResponse(200, "ok", Payloads.newInputStreamPayload(is)));
UploadInfo response = parser.apply(new HttpResponse(200, "ok", Payloads
.newInputStreamPayload(is)));
assertEquals(response.getHost(), URI.create("https://node1.nirvanix.com")); assertEquals(response.getHost(), URI.create("https://node1.nirvanix.com"));
assertEquals(response.getToken(), assertEquals(response.getToken(), "siR-ALYd~BEcJ8GR2tE~oX3SEHO8~2WXKT5xjFk~YLS5OvJyHI21TN34rQ");
"siR-ALYd~BEcJ8GR2tE~oX3SEHO8~2WXKT5xjFk~YLS5OvJyHI21TN34rQ");
} }
} }

View File

@ -21,9 +21,8 @@ package org.jclouds.rackspace.cloudfiles.functions;
import static com.google.common.base.Preconditions.checkArgument; import static com.google.common.base.Preconditions.checkArgument;
import static com.google.common.base.Preconditions.checkState; import static com.google.common.base.Preconditions.checkState;
import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;
import java.lang.reflect.Type; import java.lang.reflect.Type;
import java.util.SortedSet; import java.util.SortedSet;
@ -33,6 +32,7 @@ import org.jclouds.blobstore.domain.PageSet;
import org.jclouds.blobstore.domain.internal.PageSetImpl; import org.jclouds.blobstore.domain.internal.PageSetImpl;
import org.jclouds.http.HttpRequest; import org.jclouds.http.HttpRequest;
import org.jclouds.http.functions.ParseJson; import org.jclouds.http.functions.ParseJson;
import org.jclouds.json.Json;
import org.jclouds.rackspace.cloudfiles.domain.ObjectInfo; import org.jclouds.rackspace.cloudfiles.domain.ObjectInfo;
import org.jclouds.rackspace.cloudfiles.domain.internal.ObjectInfoImpl; import org.jclouds.rackspace.cloudfiles.domain.internal.ObjectInfoImpl;
import org.jclouds.rackspace.cloudfiles.options.ListContainerOptions; import org.jclouds.rackspace.cloudfiles.options.ListContainerOptions;
@ -42,7 +42,6 @@ import org.jclouds.rest.internal.GeneratedHttpRequest;
import com.google.common.base.Function; import com.google.common.base.Function;
import com.google.common.collect.Iterables; import com.google.common.collect.Iterables;
import com.google.common.collect.Sets; import com.google.common.collect.Sets;
import com.google.gson.Gson;
import com.google.gson.reflect.TypeToken; import com.google.gson.reflect.TypeToken;
import com.google.inject.TypeLiteral; import com.google.inject.TypeLiteral;
@ -51,37 +50,31 @@ import com.google.inject.TypeLiteral;
* *
* @author Adrian Cole * @author Adrian Cole
*/ */
public class ParseObjectInfoListFromJsonResponse extends public class ParseObjectInfoListFromJsonResponse extends ParseJson<PageSet<ObjectInfo>> implements InvocationContext {
ParseJson<PageSet<ObjectInfo>> implements InvocationContext {
private GeneratedHttpRequest<?> request; private GeneratedHttpRequest<?> request;
@Inject @Inject
public ParseObjectInfoListFromJsonResponse(Gson gson) { public ParseObjectInfoListFromJsonResponse(Json json) {
super(gson, new TypeLiteral<PageSet<ObjectInfo>>() { super(json, new TypeLiteral<PageSet<ObjectInfo>>() {
}); });
} }
public PageSet<ObjectInfo> apply(InputStream stream) { public PageSet<ObjectInfo> apply(InputStream stream) {
checkState(request != null, "request should be initialized at this point"); checkState(request != null, "request should be initialized at this point");
checkState(request.getArgs() != null, checkState(request.getArgs() != null, "request.getArgs() should be initialized at this point");
"request.getArgs() should be initialized at this point"); checkArgument(request.getArgs()[0] instanceof String, "arg[0] must be a container name");
checkArgument(request.getArgs()[0] instanceof String,
"arg[0] must be a container name");
checkArgument(request.getArgs()[1] instanceof ListContainerOptions[], checkArgument(request.getArgs()[1] instanceof ListContainerOptions[],
"arg[1] must be an array of ListContainerOptions"); "arg[1] must be an array of ListContainerOptions");
ListContainerOptions[] optionsList = (ListContainerOptions[]) request ListContainerOptions[] optionsList = (ListContainerOptions[]) request.getArgs()[1];
.getArgs()[1]; ListContainerOptions options = optionsList.length > 0 ? optionsList[0] : ListContainerOptions.NONE;
ListContainerOptions options = optionsList.length > 0 ? optionsList[0]
: ListContainerOptions.NONE;
Type listType = new TypeToken<SortedSet<ObjectInfoImpl>>() { Type listType = new TypeToken<SortedSet<ObjectInfoImpl>>() {
}.getType(); }.getType();
try { try {
SortedSet<ObjectInfoImpl> list = gson.fromJson(new InputStreamReader( SortedSet<ObjectInfoImpl> list = apply(stream, listType);
stream, "UTF-8"), listType); SortedSet<ObjectInfo> returnVal = Sets.newTreeSet(Iterables.transform(list,
SortedSet<ObjectInfo> returnVal = Sets.newTreeSet(Iterables.transform( new Function<ObjectInfoImpl, ObjectInfo>() {
list, new Function<ObjectInfoImpl, ObjectInfo>() {
public ObjectInfo apply(ObjectInfoImpl from) { public ObjectInfo apply(ObjectInfoImpl from) {
return from; return from;
} }
@ -89,16 +82,14 @@ public class ParseObjectInfoListFromJsonResponse extends
boolean truncated = options.getMaxResults() == returnVal.size(); boolean truncated = options.getMaxResults() == returnVal.size();
String marker = truncated ? returnVal.last().getName() : null; String marker = truncated ? returnVal.last().getName() : null;
return new PageSetImpl<ObjectInfo>(returnVal, marker); return new PageSetImpl<ObjectInfo>(returnVal, marker);
} catch (IOException e) {
} catch (UnsupportedEncodingException e) { throw new RuntimeException("problem reading response from request: " + request, e);
throw new RuntimeException("jclouds requires UTF-8 encoding", e);
} }
} }
@Override @Override
public ParseObjectInfoListFromJsonResponse setContext(HttpRequest request) { public ParseObjectInfoListFromJsonResponse setContext(HttpRequest request) {
checkArgument(request instanceof GeneratedHttpRequest<?>, checkArgument(request instanceof GeneratedHttpRequest<?>, "note this handler requires a GeneratedHttpRequest");
"note this handler requires a GeneratedHttpRequest");
this.request = (GeneratedHttpRequest<?>) request; this.request = (GeneratedHttpRequest<?>) request;
return this; return this;
} }

View File

@ -20,9 +20,9 @@ package org.jclouds.twitter.functions;
import static org.testng.Assert.assertEquals; import static org.testng.Assert.assertEquals;
import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.net.URI; import java.net.URI;
import java.net.UnknownHostException;
import java.util.SortedSet; import java.util.SortedSet;
import org.jclouds.date.DateService; import org.jclouds.date.DateService;
@ -52,7 +52,7 @@ public class ParseStatusesFromJsonResponseTest {
DateService dateService = new SimpleDateFormatDateService(); DateService dateService = new SimpleDateFormatDateService();
public void testApplyInputStreamDetails() throws UnknownHostException { public void testApplyInputStreamDetails() throws IOException {
InputStream is = getClass().getResourceAsStream("/test_mentions.json"); InputStream is = getClass().getResourceAsStream("/test_mentions.json");
SortedSet<Status> expects = ImmutableSortedSet SortedSet<Status> expects = ImmutableSortedSet