http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/91a388d0/juneau-server-test/src/main/java/org/apache/juneau/server/test/NoParserInputResource.java ---------------------------------------------------------------------- diff --git a/juneau-server-test/src/main/java/org/apache/juneau/server/test/NoParserInputResource.java b/juneau-server-test/src/main/java/org/apache/juneau/server/test/NoParserInputResource.java deleted file mode 100755 index 4a1b072..0000000 --- a/juneau-server-test/src/main/java/org/apache/juneau/server/test/NoParserInputResource.java +++ /dev/null @@ -1,56 +0,0 @@ -// *************************************************************************************************************************** -// * 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.io.*; - -import org.apache.juneau.internal.*; -import org.apache.juneau.plaintext.*; -import org.apache.juneau.server.*; -import org.apache.juneau.server.annotation.*; - -/** - * JUnit automated testcase resource. - */ -@RestResource( - path="/testNoParserInput", - serializers=PlainTextSerializer.class -) -public class NoParserInputResource extends RestServlet { - private static final long serialVersionUID = 1L; - - //==================================================================================================== - // @Body annotated InputStream. - //==================================================================================================== - @RestMethod(name="PUT", path="/testInputStream") - public String testInputStream(@Body InputStream in) throws Exception { - return IOUtils.read(in); - } - - //==================================================================================================== - // @Body annotated Reader. - //==================================================================================================== - @RestMethod(name="PUT", path="/testReader") - public String testReader(@Body Reader in) throws Exception { - return IOUtils.read(in); - } - - //==================================================================================================== - // @Body annotated PushbackReader. - // This should always fail since the servlet reader is not a pushback reader. - //==================================================================================================== - @RestMethod(name="PUT", path="/testPushbackReader") - public String testPushbackReader(@Body PushbackReader in) throws Exception { - return IOUtils.read(in); - } -}
http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/91a388d0/juneau-server-test/src/main/java/org/apache/juneau/server/test/OnPostCallResource.java ---------------------------------------------------------------------- diff --git a/juneau-server-test/src/main/java/org/apache/juneau/server/test/OnPostCallResource.java b/juneau-server-test/src/main/java/org/apache/juneau/server/test/OnPostCallResource.java deleted file mode 100755 index c2f656f..0000000 --- a/juneau-server-test/src/main/java/org/apache/juneau/server/test/OnPostCallResource.java +++ /dev/null @@ -1,94 +0,0 @@ -// *************************************************************************************************************************** -// * 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 org.apache.juneau.*; -import org.apache.juneau.annotation.*; -import org.apache.juneau.serializer.*; -import org.apache.juneau.server.*; -import org.apache.juneau.server.annotation.*; - -/** - * JUnit automated testcase resource. - * Validates that headers - */ -@RestResource( - path="/testOnPostCall", - serializers=OnPostCallResource.TestSerializer.class, - properties={ - @Property(name="p1",value="sp1"), // Unchanged servlet-level property. - @Property(name="p2",value="sp2"), // Servlet-level property overridden by onPostCall. - @Property(name="p3",value="sp3"), // Servlet-level property overridded by method. - @Property(name="p4",value="sp4") // Servlet-level property overridden by method then onPostCall. - } -) -public class OnPostCallResource extends RestServlet { - private static final long serialVersionUID = 1L; - - @Produces("text/s1,text/s2,text/s3") - public static class TestSerializer extends WriterSerializer { - @Override /* Serializer */ - protected void doSerialize(SerializerSession session, Object o) throws Exception { - ObjectMap p = session.getProperties(); - session.getWriter().write("p1="+p.get("p1")+",p2="+p.get("p2")+",p3="+p.get("p3")+",p4="+p.get("p4")+",p5="+p.get("p5")+",contentType="+session.getProperties().getString("mediaType")); - } - @Override /* Serializer */ - public ObjectMap getResponseHeaders(ObjectMap properties) { - if (properties.containsKey("Override-Content-Type")) - return new ObjectMap().append("Content-Type", properties.get("Override-Content-Type")); - return null; - } - } - - @Override /* RestServlet */ - protected void onPostCall(RestRequest req, RestResponse res) { - ObjectMap properties = req.getProperties(); - properties.put("p2", "xp2"); - properties.put("p4", "xp4"); - properties.put("p5", "xp5"); // New property - String overrideAccept = req.getHeader("Override-Accept"); - if (overrideAccept != null) - req.setHeader("Accept", overrideAccept); - String overrideContentType = req.getHeader("Override-Content-Type"); - if (overrideContentType != null) - properties.put("Override-Content-Type", overrideContentType); - } - - - //==================================================================================================== - // Test1 - Properties overridden via properties annotation. - //==================================================================================================== - @RestMethod(name="PUT", path="/testPropertiesOverridenByAnnotation", - properties={ - @Property(name="p3",value="mp3"), - @Property(name="p4",value="mp4") - }, - defaultRequestHeaders="Accept: text/s2" - ) - public String testPropertiesOverridenByAnnotation() { - return ""; - } - - //==================================================================================================== - // Test2 - Properties overridden programmatically. - //==================================================================================================== - @RestMethod(name="PUT", path="/testPropertiesOverriddenProgramatically") - public String testPropertiesOverriddenProgramatically(RestRequest req, @Properties ObjectMap properties) throws Exception { - properties.put("p3", "pp3"); - properties.put("p4", "pp4"); - String accept = req.getHeader("Accept"); - if (accept == null || accept.isEmpty()) - req.setHeader("Accept", "text/s2"); - return ""; - } -} http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/91a388d0/juneau-server-test/src/main/java/org/apache/juneau/server/test/OnPreCallResource.java ---------------------------------------------------------------------- diff --git a/juneau-server-test/src/main/java/org/apache/juneau/server/test/OnPreCallResource.java b/juneau-server-test/src/main/java/org/apache/juneau/server/test/OnPreCallResource.java deleted file mode 100755 index dcbc8be..0000000 --- a/juneau-server-test/src/main/java/org/apache/juneau/server/test/OnPreCallResource.java +++ /dev/null @@ -1,85 +0,0 @@ -// *************************************************************************************************************************** -// * 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 org.apache.juneau.*; -import org.apache.juneau.annotation.*; -import org.apache.juneau.parser.*; -import org.apache.juneau.plaintext.*; -import org.apache.juneau.server.*; -import org.apache.juneau.server.annotation.*; - -/** - * JUnit automated testcase resource. - * Validates that headers - */ -@RestResource( - path="/testOnPreCall", - parsers=OnPreCallResource.TestParserA.class, - serializers=PlainTextSerializer.class, - properties={ - @Property(name="p1",value="sp1"), // Unchanged servlet-level property. - @Property(name="p2",value="sp2"), // Servlet-level property overridden by onPreCall. - @Property(name="p3",value="sp3"), // Servlet-level property overridded by method. - @Property(name="p4",value="sp4") // Servlet-level property overridden by method then onPreCall. - } -) -public class OnPreCallResource extends RestServlet { - private static final long serialVersionUID = 1L; - - @Consumes("text/a1,text/a2,text/a3") - public static class TestParserA extends ReaderParser { - @SuppressWarnings("unchecked") - @Override /* Parser */ - protected <T> T doParse(ParserSession session, ClassMeta<T> type) throws Exception { - ObjectMap p = session.getProperties(); - String matchingContentType = session.getProperties().getString("mediaType"); - return (T)("p1="+p.get("p1")+",p2="+p.get("p2")+",p3="+p.get("p3")+",p4="+p.get("p4")+",p5="+p.get("p5")+",contentType="+matchingContentType); - } - } - - @Override /* RestServlet */ - protected void onPreCall(RestRequest req) { - ObjectMap properties = req.getProperties(); - properties.put("p2", "xp2"); - properties.put("p4", "xp4"); - properties.put("p5", "xp5"); // New property - String overrideContentType = req.getHeader("Override-Content-Type"); - if (overrideContentType != null) - req.setHeader("Content-Type", overrideContentType); - } - - - //==================================================================================================== - // Properties overridden via properties annotation. - //==================================================================================================== - @RestMethod(name="PUT", path="/testPropertiesOverriddenByAnnotation", - properties={ - @Property(name="p3",value="mp3"), - @Property(name="p4",value="mp4") - } - ) - public String testPropertiesOverriddenByAnnotation(@Body String in) { - return in; - } - - //==================================================================================================== - // Properties overridden programmatically. - //==================================================================================================== - @RestMethod(name="PUT", path="/testPropertiesOverriddenProgrammatically") - public String testPropertiesOverriddenProgrammatically(RestRequest req, @Properties ObjectMap properties) throws Exception { - properties.put("p3", "pp3"); - properties.put("p4", "pp4"); - return req.getBody(String.class); - } -} http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/91a388d0/juneau-server-test/src/main/java/org/apache/juneau/server/test/OptionsWithoutNlsResource.java ---------------------------------------------------------------------- diff --git a/juneau-server-test/src/main/java/org/apache/juneau/server/test/OptionsWithoutNlsResource.java b/juneau-server-test/src/main/java/org/apache/juneau/server/test/OptionsWithoutNlsResource.java deleted file mode 100755 index fe17127..0000000 --- a/juneau-server-test/src/main/java/org/apache/juneau/server/test/OptionsWithoutNlsResource.java +++ /dev/null @@ -1,44 +0,0 @@ -// *************************************************************************************************************************** -// * 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 org.apache.juneau.dto.swagger.*; -import org.apache.juneau.server.*; -import org.apache.juneau.server.annotation.*; - -/** - * JUnit automated testcase resource. - */ -@RestResource( - path="/testOptionsWithoutNls" -) -public class OptionsWithoutNlsResource extends RestServletDefault { - private static final long serialVersionUID = 1L; - - //==================================================================================================== - // Should get to the options page without errors - //==================================================================================================== - @RestMethod(name="OPTIONS", path="/testOptions/*") - public Swagger testOptions(RestRequest req) { - return req.getSwagger(); - } - - //==================================================================================================== - // Missing resource bundle should cause {!!x} string. - //==================================================================================================== - @RestMethod(name="GET", path="/testMissingResourceBundle") - public String test(RestRequest req) { - return req.getMessage("bad", 1, 2, 3); - } - -} http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/91a388d0/juneau-server-test/src/main/java/org/apache/juneau/server/test/OverlappingMethodsResource.java ---------------------------------------------------------------------- diff --git a/juneau-server-test/src/main/java/org/apache/juneau/server/test/OverlappingMethodsResource.java b/juneau-server-test/src/main/java/org/apache/juneau/server/test/OverlappingMethodsResource.java deleted file mode 100755 index 9c5d3ff..0000000 --- a/juneau-server-test/src/main/java/org/apache/juneau/server/test/OverlappingMethodsResource.java +++ /dev/null @@ -1,146 +0,0 @@ -// *************************************************************************************************************************** -// * 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 org.apache.juneau.plaintext.*; -import org.apache.juneau.server.*; -import org.apache.juneau.server.annotation.*; - -/** - * JUnit automated testcase resource. - */ -@RestResource( - path="/testOverlappingMethods", - serializers=PlainTextSerializer.class -) -public class OverlappingMethodsResource extends RestServletDefault { - private static final long serialVersionUID = 1L; - - //==================================================================================================== - // Overlapping guards - //==================================================================================================== - @RestMethod(name="GET", path="/testOverlappingGuards1", guards=Test1Guard.class) - public String testOverlappingGuards1() { - return "test1_doGet"; - } - - //==================================================================================================== - // Overlapping guards - //==================================================================================================== - @RestMethod(name="GET", path="/testOverlappingGuards2", guards={Test1Guard.class, Test2Guard.class}) - public String testOverlappingGuards2() { - return "test2_doGet"; - } - - public static class Test1Guard extends RestGuard { - @Override /* RestGuard */ - public boolean isRequestAllowed(RestRequest req) { - return req.getQueryParameter("t1","").equals("1"); - } - } - - public static class Test2Guard extends RestGuard { - @Override /* RestGuard */ - public boolean isRequestAllowed(RestRequest req) { - return req.getQueryParameter("t2","").equals("2"); - } - } - - //==================================================================================================== - // Overlapping matchers - //==================================================================================================== - @RestMethod(name="GET", path="/testOverlappingMatchers1", matchers=Test3aMatcher.class) - public String testOverlappingMatchers1() { - return "test3a"; - } - - @RestMethod(name="GET", path="/testOverlappingMatchers1", matchers=Test3bMatcher.class) - public String test3b_doGet() { - return "test3b"; - } - - @RestMethod(name="GET", path="/testOverlappingMatchers1") - public String test3c_doGet() { - return "test3c"; - } - - public static class Test3aMatcher extends RestMatcher { - @Override /* RestMatcher */ - public boolean matches(RestRequest req) { - return req.getQueryParameter("t1","").equals("1"); - } - } - - public static class Test3bMatcher extends RestMatcher { - @Override /* RestMatcher */ - public boolean matches(RestRequest req) { - return req.getQueryParameter("t2","").equals("2"); - } - } - - //==================================================================================================== - // Overlapping matchers - //==================================================================================================== - @RestMethod(name="GET", path="/testOverlappingMatchers2") - public String test4a_doGet() { - return "test4a"; - } - - @RestMethod(name="GET", path="/testOverlappingMatchers2", matchers={Test3aMatcher.class, Test3bMatcher.class}) - public String test4b_doGet() { - return "test4b"; - } - - //==================================================================================================== - // Overlapping URL patterns - //==================================================================================================== - @RestMethod(name="GET", path="/testOverlappingUrlPatterns") - public String testOverlappingUrlPatterns1() { - return "test5a"; - } - - @RestMethod(name="GET", path="/testOverlappingUrlPatterns/*") - public String testOverlappingUrlPatterns2() { - return "test5b"; - } - - @RestMethod(name="GET", path="/testOverlappingUrlPatterns/foo") - public String testOverlappingUrlPatterns3() { - return "test5c"; - } - - @RestMethod(name="GET", path="/testOverlappingUrlPatterns/foo/*") - public String testOverlappingUrlPatterns4() { - return "test5d"; - } - - @RestMethod(name="GET", path="/testOverlappingUrlPatterns/{id}") - public String testOverlappingUrlPatterns5() { - return "test5e"; - } - - @RestMethod(name="GET", path="/testOverlappingUrlPatterns/{id}/*") - public String testOverlappingUrlPatterns6() { - return "test5f"; - } - - @RestMethod(name="GET", path="/testOverlappingUrlPatterns/{id}/foo") - public String testOverlappingUrlPatterns7() { - return "test5g"; - } - - @RestMethod(name="GET", path="/testOverlappingUrlPatterns/{id}/foo/*") - public String testOverlappingUrlPatterns8() { - return "test5h"; - } -} http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/91a388d0/juneau-server-test/src/main/java/org/apache/juneau/server/test/ParamsResource.java ---------------------------------------------------------------------- diff --git a/juneau-server-test/src/main/java/org/apache/juneau/server/test/ParamsResource.java b/juneau-server-test/src/main/java/org/apache/juneau/server/test/ParamsResource.java deleted file mode 100755 index bb095d2..0000000 --- a/juneau-server-test/src/main/java/org/apache/juneau/server/test/ParamsResource.java +++ /dev/null @@ -1,293 +0,0 @@ -// *************************************************************************************************************************** -// * 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.RestServletContext.*; -import static org.apache.juneau.urlencoding.UrlEncodingContext.*; - -import java.util.*; - -import javax.servlet.http.*; - -import org.apache.juneau.*; -import org.apache.juneau.json.*; -import org.apache.juneau.plaintext.*; -import org.apache.juneau.samples.addressbook.*; -import org.apache.juneau.server.*; -import org.apache.juneau.server.annotation.*; -import org.apache.juneau.transforms.*; -import org.apache.juneau.urlencoding.*; - -/** - * JUnit automated testcase resource. - */ -@RestResource( - path="/testParams", - serializers=PlainTextSerializer.class, - properties={ - @Property(name=REST_allowMethodParam, value="*") - } -) -public class ParamsResource extends RestServletDefault { - private static final long serialVersionUID = 1L; - - //==================================================================================================== - // Basic tests - //==================================================================================================== - @RestMethod(name="GET", path="/") - public void doGet(RestResponse res) { - res.setOutput("GET"); - } - - @RestMethod(name="GET", path="/get1") - public String doGet1() { - return "GET /get1"; - } - - @RestMethod(name="GET", path="/get1/{foo}") - public void doGet1a(RestResponse res, String foo) { - res.setOutput("GET /get1a " + foo); - } - - @RestMethod(name="GET", path="/get1/{foo}/{bar}") - public void doGet1b(RestResponse res, String foo, String bar) { - res.setOutput("GET /get1b " + foo + "," + bar); - } - - @RestMethod(name="GET", path="/get3/{foo}/{bar}/*") - public void doGet3(HttpServletRequest reqx, HttpServletResponse resx, String foo, int bar) { - RestRequest req = (RestRequest)reqx; - RestResponse res = (RestResponse)resx; - res.setOutput("GET /get3/"+foo+"/"+bar+" remainder="+req.getPathRemainder()); - } - - // Test method name with overlapping name, remainder allowed. - @RestMethod(name="GET2") - public void get2(RestRequest req, RestResponse res) { - res.setOutput("GET2 remainder="+req.getPathRemainder()); - } - - // Default POST - @RestMethod(name="POST") - public void doPost(RestRequest req, RestResponse res) { - res.setOutput("POST remainder="+req.getPathRemainder()); - } - - // Bean parameter - @RestMethod(name="POST", path="/person/{person}") - public void doPost(RestRequest req, RestResponse res, Person p) { - res.setOutput("POST /person/{name="+p.name+",birthDate.year="+p.birthDate.get(Calendar.YEAR)+"} remainder="+req.getPathRemainder()); - } - - // Various primitive types - @RestMethod(name="PUT", path="/primitives/{xInt}/{xShort}/{xLong}/{xChar}/{xFloat}/{xDouble}/{xByte}/{xBoolean}") - public void doPut1(RestResponse res, int xInt, short xShort, long xLong, char xChar, float xFloat, double xDouble, byte xByte, boolean xBoolean) { - res.setOutput("PUT /primitives/"+xInt+"/"+xShort+"/"+xLong+"/"+xChar+"/"+xFloat+"/"+xDouble+"/"+xByte+"/"+xBoolean); - } - - // Various primitive objects - @RestMethod(name="PUT", path="/primitiveObjects/{xInt}/{xShort}/{xLong}/{xChar}/{xFloat}/{xDouble}/{xByte}/{xBoolean}") - public void doPut2(RestResponse res, Integer xInt, Short xShort, Long xLong, Character xChar, Float xFloat, Double xDouble, Byte xByte, Boolean xBoolean) { - res.setOutput("PUT /primitiveObjects/"+xInt+"/"+xShort+"/"+xLong+"/"+xChar+"/"+xFloat+"/"+xDouble+"/"+xByte+"/"+xBoolean); - } - - // Object with forString(String) method - @RestMethod(name="PUT", path="/uuid/{uuid}") - public void doPut1(RestResponse res, UUID uuid) { - res.setOutput("PUT /uuid/"+uuid); - } - - @Override /* RestServlet */ - public Class<?>[] createPojoSwaps() { - return new Class[]{CalendarSwap.DateMedium.class}; - } - - //==================================================================================================== - // @FormData annotation - GET - //==================================================================================================== - @RestMethod(name="GET", path="/testParamGet/*") - public String testParamGet(RestRequest req, @Query("p1") String p1, @Query("p2") int p2) throws Exception { - return "p1=["+p1+","+req.getQueryParameter("p1")+","+req.getQueryParameter("p1", String.class)+"],p2=["+p2+","+req.getQueryParameter("p2")+","+req.getQueryParameter("p2", int.class)+"]"; - } - - //==================================================================================================== - // @FormData annotation - POST - //==================================================================================================== - @RestMethod(name="POST", path="/testParamPost/*") - public String testParamPost(RestRequest req, @FormData("p1") String p1, @FormData("p2") int p2) throws Exception { - return "p1=["+p1+","+req.getFormDataParameter("p1")+","+req.getFormDataParameter("p1", String.class)+"],p2=["+p2+","+req.getFormDataParameter("p2")+","+req.getFormDataParameter("p2", int.class)+"]"; - } - - //==================================================================================================== - // @Query annotation - GET - //==================================================================================================== - @RestMethod(name="GET", path="/testQParamGet/*") - public String testQParamGet(RestRequest req, @Query("p1") String p1, @Query("p2") int p2) throws Exception { - return "p1=["+p1+","+req.getQueryParameter("p1")+","+req.getQueryParameter("p1", String.class)+"],p2=["+p2+","+req.getQueryParameter("p2")+","+req.getQueryParameter("p2", int.class)+"]"; - } - - //==================================================================================================== - // @Query annotation - POST - //==================================================================================================== - @RestMethod(name="POST", path="/testQParamPost/*") - public String testQParamPost(RestRequest req, @Query("p1") String p1, @Query("p2") int p2) throws Exception { - return "p1=["+p1+","+req.getQueryParameter("p1")+","+req.getQueryParameter("p1", String.class)+"],p2=["+p2+","+req.getQueryParameter("p2")+","+req.getQueryParameter("p2", int.class)+"]"; - } - - //==================================================================================================== - // @FormData(format=PLAIN) annotation - GET - //==================================================================================================== - @RestMethod(name="GET", path="/testPlainParamGet/*") - public String testPlainParamGet(RestRequest req, @Query(value="p1",format="PLAIN") String p1) throws Exception { - return "p1=["+p1+","+req.getQueryParameter("p1")+","+req.getQueryParameter("p1", String.class)+"]"; - } - - //==================================================================================================== - // @FormData(format=PLAIN) annotation - POST - //==================================================================================================== - @RestMethod(name="POST", path="/testPlainParamPost/*") - public String testPlainParamPost(RestRequest req, @FormData(value="p1",format="PLAIN") String p1) throws Exception { - return "p1=["+p1+","+req.getFormDataParameter("p1")+","+req.getFormDataParameter("p1", String.class)+"]"; - } - - //==================================================================================================== - // @Query(format=PLAIN) annotation - GET - //==================================================================================================== - @RestMethod(name="GET", path="/testPlainQParamGet/*") - public String testPlainQParamGet(RestRequest req, @Query(value="p1",format="PLAIN") String p1) throws Exception { - return "p1=["+p1+","+req.getQueryParameter("p1")+","+req.getQueryParameter("p1", String.class)+"]"; - } - - //==================================================================================================== - // @Query(format=PLAIN) annotation - POST - //==================================================================================================== - @RestMethod(name="POST", path="/testPlainQParamPost/*") - public String testPlainQParamPost(RestRequest req, @Query(value="p1",format="PLAIN") String p1) throws Exception { - return "p1=["+p1+","+req.getQueryParameter("p1")+","+req.getQueryParameter("p1", String.class)+"]"; - } - - //==================================================================================================== - // @HasQuery annotation - GET - //==================================================================================================== - @RestMethod(name="GET", path="/testHasParamGet/*") - public String testHasParamGet(RestRequest req, @HasQuery("p1") boolean p1, @HasQuery("p2") Boolean p2) throws Exception { - return "p1=["+p1+","+req.hasQueryParameter("p1")+"],p2=["+p2+","+req.hasQueryParameter("p2")+"]"; - } - - //==================================================================================================== - // @HasQuery annotation - POST - //==================================================================================================== - @RestMethod(name="POST", path="/testHasParamPost/*") - public String testHasParamPost(RestRequest req, @HasFormData("p1") boolean p1, @HasFormData("p2") Boolean p2) throws Exception { - return "p1=["+p1+","+req.hasFormDataParameter("p1")+"],p2=["+p2+","+req.hasFormDataParameter("p2")+"]"; - } - - //==================================================================================================== - // @HasQuery annotation - GET - //==================================================================================================== - @RestMethod(name="GET", path="/testHasQParamGet/*") - public String testHasQParamGet(RestRequest req, @HasQuery("p1") boolean p1, @HasQuery("p2") Boolean p2) throws Exception { - return "p1=["+p1+","+req.hasQueryParameter("p1")+"],p2=["+p2+","+req.hasQueryParameter("p2")+"]"; - } - - //==================================================================================================== - // @HasQuery annotation - POST - //==================================================================================================== - @RestMethod(name="POST", path="/testHasQParamPost/*") - public String testHasQParamPost_post(RestRequest req, @HasQuery("p1") boolean p1, @HasQuery("p2") Boolean p2) throws Exception { - return "p1=["+p1+","+req.hasQueryParameter("p1")+"],p2=["+p2+","+req.hasQueryParameter("p2")+"]"; - } - - //==================================================================================================== - // Form POSTS with @Body parameter - //==================================================================================================== - @RestMethod(name="POST", path="/testFormPostAsContent/*") - public String testFormPostAsContent(@Body Test6Bean bean, - @HasQuery("p1") boolean hqp1, @HasQuery("p2") boolean hqp2, - @Query("p1") String qp1, @Query("p2") int qp2) throws Exception { - return "bean=["+JsonSerializer.DEFAULT_LAX.toString(bean)+"],qp1=["+qp1+"],qp2=["+qp2+"],hqp1=["+hqp1+"],hqp2=["+hqp2+"]"; - } - - public static class Test6Bean { - public String p1; - public int p2; - } - - //==================================================================================================== - // Test @FormData and @Query annotations when using multi-part parameters (e.g. &key=val1,&key=val2). - //==================================================================================================== - @RestMethod(name="GET", path="/testMultiPartParams") - public String testMultiPartParams( - @Query(value="p1",multipart=true) String[] p1, - @Query(value="p2",multipart=true) int[] p2, - @Query(value="p3",multipart=true) List<String> p3, - @Query(value="p4",multipart=true) List<Integer> p4, - @Query(value="p5",multipart=true) String[] p5, - @Query(value="p6",multipart=true) int[] p6, - @Query(value="p7",multipart=true) List<String> p7, - @Query(value="p8",multipart=true) List<Integer> p8, - @Query(value="p9",multipart=true) A[] p9, - @Query(value="p10",multipart=true) List<A> p10, - @Query(value="p11",multipart=true) A[] p11, - @Query(value="p12",multipart=true) List<A> p12) throws Exception { - ObjectMap m = new ObjectMap() - .append("p1", p1) - .append("p2", p2) - .append("p3", p3) - .append("p4", p4) - .append("p5", p5) - .append("p6", p6) - .append("p7", p7) - .append("p8", p8) - .append("p9", p9) - .append("p10", p10) - .append("p11", p11) - .append("p12", p12); - return JsonSerializer.DEFAULT_LAX.toString(m); - } - - public static class A { - public String a; - public int b; - public boolean c; - } - - //==================================================================================================== - // Test multi-part parameter keys on bean properties of type array/Collection (i.e. &key=val1,&key=val2) - // using URLENC_expandedParams property. - // A simple round-trip test to verify that both serializing and parsing works. - //==================================================================================================== - @RestMethod(name="POST", path="/testFormPostsWithMultiParamsUsingProperty", - properties={ - @Property(name=URLENC_expandedParams, value="true"), - @Property(name=UonSerializerContext.UON_simpleMode, value="true") - } - ) - public DTO2s.B testFormPostsWithMultiParamsViaProperty(@Body DTO2s.B content) throws Exception { - return content; - } - - //==================================================================================================== - // Test multi-part parameter keys on bean properties of type array/Collection (i.e. &key=val1,&key=val2) - // using @UrlEncoding(expandedParams=true) annotation. - // A simple round-trip test to verify that both serializing and parsing works. - //==================================================================================================== - @RestMethod(name="POST", path="/testFormPostsWithMultiParamsUsingAnnotation", - properties={ - @Property(name=UonSerializerContext.UON_simpleMode, value="true") - } - ) - public DTO2s.C testFormPostsWithMultiParamsUsingAnnotation(@Body DTO2s.C content) throws Exception { - return content; - } -} http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/91a388d0/juneau-server-test/src/main/java/org/apache/juneau/server/test/ParsersResource.java ---------------------------------------------------------------------- diff --git a/juneau-server-test/src/main/java/org/apache/juneau/server/test/ParsersResource.java b/juneau-server-test/src/main/java/org/apache/juneau/server/test/ParsersResource.java deleted file mode 100755 index 608f9d5..0000000 --- a/juneau-server-test/src/main/java/org/apache/juneau/server/test/ParsersResource.java +++ /dev/null @@ -1,112 +0,0 @@ -// *************************************************************************************************************************** -// * 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.annotation.Inherit.*; - -import org.apache.juneau.*; -import org.apache.juneau.annotation.*; -import org.apache.juneau.internal.*; -import org.apache.juneau.parser.*; -import org.apache.juneau.plaintext.*; -import org.apache.juneau.server.*; -import org.apache.juneau.server.annotation.*; - -/** - * JUnit automated testcase resource. - * Validates correct parser is used. - */ -@RestResource( - path="/testParsers", - parsers=ParsersResource.TestParserA.class, - serializers=PlainTextSerializer.class -) -public class ParsersResource extends RestServletDefault { - private static final long serialVersionUID = 1L; - - @Consumes("text/a") - public static class TestParserA extends ReaderParser { - @SuppressWarnings("unchecked") - @Override /* Parser */ - protected <T> T doParse(ParserSession session, ClassMeta<T> type) throws Exception { - return (T)("text/a - " + IOUtils.read(session.getReader()).trim()); - } - } - - //==================================================================================================== - // Parser defined on class. - //==================================================================================================== - @RestMethod(name="PUT", path="/testParserOnClass") - public String testParserOnClass(@Body String in) { - return in; - } - - //==================================================================================================== - // Parser defined on method. - //==================================================================================================== - @RestMethod(name="PUT", path="/testParserOnMethod", parsers=TestParserB.class) - public String testParserOnMethod(@Body String in) { - return in; - } - - @Consumes("text/b") - public static class TestParserB extends ReaderParser { - @SuppressWarnings("unchecked") - @Override /* Parser */ - protected <T> T doParse(ParserSession session, ClassMeta<T> type) throws Exception { - return (T)("text/b - " + IOUtils.read(session.getReader()).trim()); - } - } - - //==================================================================================================== - // Parser overridden on method. - //==================================================================================================== - @RestMethod(name="PUT", path="/testParserOverriddenOnMethod", parsers={TestParserB.class,TestParserC.class}, parsersInherit=PARSERS) - public String testParserOverriddenOnMethod(@Body String in) { - return in; - } - - @Consumes("text/c") - public static class TestParserC extends ReaderParser { - @SuppressWarnings("unchecked") - @Override /* Parser */ - protected <T> T doParse(ParserSession session, ClassMeta<T> type) throws Exception { - return (T)("text/c - " + IOUtils.read(session.getReader()).trim()); - } - } - - //==================================================================================================== - // Parser with different Accept than Content-Type. - //==================================================================================================== - @RestMethod(name="PUT", path="/testParserWithDifferentMediaTypes", parsers={TestParserD.class}, parsersInherit=PARSERS) - public String testParserWithDifferentMediaTypes(@Body String in) { - return in; - } - - @Consumes("text/a,text/d") - public static class TestParserD extends ReaderParser { - @SuppressWarnings("unchecked") - @Override /* Parser */ - protected <T> T doParse(ParserSession session, ClassMeta<T> type) throws Exception { - return (T)("text/d - " + IOUtils.read(session.getReader()).trim()); - } - } - - //==================================================================================================== - // Check for valid error response. - //==================================================================================================== - @RestMethod(name="PUT", path="/testValidErrorResponse") - public String testValidErrorResponse(@Body String in) { - return in; - } -} http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/91a388d0/juneau-server-test/src/main/java/org/apache/juneau/server/test/PathResource.java ---------------------------------------------------------------------- diff --git a/juneau-server-test/src/main/java/org/apache/juneau/server/test/PathResource.java b/juneau-server-test/src/main/java/org/apache/juneau/server/test/PathResource.java deleted file mode 100755 index e6aa718..0000000 --- a/juneau-server-test/src/main/java/org/apache/juneau/server/test/PathResource.java +++ /dev/null @@ -1,69 +0,0 @@ -// *************************************************************************************************************************** -// * 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 org.apache.juneau.server.*; -import org.apache.juneau.server.annotation.*; - -/** - * JUnit automated testcase resource. - * Tests the RestServlet.getPath() method. - */ -@RestResource( - path="/testPath", - children={ - PathResource.TestPath2.class - } -) -public class PathResource extends RestServletDefault { - private static final long serialVersionUID = 1L; - - //==================================================================================================== - // Basic tests - //==================================================================================================== - @RestMethod(name="GET", path="/") - public String doGet() { - return getPath(); - } - - @RestResource( - path="/testPath2", - children={ - PathResource.TestPath3.class - } - ) - public static class TestPath2 extends RestServletDefault { - private static final long serialVersionUID = 1L; - // Basic tests - @RestMethod(name="GET", path="/") - public String doGet() { - return getPath(); - } - } - - @RestResource( - path="/testPath3" - ) - public static class TestPath3a extends RestServletDefault { - private static final long serialVersionUID = 1L; - // Basic tests - @RestMethod(name="GET", path="/") - public String doGet() { - return getPath(); - } - } - - public static class TestPath3 extends TestPath3a { - private static final long serialVersionUID = 1L; - } -} http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/91a388d0/juneau-server-test/src/main/java/org/apache/juneau/server/test/PathsResource.java ---------------------------------------------------------------------- diff --git a/juneau-server-test/src/main/java/org/apache/juneau/server/test/PathsResource.java b/juneau-server-test/src/main/java/org/apache/juneau/server/test/PathsResource.java deleted file mode 100755 index 5530e1a..0000000 --- a/juneau-server-test/src/main/java/org/apache/juneau/server/test/PathsResource.java +++ /dev/null @@ -1,73 +0,0 @@ -// *************************************************************************************************************************** -// * 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 org.apache.juneau.*; -import org.apache.juneau.server.*; -import org.apache.juneau.server.annotation.*; - -/** - * JUnit automated testcase resource. - * Tests the URL-related methods on RestRequest. - */ -@RestResource( - path="/testPaths", - children={ - PathsResource.A.class - } -) -public class PathsResource extends RestServletDefault { - private static final long serialVersionUID = 1L; - - @RestMethod(name="GET", path="/*") - public ObjectMap doGet1(RestRequest req, @PathRemainder String r) { - return getPaths(req).append("pathRemainder2", r).append("method",1); - } - - @RestMethod(name="GET", path="/test2/*") - public ObjectMap doGet2(RestRequest req, @PathRemainder String r) { - return getPaths(req).append("pathRemainder2", r).append("method",2); - } - - @RestResource( - path="/a" - ) - public static class A extends RestServletDefault { - private static final long serialVersionUID = 1L; - @RestMethod(name="GET", path="/*") - public ObjectMap doGet1(RestRequest req, @PathRemainder String r) { - return getPaths(req).append("pathRemainder2", r).append("method",3); - } - @RestMethod(name="GET", path="/test2/*") - public ObjectMap doGet2(RestRequest req, @PathRemainder String r) { - return getPaths(req).append("pathRemainder2", r).append("method",4); - } - } - - private static ObjectMap getPaths(RestRequest req) { - return new ObjectMap() - .append("pathInfo", req.getPathInfo()) - .append("pathInfoUndecoded", req.getPathInfoUndecoded()) - .append("pathInfoParts", req.getPathInfoParts()) - .append("pathRemainder", req.getPathRemainder()) - .append("pathRemainderUndecoded", req.getPathRemainderUndecoded()) - .append("requestURI", req.getRequestURI()) - .append("requestParentURI", req.getRequestParentURI()) - .append("requestURL", req.getRequestURL()) - .append("servletPath", req.getServletPath()) - .append("servletURI", req.getServletURI()) - .append("servletParentURI", req.getServletParentURI()) - .append("relativeServletURI", req.getRelativeServletURI()); - - } -} http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/91a388d0/juneau-server-test/src/main/java/org/apache/juneau/server/test/PropertiesResource.java ---------------------------------------------------------------------- diff --git a/juneau-server-test/src/main/java/org/apache/juneau/server/test/PropertiesResource.java b/juneau-server-test/src/main/java/org/apache/juneau/server/test/PropertiesResource.java deleted file mode 100755 index 73b8775..0000000 --- a/juneau-server-test/src/main/java/org/apache/juneau/server/test/PropertiesResource.java +++ /dev/null @@ -1,89 +0,0 @@ -// *************************************************************************************************************************** -// * 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 java.lang.String.*; - -import org.apache.juneau.*; -import org.apache.juneau.annotation.*; -import org.apache.juneau.serializer.*; -import org.apache.juneau.server.*; -import org.apache.juneau.server.annotation.*; - -/** - * JUnit automated testcase resource. - */ -@RestResource( - path="/testProperties", - properties={ - @Property(name="A1",value="a1"), - @Property(name="A2",value="a2"), - @Property(name="foo",value="bar"), - @Property(name="bar",value="baz"), - @Property(name="R1a",value="$R{requestURI}"), - @Property(name="R1b",value="$R{requestParentURI}"), - @Property(name="R2",value="$R{foo}"), - @Property(name="R3",value="$R{$R{foo}}"), - @Property(name="R4",value="$R{A1}"), - @Property(name="R5",value="$R{A2}"), - @Property(name="R6",value="$R{C}"), - } -) -public class PropertiesResource extends RestServletDefault { - private static final long serialVersionUID = 1L; - - //==================================================================================================== - // Properties defined on method. - //==================================================================================================== - @RestMethod(name="GET", path="/testPropertiesDefinedOnMethod", - properties={ - @Property(name="B1",value="b1"), - @Property(name="B2",value="b2") - }, - serializers=PropertySerializer1.class - ) - public void testPropertiesDefinedOnMethod(RestResponse res) { - res.setProperty("A2", "c"); - res.setProperty("B2", "c"); - res.setProperty("C", "c"); - res.setOutput(null); - } - - @Produces("application/json,text/json") - public static class PropertySerializer1 extends WriterSerializer { - @Override /* Serializer */ - protected void doSerialize(SerializerSession session, Object output) throws Exception { - ObjectMap p = session.getProperties(); - session.getWriter().write(format("A1=%s,A2=%s,B1=%s,B2=%s,C=%s,R1a=%s,R1b=%s,R2=%s,R3=%s,R4=%s,R5=%s,R6=%s", - p.get("A1"), p.get("A2"), p.get("B1"), p.get("B2"), p.get("C"), - p.get("R1a"), p.get("R1b"), p.get("R2"), p.get("R3"), p.get("R4"), p.get("R5"), p.get("R6"))); - } - } - - //==================================================================================================== - // Make sure attributes/parameters/headers are available through ctx.getProperties(). - //==================================================================================================== - @RestMethod(name="GET", path="/testProperties/{A}", serializers=PropertySerializer2.class) - public void testProperties(RestResponse res) { - res.setOutput(null); - } - - @Produces("application/json,text/json") - public static class PropertySerializer2 extends WriterSerializer { - @Override /* Serializer */ - protected void doSerialize(SerializerSession session, Object output) throws Exception { - ObjectMap p = session.getProperties(); - session.getWriter().write(format("A=%s,P=%s,H=%s", p.get("A"), p.get("P"), p.get("h"))); - } - } -} http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/91a388d0/juneau-server-test/src/main/java/org/apache/juneau/server/test/RestClient2Resource.java ---------------------------------------------------------------------- diff --git a/juneau-server-test/src/main/java/org/apache/juneau/server/test/RestClient2Resource.java b/juneau-server-test/src/main/java/org/apache/juneau/server/test/RestClient2Resource.java deleted file mode 100755 index 197ab40..0000000 --- a/juneau-server-test/src/main/java/org/apache/juneau/server/test/RestClient2Resource.java +++ /dev/null @@ -1,36 +0,0 @@ -// *************************************************************************************************************************** -// * 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.io.*; - -import org.apache.juneau.server.*; -import org.apache.juneau.server.annotation.*; - -/** - * JUnit automated testcase resource. - */ -@RestResource( - path="/testRestClient" -) -public class RestClient2Resource extends RestServletDefault { - private static final long serialVersionUID = 1L; - - //==================================================================================================== - // Echo response - //==================================================================================================== - @RestMethod(name="POST", path="/") - public Reader test1(RestRequest req) throws Exception { - return new StringReader(req.getBodyAsString()); - } -} http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/91a388d0/juneau-server-test/src/main/java/org/apache/juneau/server/test/Root.java ---------------------------------------------------------------------- diff --git a/juneau-server-test/src/main/java/org/apache/juneau/server/test/Root.java b/juneau-server-test/src/main/java/org/apache/juneau/server/test/Root.java deleted file mode 100755 index 9ebd621..0000000 --- a/juneau-server-test/src/main/java/org/apache/juneau/server/test/Root.java +++ /dev/null @@ -1,71 +0,0 @@ -// *************************************************************************************************************************** -// * 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 org.apache.juneau.microservice.resources.*; -import org.apache.juneau.server.*; -import org.apache.juneau.server.annotation.*; -import org.apache.juneau.server.labels.*; - -@RestResource( - path="/", - children={ - AcceptCharsetResource.class, - BeanContextPropertiesResource.class, - CallbackStringsResource.class, - CharsetEncodingsResource.class, - ClientVersionResource.class, - ConfigResource.class, - ContentResource.class, - DefaultContentTypesResource.class, - ErrorConditionsResource.class, - TransformsResource.class, - GroupsResource.class, - GzipResource.TestGzipOff.class, - GzipResource.TestGzipOn.class, - InheritanceResource.TestEncoders.class, - InheritanceResource.TestTransforms.class, - InheritanceResource.TestParsers.class, - InheritanceResource.TestProperties.class, - InheritanceResource.TestSerializers.class, - LargePojosResource.class, - MessagesResource.Messages2Resource.class, - MessagesResource.class, - NlsResource.class, - NlsPropertyResource.class, - NoParserInputResource.class, - OnPostCallResource.class, - OnPreCallResource.class, - OptionsWithoutNlsResource.class, - OverlappingMethodsResource.class, - ParamsResource.class, - ParsersResource.class, - PathResource.class, - PathsResource.class, - PropertiesResource.class, - RestClient2Resource.class, - SerializersResource.class, - StaticFilesResource.class, - UrisResource.class, - UrlContentResource.class, - ShutdownResource.class - } -) -public class Root extends RestServletDefault { - private static final long serialVersionUID = 1L; - - @RestMethod(name="GET", path="/") - public ChildResourceDescriptions doGet(RestRequest req) { - return new ChildResourceDescriptions(this, req); - } -} \ No newline at end of file http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/91a388d0/juneau-server-test/src/main/java/org/apache/juneau/server/test/SerializersResource.java ---------------------------------------------------------------------- diff --git a/juneau-server-test/src/main/java/org/apache/juneau/server/test/SerializersResource.java b/juneau-server-test/src/main/java/org/apache/juneau/server/test/SerializersResource.java deleted file mode 100755 index 8051b08..0000000 --- a/juneau-server-test/src/main/java/org/apache/juneau/server/test/SerializersResource.java +++ /dev/null @@ -1,103 +0,0 @@ -// *************************************************************************************************************************** -// * 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.annotation.Inherit.*; - -import org.apache.juneau.annotation.*; -import org.apache.juneau.serializer.*; -import org.apache.juneau.server.*; -import org.apache.juneau.server.annotation.*; - -/** - * JUnit automated testcase resource. - */ -@RestResource( - path="/testSerializers", - serializers=SerializersResource.TestSerializerA.class -) -public class SerializersResource extends RestServletDefault { - private static final long serialVersionUID = 1L; - - @Produces("text/a") - public static class TestSerializerA extends WriterSerializer { - @Override /* Serializer */ - protected void doSerialize(SerializerSession session, Object o) throws Exception { - session.getWriter().write("text/a - " + o); - } - } - - @Produces("text/b") - public static class TestSerializerB extends WriterSerializer { - @Override /* Serializer */ - protected void doSerialize(SerializerSession session, Object o) throws Exception { - session.getWriter().write("text/b - " + o); - } - } - - //==================================================================================================== - // Serializer defined on class. - //==================================================================================================== - @RestMethod(name="GET", path="/testSerializerOnClass") - public String testSerializerOnClass() { - return "test1"; - } - - //==================================================================================================== - // Serializer defined on method. - //==================================================================================================== - @RestMethod(name="GET", path="/testSerializerOnMethod", serializers=TestSerializerB.class) - public String testSerializerOnMethod() { - return "test2"; - } - - //==================================================================================================== - // Serializer overridden on method. - //==================================================================================================== - @RestMethod(name="GET", path="/testSerializerOverriddenOnMethod", serializers={TestSerializerB.class,TestSerializerC.class}, serializersInherit=SERIALIZERS) - public String testSerializerOverriddenOnMethod() { - return "test3"; - } - - @Produces("text/a") - public static class TestSerializerC extends WriterSerializer { - @Override /* Serializer */ - protected void doSerialize(SerializerSession session, Object o) throws Exception { - session.getWriter().write("text/c - " + o); - } - } - - //==================================================================================================== - // Serializer with different Accept than Content-Type. - //==================================================================================================== - @RestMethod(name="GET", path="/testSerializerWithDifferentMediaTypes", serializers={TestSerializerD.class}, serializersInherit=SERIALIZERS) - public String testSerializerWithDifferentMediaTypes() { - return "test4"; - } - - @Produces(value="text/a,text/d",contentType="text/d") - public static class TestSerializerD extends WriterSerializer { - @Override /* Serializer */ - protected void doSerialize(SerializerSession session, Object o) throws Exception { - session.getWriter().write("text/d - " + o); - } - } - - //==================================================================================================== - // Check for valid 406 error response. - //==================================================================================================== - @RestMethod(name="GET", path="/test406") - public String test406() { - return "test406"; - } -} http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/91a388d0/juneau-server-test/src/main/java/org/apache/juneau/server/test/StaticFilesResource.java ---------------------------------------------------------------------- diff --git a/juneau-server-test/src/main/java/org/apache/juneau/server/test/StaticFilesResource.java b/juneau-server-test/src/main/java/org/apache/juneau/server/test/StaticFilesResource.java deleted file mode 100755 index 59e7dfe..0000000 --- a/juneau-server-test/src/main/java/org/apache/juneau/server/test/StaticFilesResource.java +++ /dev/null @@ -1,36 +0,0 @@ -// *************************************************************************************************************************** -// * 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 org.apache.juneau.server.*; -import org.apache.juneau.server.annotation.*; - -/** - * JUnit automated testcase resource. - */ -@RestResource( - path="/testStaticFiles", - staticFiles="{xdocs:'xdocs'}" -) -public class StaticFilesResource extends RestServlet { - private static final long serialVersionUID = 1L; - - //==================================================================================================== - // Tests the @RestResource(staticFiles) annotation. - //==================================================================================================== - @RestMethod(name="GET", path="/*") - public String testXdocs() { - return null; - } - -} http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/91a388d0/juneau-server-test/src/main/java/org/apache/juneau/server/test/TransformsParentResource.java ---------------------------------------------------------------------- diff --git a/juneau-server-test/src/main/java/org/apache/juneau/server/test/TransformsParentResource.java b/juneau-server-test/src/main/java/org/apache/juneau/server/test/TransformsParentResource.java deleted file mode 100755 index 7507650..0000000 --- a/juneau-server-test/src/main/java/org/apache/juneau/server/test/TransformsParentResource.java +++ /dev/null @@ -1,26 +0,0 @@ -// *************************************************************************************************************************** -// * 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 org.apache.juneau.server.*; -import org.apache.juneau.server.annotation.*; - -/** - * JUnit automated testcase resource. - */ -@RestResource( - pojoSwaps={TransformsResource.SwapA1.class} -) -public class TransformsParentResource extends RestServletDefault { - private static final long serialVersionUID = 1L; -} http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/91a388d0/juneau-server-test/src/main/java/org/apache/juneau/server/test/TransformsResource.java ---------------------------------------------------------------------- diff --git a/juneau-server-test/src/main/java/org/apache/juneau/server/test/TransformsResource.java b/juneau-server-test/src/main/java/org/apache/juneau/server/test/TransformsResource.java deleted file mode 100755 index 6be5731..0000000 --- a/juneau-server-test/src/main/java/org/apache/juneau/server/test/TransformsResource.java +++ /dev/null @@ -1,114 +0,0 @@ -// *************************************************************************************************************************** -// * 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 org.apache.juneau.*; -import org.apache.juneau.parser.*; -import org.apache.juneau.serializer.*; -import org.apache.juneau.server.annotation.*; -import org.apache.juneau.transform.*; - -/** - * JUnit automated testcase resource. - */ -@RestResource( - path="/testTransforms", - pojoSwaps={TransformsResource.SwapA2.class} -) -public class TransformsResource extends TransformsParentResource { - private static final long serialVersionUID = 1L; - - //==================================================================================================== - // Test class transform overrides parent class transform - // Should return "A2-1". - //==================================================================================================== - @RestMethod(name="GET", path="/testClassTransformOverridesParentClassTransform") - public A testClassTransformOverridesParentClassTransform() { - return new A(); - } - @RestMethod(name="PUT", path="/testClassTransformOverridesParentClassTransform") - public A test1b(@Body A a) { - return a; - } - @RestMethod(name="PUT", path="/testClassTransformOverridesParentClassTransform/{a}") - public A test1c(@Path A a) { - return a; - } - - //==================================================================================================== - // Test method transform overrides class transform - // Should return "A3-1". - //==================================================================================================== - @RestMethod(name="GET", path="/testMethodTransformOverridesClassTransform", pojoSwaps={SwapA3.class}) - public A test2a() { - return new A(); - } - @RestMethod(name="PUT", path="/testMethodTransformOverridesClassTransform", pojoSwaps={SwapA3.class}) - public A test2b(@Body A a) { - return a; - } - @RestMethod(name="PUT", path="/testMethodTransformOverridesClassTransform/{a}", pojoSwaps={SwapA3.class}) - public A test2c(@Path A a) { - return a; - } - - - public static class A { - public int f1; - } - - public static class SwapA1 extends StringSwap<A> { - @Override /* PojoSwap */ - public String swap(BeanSession session, A a) throws SerializeException { - return "A1-" + a.f1; - } - @Override /* PojoSwap */ - public A unswap(BeanSession session, String in, ClassMeta<?> hint) throws ParseException { - if (! in.startsWith("A1")) - throw new RuntimeException("Invalid input for SwapA1!"); - A a = new A(); - a.f1 = Integer.parseInt(in.substring(3)); - return a; - } - } - - public static class SwapA2 extends StringSwap<A> { - @Override /* PojoSwap */ - public String swap(BeanSession session, A a) throws SerializeException { - return "A2-" + a.f1; - } - @Override /* PojoSwap */ - public A unswap(BeanSession session, String in, ClassMeta<?> hint) throws ParseException { - if (! in.startsWith("A2")) - throw new RuntimeException("Invalid input for SwapA2!"); - A a = new A(); - a.f1 = Integer.parseInt(in.substring(3)); - return a; - } - } - - public static class SwapA3 extends StringSwap<A> { - @Override /* PojoSwap */ - public String swap(BeanSession session, A a) throws SerializeException { - return "A3-" + a.f1; - } - @Override /* PojoSwap */ - public A unswap(BeanSession session, String in, ClassMeta<?> hint) throws ParseException { - if (! in.startsWith("A3")) - throw new RuntimeException("Invalid input for SwapA3!"); - A a = new A(); - a.f1 = Integer.parseInt(in.substring(3)); - return a; - } - } -}