All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.yammer.dropwizard.testing.JsonHelpers Maven / Gradle / Ivy

There is a newer version: 0.6.2
Show newest version
package com.yammer.dropwizard.testing;

import com.yammer.dropwizard.json.Json;
import org.codehaus.jackson.JsonNode;
import org.codehaus.jackson.type.TypeReference;

import java.io.IOException;

import static com.yammer.dropwizard.testing.FixtureHelpers.fixture;

/**
 * A set of helper methods for testing the serialization and deserialization of classes to and from
 * JSON.
 * 

For example, a test for reading and writing a {@code Person} object as JSON:

*

 * assertThat("writing a person as JSON produces the appropriate JSON object",
 *            asJson(person),
 *            is(jsonFixture("fixtures/person.json"));
 *
 * assertThat("reading a JSON object as a person produces the appropriate person",
 *            fromJson(jsonFixture("fixtures/person.json"), Person.class),
 *            is(person));
 * 
*/ public class JsonHelpers { private static final Json JSON = new Json(); private JsonHelpers() { /* singleton */ } /** * Converts the given object into a canonical JSON string. * * @param object an object * @return {@code object} as a JSON string * @throws IllegalArgumentException if there is an error encoding {@code object} */ public static String asJson(Object object) throws IllegalArgumentException { return JSON.writeValueAsString(object); } /** * Converts the given JSON string into an object of the given type. * * @param json a JSON string * @param klass the class of the type that {@code json} should be converted to * @param the type that {@code json} should be converted to * @return {@code json} as an instance of {@code T} * @throws IOException if there is an error reading {@code json} as an instance of {@code T} */ public static T fromJson(String json, Class klass) throws IOException { return JSON.readValue(json, klass); } /** * Converts the given JSON string into an object of the given type. * * @param json a JSON string * @param reference a reference of the type that {@code json} should be converted to * @param the type that {@code json} should be converted to * @return {@code json} as an instance of {@code T} * @throws IOException if there is an error reading {@code json} as an instance of {@code T} */ public static T fromJson(String json, TypeReference reference) throws IOException { return JSON.readValue(json, reference); } /** * Loads the given fixture resource as a normalized JSON string. * * @param filename the filename of the fixture * @return the contents of {@code filename} as a normalized JSON string * @throws IOException if there is an error parsing {@code filename} */ public static String jsonFixture(String filename) throws IOException { return JSON.writeValueAsString(JSON.readValue(fixture(filename), JsonNode.class)); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy