http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/d45e1351/juneau-server-test/src/test/java/org/apache/juneau/server/test/RestUtilsTest.java
----------------------------------------------------------------------
diff --git 
a/juneau-server-test/src/test/java/org/apache/juneau/server/test/RestUtilsTest.java
 
b/juneau-server-test/src/test/java/org/apache/juneau/server/test/RestUtilsTest.java
new file mode 100755
index 0000000..a0dae9e
--- /dev/null
+++ 
b/juneau-server-test/src/test/java/org/apache/juneau/server/test/RestUtilsTest.java
@@ -0,0 +1,188 @@
+// 
***************************************************************************************************************************
+// * Licensed to the Apache Software Foundation (ASF) under one or more 
contributor license agreements.  See the NOTICE file *
+// * distributed with this work for additional information regarding copyright 
ownership.  The ASF licenses this file        *
+// * to you under the Apache License, Version 2.0 (the "License"); you may not 
use this file except in compliance            *
+// * with the License.  You may obtain a copy of the License at                
                                              *
+// *                                                                           
                                              *
+// *  http://www.apache.org/licenses/LICENSE-2.0                               
                                              *
+// *                                                                           
                                              *
+// * Unless required by applicable law or agreed to in writing, software 
distributed under the License is distributed on an  *
+// * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either 
express or implied.  See the License for the        *
+// * specific language governing permissions and limitations under the 
License.                                              *
+// 
***************************************************************************************************************************
+package org.apache.juneau.server.test;
+
+import static org.apache.juneau.server.RestUtils.*;
+import static org.junit.Assert.*;
+
+import org.junit.*;
+
+public class RestUtilsTest {
+
+       
//====================================================================================================
+       // decode(String)
+       
//====================================================================================================
+       @Test
+       public void testDecode() throws Exception {
+               assertNull(decode(null));
+               assertEquals("foo/bar baz  bing", 
decode("foo%2Fbar+baz++bing"));
+       }
+
+       
//====================================================================================================
+       // encode(String)
+       
//====================================================================================================
+       @Test
+       public void testEncode() throws Exception {
+               assertNull(encode(null));
+               assertEquals("foo%2Fbar+baz++bing", encode("foo/bar baz  
bing"));
+               assertEquals("foobar", encode("foobar"));
+               assertEquals("+", encode(" "));
+               assertEquals("%2F", encode("/"));
+       }
+
+       
//====================================================================================================
+       // trimPathInfo(String,String)
+       
//====================================================================================================
+       @Test
+       public void testGetServletURI() throws Exception {
+               String e, sp, cp;
+
+               e = "http://hostname";;
+               sp = "";
+               cp = "";
+
+               for (String s : new String[]{
+                               "http://hostname";,
+                               "http://hostname/foo";,
+                               "http://hostname?foo";,
+                               "http://hostname/?foo"})
+                       assertEquals(e, trimPathInfo(new StringBuffer(s), cp, 
sp).toString());
+
+               for (String s : new String[]{
+                               "http:/hostname?foo"}) {
+                       try {
+                               trimPathInfo(new StringBuffer(s), cp, sp);
+                               fail("Exception expected - " + s);
+                       } catch (RuntimeException ex) {}
+               }
+
+
+               e = "http://hostname";;
+               sp = "/";
+               cp = "/";
+
+               for (String s : new String[]{
+                               "http://hostname";,
+                               "http://hostname/foo";,
+                               "http://hostname?foo";,
+                               "http://hostname/?foo"})
+                       assertEquals(e, trimPathInfo(new StringBuffer(s), cp, 
sp).toString());
+
+               e = "http://hostname/foo";;
+               sp = "/foo";
+               cp = "/";
+
+               for (String s : new String[]{
+                               "http://hostname/foo";,
+                               "http://hostname/foo/bar";,
+                               "http://hostname/foo?bar"})
+                       assertEquals(e, trimPathInfo(new StringBuffer(s), cp, 
sp).toString());
+
+               for (String s : new String[]{
+                               "http://hostname/foo2";,
+                               "http://hostname/fo2";,
+                               "http://hostname?foo";,
+                               "http://hostname/fo?bar";,
+                               "http:/hostname/foo"}) {
+                       try {
+                               trimPathInfo(new StringBuffer(s), cp, sp);
+                               fail("Exception expected - " + s);
+                       } catch (RuntimeException ex) {}
+               }
+
+               e = "http://hostname/foo/bar";;
+               sp = "/foo/bar";
+               cp = "/";
+
+               for (String s : new String[]{
+                               "http://hostname/foo/bar";,
+                               "http://hostname/foo/bar/baz";,
+                               "http://hostname/foo/bar?baz"})
+                       assertEquals(e, trimPathInfo(new StringBuffer(s), cp, 
sp).toString());
+
+               for (String s : new String[]{
+                               "http://hostname/foo2/bar";,
+                               "http://hostname/foo/bar2";
+                       }) {
+                       try {
+                               trimPathInfo(new StringBuffer(s), cp, sp);
+                               fail("Exception expected - " + s);
+                       } catch (RuntimeException ex) {}
+               }
+
+               e = "http://hostname/foo/bar";;
+               sp = "/bar";
+               cp = "/foo";
+
+               for (String s : new String[]{
+                               "http://hostname/foo/bar";,
+                               "http://hostname/foo/bar/baz";,
+                               "http://hostname/foo/bar?baz"})
+                       assertEquals(e, trimPathInfo(new StringBuffer(s), cp, 
sp).toString());
+
+               for (String s : new String[]{
+                               "http://hostname/foo2/bar";,
+                               "http://hostname/foo/bar2";
+                       }) {
+                       try {
+                               trimPathInfo(new StringBuffer(s), cp, sp);
+                               fail("Exception expected - " + s);
+                       } catch (RuntimeException ex) {}
+               }
+       }
+
+       
//====================================================================================================
+       // trimSlashes(String)
+       
//====================================================================================================
+       @Test
+       public void testTrimSlashes() throws Exception {
+               assertNull(trimSlashes(null));
+               assertEquals("", trimSlashes(""));
+               assertEquals("", trimSlashes("/"));
+               assertEquals("", trimSlashes("//"));
+               assertEquals("foo/bar", trimSlashes("foo/bar"));
+               assertEquals("foo/bar", trimSlashes("foo/bar//"));
+               assertEquals("foo/bar", trimSlashes("/foo/bar//"));
+               assertEquals("foo/bar", trimSlashes("//foo/bar//"));
+       }
+
+       
//====================================================================================================
+       // trimTrailingSlashes(String)
+       
//====================================================================================================
+       @Test
+       public void testTrimTrailingSlashes() throws Exception {
+               assertNull(trimTrailingSlashes((String)null));
+               assertEquals("", trimTrailingSlashes(""));
+               assertEquals("", trimTrailingSlashes("/"));
+               assertEquals("", trimTrailingSlashes("//"));
+               assertEquals("foo/bar", trimTrailingSlashes("foo/bar"));
+               assertEquals("foo/bar", trimTrailingSlashes("foo/bar//"));
+               assertEquals("/foo/bar", trimTrailingSlashes("/foo/bar//"));
+               assertEquals("//foo/bar", trimTrailingSlashes("//foo/bar//"));
+       }
+
+       
//====================================================================================================
+       // trimTrailingSlashes(StringBuffer)
+       
//====================================================================================================
+       @Test
+       public void testTrimTrailingSlashes2() throws Exception {
+               assertNull(trimTrailingSlashes((StringBuffer)null));
+               assertEquals("", trimTrailingSlashes(new 
StringBuffer("")).toString());
+               assertEquals("", trimTrailingSlashes(new 
StringBuffer("/")).toString());
+               assertEquals("", trimTrailingSlashes(new 
StringBuffer("//")).toString());
+               assertEquals("foo/bar", trimTrailingSlashes(new 
StringBuffer("foo/bar")).toString());
+               assertEquals("foo/bar", trimTrailingSlashes(new 
StringBuffer("foo/bar//")).toString());
+               assertEquals("/foo/bar", trimTrailingSlashes(new 
StringBuffer("/foo/bar//")).toString());
+               assertEquals("//foo/bar", trimTrailingSlashes(new 
StringBuffer("//foo/bar//")).toString());
+       }
+}

http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/d45e1351/juneau-server-test/src/test/java/org/apache/juneau/server/test/SerializersTest.java
----------------------------------------------------------------------
diff --git 
a/juneau-server-test/src/test/java/org/apache/juneau/server/test/SerializersTest.java
 
b/juneau-server-test/src/test/java/org/apache/juneau/server/test/SerializersTest.java
new file mode 100755
index 0000000..a8bba98
--- /dev/null
+++ 
b/juneau-server-test/src/test/java/org/apache/juneau/server/test/SerializersTest.java
@@ -0,0 +1,152 @@
+// 
***************************************************************************************************************************
+// * Licensed to the Apache Software Foundation (ASF) under one or more 
contributor license agreements.  See the NOTICE file *
+// * distributed with this work for additional information regarding copyright 
ownership.  The ASF licenses this file        *
+// * to you under the Apache License, Version 2.0 (the "License"); you may not 
use this file except in compliance            *
+// * with the License.  You may obtain a copy of the License at                
                                              *
+// *                                                                           
                                              *
+// *  http://www.apache.org/licenses/LICENSE-2.0                               
                                              *
+// *                                                                           
                                              *
+// * Unless required by applicable law or agreed to in writing, software 
distributed under the License is distributed on an  *
+// * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either 
express or implied.  See the License for the        *
+// * specific language governing permissions and limitations under the 
License.                                              *
+// 
***************************************************************************************************************************
+package org.apache.juneau.server.test;
+
+import static javax.servlet.http.HttpServletResponse.*;
+import static org.apache.juneau.server.test.TestUtils.*;
+import static org.junit.Assert.*;
+
+import org.apache.juneau.client.*;
+import org.apache.juneau.json.*;
+import org.junit.*;
+
+public class SerializersTest {
+
+       private static String URL = "/testSerializers";
+       private static boolean debug = false;
+       private static RestClient client;
+
+       @BeforeClass
+       public static void beforeClass() {
+               client = new TestRestClient(JsonSerializer.DEFAULT, 
JsonParser.DEFAULT);
+       }
+
+       @AfterClass
+       public static void afterClass() {
+               client.closeQuietly();
+       }
+
+       
//====================================================================================================
+       // Serializer defined on class.
+       
//====================================================================================================
+       @Test
+       public void testSerializerOnClass() throws Exception {
+               String url = URL + "/testSerializerOnClass";
+
+               client.setAccept("text/a");
+               String r = client.doGet(url).getResponseAsString();
+               assertEquals("text/a - test1", r);
+
+               try {
+                       client.setAccept("text/b");
+                       client.doGet(url + 
"?noTrace=true").getResponseAsString();
+                       fail("Exception expected");
+               } catch (RestCallException e) {
+                       checkErrorResponse(debug, e, SC_NOT_ACCEPTABLE,
+                               "Unsupported media-type in request header 
'Accept': 'text/b'",
+                               "Supported media-types: [text/a, ");
+               }
+
+               client.setAccept("text/json");
+               r = client.doGet(url).getResponseAsString();
+               assertEquals("\"test1\"", r);
+       }
+
+       
//====================================================================================================
+       // Serializer defined on method.
+       
//====================================================================================================
+       @Test
+       public void testSerializerOnMethod() throws Exception {
+               String url = URL + "/testSerializerOnMethod";
+
+               try {
+                       client.setAccept("text/a");
+                       client.doGet(url + 
"?noTrace=true").getResponseAsString();
+                       fail("Exception expected");
+               } catch (RestCallException e) {
+                       checkErrorResponse(debug, e, SC_NOT_ACCEPTABLE,
+                               "Unsupported media-type in request header 
'Accept': 'text/a'",
+                               "Supported media-types: [text/b]"
+                       );
+               }
+
+               try {
+                       client.setAccept("text/json");
+                       client.doGet(url + 
"?noTrace=true").getResponseAsString();
+                       fail("Exception expected");
+               } catch (RestCallException e) {
+                       checkErrorResponse(debug, e, SC_NOT_ACCEPTABLE,
+                               "Unsupported media-type in request header 
'Accept': 'text/json'",
+                               "Supported media-types: [text/b]"
+                       );
+               }
+       }
+
+       
//====================================================================================================
+       // Serializer overridden on method.
+       
//====================================================================================================
+       @Test
+       public void testSerializerOverriddenOnMethod() throws Exception {
+               String url = URL + "/testSerializerOverriddenOnMethod";
+
+               client.setAccept("text/a");
+               String r = client.doGet(url).getResponseAsString();
+               assertEquals("text/c - test3", r);
+
+               client.setAccept("text/b");
+               r = client.doGet(url).getResponseAsString();
+               assertEquals("text/b - test3", r);
+
+               client.setAccept("text/json");
+               r = client.doGet(url).getResponseAsString();
+               assertEquals("\"test3\"", r);
+       }
+
+       
//====================================================================================================
+       // Serializer with different Accept than Content-Type.
+       
//====================================================================================================
+       @Test
+       public void testSerializerWithDifferentMediaTypes() throws Exception {
+               String url = URL + "/testSerializerWithDifferentMediaTypes";
+
+               client.setAccept("text/a");
+               String r = client.doGet(url).getResponseAsString();
+               assertEquals("text/d - test4", r);
+
+               client.setAccept("text/d");
+               r = client.doGet(url).getResponseAsString();
+               assertEquals("text/d - test4", r);
+
+               client.setAccept("text/json");
+               r = client.doGet(url).getResponseAsString();
+               assertEquals("\"test4\"", r);
+       }
+
+       
//====================================================================================================
+       // Check for valid 406 error response.
+       
//====================================================================================================
+       @Test
+       public void test406() throws Exception {
+               String url = URL + "/test406";
+
+               try {
+                       client.setAccept("text/bad");
+                       client.doGet(url + 
"?noTrace=true").getResponseAsString();
+                       fail("Exception expected");
+               } catch (RestCallException e) {
+                       checkErrorResponse(debug, e, SC_NOT_ACCEPTABLE,
+                               "Unsupported media-type in request header 
'Accept': 'text/bad'",
+                               "Supported media-types: [text/a");
+               }
+       }
+}

http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/d45e1351/juneau-server-test/src/test/java/org/apache/juneau/server/test/StaticFilesTest.java
----------------------------------------------------------------------
diff --git 
a/juneau-server-test/src/test/java/org/apache/juneau/server/test/StaticFilesTest.java
 
b/juneau-server-test/src/test/java/org/apache/juneau/server/test/StaticFilesTest.java
new file mode 100755
index 0000000..0a1449a
--- /dev/null
+++ 
b/juneau-server-test/src/test/java/org/apache/juneau/server/test/StaticFilesTest.java
@@ -0,0 +1,56 @@
+// 
***************************************************************************************************************************
+// * Licensed to the Apache Software Foundation (ASF) under one or more 
contributor license agreements.  See the NOTICE file *
+// * distributed with this work for additional information regarding copyright 
ownership.  The ASF licenses this file        *
+// * to you under the Apache License, Version 2.0 (the "License"); you may not 
use this file except in compliance            *
+// * with the License.  You may obtain a copy of the License at                
                                              *
+// *                                                                           
                                              *
+// *  http://www.apache.org/licenses/LICENSE-2.0                               
                                              *
+// *                                                                           
                                              *
+// * Unless required by applicable law or agreed to in writing, software 
distributed under the License is distributed on an  *
+// * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either 
express or implied.  See the License for the        *
+// * specific language governing permissions and limitations under the 
License.                                              *
+// 
***************************************************************************************************************************
+package org.apache.juneau.server.test;
+
+import static org.junit.Assert.*;
+
+import org.apache.juneau.client.*;
+import org.apache.juneau.plaintext.*;
+import org.junit.*;
+
+public class StaticFilesTest {
+
+       private static String URL = "/testStaticFiles";
+
+       
//====================================================================================================
+       // Tests the @RestResource(staticFiles) annotation.
+       
//====================================================================================================
+       @Test
+       public void testXdocs() throws Exception {
+               RestClient client = new 
TestRestClient(PlainTextSerializer.class, PlainTextParser.class);
+               String r;
+               String url = URL + "/xdocs";
+
+               r = client.doGet(url + "/test.txt").getResponseAsString();
+               assertTrue(r.endsWith("OK-1"));
+               r = client.doGet(url + "/xdocs/test.txt").getResponseAsString();
+               assertTrue(r.endsWith("OK-2"));
+
+               // For security reasons, paths containing ".." should always 
return 404.
+               try {
+                       client.doGet(url + 
"/xdocs/../test.txt?noTrace=true").connect();
+                       fail("404 exception expected");
+               } catch (RestCallException e) {
+                       assertEquals(404, e.getResponseCode());
+               }
+
+               try {
+                       client.doGet(url + 
"/xdocs/%2E%2E/test.txt?noTrace=true").connect();
+                       fail("404 exception expected");
+               } catch (RestCallException e) {
+                       assertEquals(404, e.getResponseCode());
+               }
+
+               client.closeQuietly();
+       }
+}

http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/d45e1351/juneau-server-test/src/test/java/org/apache/juneau/server/test/TestRestClient.java
----------------------------------------------------------------------
diff --git 
a/juneau-server-test/src/test/java/org/apache/juneau/server/test/TestRestClient.java
 
b/juneau-server-test/src/test/java/org/apache/juneau/server/test/TestRestClient.java
new file mode 100755
index 0000000..e7537d9
--- /dev/null
+++ 
b/juneau-server-test/src/test/java/org/apache/juneau/server/test/TestRestClient.java
@@ -0,0 +1,69 @@
+// 
***************************************************************************************************************************
+// * Licensed to the Apache Software Foundation (ASF) under one or more 
contributor license agreements.  See the NOTICE file *
+// * distributed with this work for additional information regarding copyright 
ownership.  The ASF licenses this file        *
+// * to you under the Apache License, Version 2.0 (the "License"); you may not 
use this file except in compliance            *
+// * with the License.  You may obtain a copy of the License at                
                                              *
+// *                                                                           
                                              *
+// *  http://www.apache.org/licenses/LICENSE-2.0                               
                                              *
+// *                                                                           
                                              *
+// * Unless required by applicable law or agreed to in writing, software 
distributed under the License is distributed on an  *
+// * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either 
express or implied.  See the License for the        *
+// * specific language governing permissions and limitations under the 
License.                                              *
+// 
***************************************************************************************************************************
+package org.apache.juneau.server.test;
+
+import java.security.*;
+
+import javax.net.ssl.*;
+
+import org.apache.http.conn.ssl.*;
+import org.apache.http.impl.client.*;
+import org.apache.juneau.client.*;
+import org.apache.juneau.parser.*;
+import org.apache.juneau.serializer.*;
+
+/**
+ * REST client with lenient SSL support and lax redirection strategy.
+ */
+class TestRestClient extends RestClient {
+
+       public TestRestClient(Class<? extends Serializer> s, Class<? extends 
Parser> p) throws InstantiationException {
+               super(s,p);
+               setRootUrl(Constants.getServerTestUrl());
+       }
+
+       public TestRestClient(Serializer s, Parser p) {
+               super(s,p);
+               setRootUrl(Constants.getServerTestUrl());
+       }
+
+       public TestRestClient() {
+               setRootUrl(Constants.getServerTestUrl());
+       }
+
+       public TestRestClient(CloseableHttpClient c) {
+               super(c);
+               setRootUrl(Constants.getServerTestUrl());
+       }
+
+       public static SSLConnectionSocketFactory getSSLSocketFactory() throws 
Exception {
+               SSLContext sslContext = SSLContext.getInstance("SSL");
+               TrustManager tm = new SimpleX509TrustManager(true);
+               sslContext.init(null, new TrustManager[]{tm}, new 
SecureRandom());
+               return new SSLConnectionSocketFactory(sslContext, new 
NoopHostnameVerifier());
+       }
+
+       @Override /* RestClient */
+       protected CloseableHttpClient createHttpClient() throws Exception {
+               try {
+                       return 
HttpClients.custom().setSSLSocketFactory(getSSLSocketFactory()).setRedirectStrategy(new
 LaxRedirectStrategy()).build();
+               } catch (KeyStoreException e) {
+                       throw new RuntimeException(e);
+               } catch (NoSuchAlgorithmException e) {
+                       throw new RuntimeException(e);
+               } catch (Throwable e) {
+                       e.printStackTrace();
+                       return null;
+               }
+       }
+}

http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/d45e1351/juneau-server-test/src/test/java/org/apache/juneau/server/test/TestUtils.java
----------------------------------------------------------------------
diff --git 
a/juneau-server-test/src/test/java/org/apache/juneau/server/test/TestUtils.java 
b/juneau-server-test/src/test/java/org/apache/juneau/server/test/TestUtils.java
new file mode 100755
index 0000000..831fdc0
--- /dev/null
+++ 
b/juneau-server-test/src/test/java/org/apache/juneau/server/test/TestUtils.java
@@ -0,0 +1,60 @@
+// 
***************************************************************************************************************************
+// * Licensed to the Apache Software Foundation (ASF) under one or more 
contributor license agreements.  See the NOTICE file *
+// * distributed with this work for additional information regarding copyright 
ownership.  The ASF licenses this file        *
+// * to you under the Apache License, Version 2.0 (the "License"); you may not 
use this file except in compliance            *
+// * with the License.  You may obtain a copy of the License at                
                                              *
+// *                                                                           
                                              *
+// *  http://www.apache.org/licenses/LICENSE-2.0                               
                                              *
+// *                                                                           
                                              *
+// * Unless required by applicable law or agreed to in writing, software 
distributed under the License is distributed on an  *
+// * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either 
express or implied.  See the License for the        *
+// * specific language governing permissions and limitations under the 
License.                                              *
+// 
***************************************************************************************************************************
+package org.apache.juneau.server.test;
+
+import java.text.*;
+
+import org.apache.juneau.client.*;
+import org.apache.juneau.json.*;
+import org.apache.juneau.serializer.*;
+import org.apache.juneau.transforms.*;
+import org.junit.Assert;
+
+import junit.framework.*;
+
+public class TestUtils {
+
+       private static JsonSerializer js2 = new JsonSerializer.Simple()
+               .addPojoSwaps(IteratorSwap.class, EnumerationSwap.class);
+
+       /**
+        * Assert that the object equals the specified string after running it 
through JsonSerializer.DEFAULT_LAX.toString().
+        */
+       public static void assertObjectEquals(String s, Object o) {
+               assertObjectEquals(s, o, js2);
+       }
+
+       /**
+        * Assert that the object equals the specified string after running it 
through ws.toString().
+        */
+       public static void assertObjectEquals(String s, Object o, 
WriterSerializer ws) {
+               Assert.assertEquals(s, ws.toString(o));
+       }
+
+       public static void checkErrorResponse(boolean debug, RestCallException 
e, int status, String...contains) throws AssertionFailedError {
+               String r = e.getResponseMessage();
+               if (debug) {
+                       System.err.println(r);
+                       e.printStackTrace();
+               }
+               if (status != e.getResponseCode())
+                       throw new 
AssertionFailedError(MessageFormat.format("Response status code was not 
correct.  Expected: ''{0}''.  Actual: ''{1}''", status, e.getResponseCode()));
+               for (String s : contains) {
+                       if (r == null || ! r.contains(s)) {
+                               if (! debug)
+                                       System.err.println(r);
+                               throw new 
AssertionFailedError(MessageFormat.format("Response did not have the following 
expected text: ''{0}''", s));
+                       }
+               }
+       }
+}

http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/d45e1351/juneau-server-test/src/test/java/org/apache/juneau/server/test/TransformsTest.java
----------------------------------------------------------------------
diff --git 
a/juneau-server-test/src/test/java/org/apache/juneau/server/test/TransformsTest.java
 
b/juneau-server-test/src/test/java/org/apache/juneau/server/test/TransformsTest.java
new file mode 100755
index 0000000..cdb1b5d
--- /dev/null
+++ 
b/juneau-server-test/src/test/java/org/apache/juneau/server/test/TransformsTest.java
@@ -0,0 +1,68 @@
+// 
***************************************************************************************************************************
+// * Licensed to the Apache Software Foundation (ASF) under one or more 
contributor license agreements.  See the NOTICE file *
+// * distributed with this work for additional information regarding copyright 
ownership.  The ASF licenses this file        *
+// * to you under the Apache License, Version 2.0 (the "License"); you may not 
use this file except in compliance            *
+// * with the License.  You may obtain a copy of the License at                
                                              *
+// *                                                                           
                                              *
+// *  http://www.apache.org/licenses/LICENSE-2.0                               
                                              *
+// *                                                                           
                                              *
+// * Unless required by applicable law or agreed to in writing, software 
distributed under the License is distributed on an  *
+// * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either 
express or implied.  See the License for the        *
+// * specific language governing permissions and limitations under the 
License.                                              *
+// 
***************************************************************************************************************************
+package org.apache.juneau.server.test;
+
+import static org.junit.Assert.*;
+
+import org.apache.juneau.client.*;
+import org.apache.juneau.json.*;
+import org.junit.*;
+
+public class TransformsTest {
+
+       private static String URL = "/testTransforms";
+
+       
//====================================================================================================
+       // test1 - Test class transform overrides parent class transform
+       // Should return "A2-1".
+       
//====================================================================================================
+       @Test
+       public void testClassTransformOverridesParentClassTransform() throws 
Exception {
+               RestClient client = new TestRestClient(JsonSerializer.DEFAULT, 
JsonParser.DEFAULT);
+               String r;
+               String url = URL + 
"/testClassTransformOverridesParentClassTransform";
+
+               r = client.doGet(url).getResponse(String.class);
+               assertEquals("A2-0", r);
+
+               r = client.doPut(url, "A2-1").getResponse(String.class);
+               assertEquals("A2-1", r);
+
+               r = client.doPut(url + "/A2-2", "").getResponse(String.class);
+               assertEquals("A2-2", r);
+
+               client.closeQuietly();
+       }
+
+       
//====================================================================================================
+       // Test method transform overrides class transform
+       // Should return "A3-1".
+       
//====================================================================================================
+       @Test
+       public void testMethodTransformOverridesClassTransform() throws 
Exception {
+               RestClient client = new TestRestClient(JsonSerializer.DEFAULT, 
JsonParser.DEFAULT);
+               String r;
+               String url = URL + 
"/testMethodTransformOverridesClassTransform";
+
+               r = client.doGet(url).getResponse(String.class);
+               assertEquals("A3-0", r);
+
+               r = client.doPut(url, "A3-1").getResponse(String.class);
+               assertEquals("A3-1", r);
+
+               r = client.doPut(url + "/A3-2", "").getResponse(String.class);
+               assertEquals("A3-2", r);
+
+               client.closeQuietly();
+       }
+}

Reply via email to