From 0cc7896f92cfe9d39e73408e5ac526f546ab1230 Mon Sep 17 00:00:00 2001 From: Adam Anderson <31078699+WhiteCat22@users.noreply.github.com> Date: Thu, 28 Mar 2024 08:52:43 -0500 Subject: [PATCH] Add a TCK test to verify that the default ExceptionMapper can be overridden. (#1235) Signed-off-by: Adam Anderson --- .../DefaultExceptionMapperIT.java | 88 +++++++++++++++++++ .../OverriddenDefaultExceptionMapper.java | 41 +++++++++ .../defaultmapper/Resource.java | 32 +++++++ .../defaultmapper/TSAppConfig.java | 31 +++++++ .../defaultmapper/web.xml.template | 32 +++++++ 5 files changed, 224 insertions(+) create mode 100644 jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/ee/resource/webappexception/defaultmapper/DefaultExceptionMapperIT.java create mode 100644 jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/ee/resource/webappexception/defaultmapper/OverriddenDefaultExceptionMapper.java create mode 100644 jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/ee/resource/webappexception/defaultmapper/Resource.java create mode 100644 jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/ee/resource/webappexception/defaultmapper/TSAppConfig.java create mode 100644 jaxrs-tck/src/main/resources/ee/jakarta/tck/ws/rs/ee/resource/webappexception/defaultmapper/web.xml.template diff --git a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/ee/resource/webappexception/defaultmapper/DefaultExceptionMapperIT.java b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/ee/resource/webappexception/defaultmapper/DefaultExceptionMapperIT.java new file mode 100644 index 000000000..ccf2f9e7e --- /dev/null +++ b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/ee/resource/webappexception/defaultmapper/DefaultExceptionMapperIT.java @@ -0,0 +1,88 @@ +/* + * Copyright (c) 2024 Contributors to the Eclipse Foundation + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v. 2.0, which is available at + * http://www.eclipse.org/legal/epl-2.0. + * + * This Source Code may also be made available under the following Secondary + * Licenses when the conditions for such availability set forth in the + * Eclipse Public License v. 2.0 are satisfied: GNU General Public License, + * version 2 with the GNU Classpath Exception, which is available at + * https://www.gnu.org/software/classpath/license.html. + * + * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 + */ + +package ee.jakarta.tck.ws.rs.ee.resource.webappexception.defaultmapper; + +import java.io.IOException; +import java.io.InputStream; + +import org.jboss.arquillian.container.test.api.Deployment; +import org.jboss.arquillian.junit5.ArquillianExtension; +import org.jboss.shrinkwrap.api.ShrinkWrap; +import org.jboss.shrinkwrap.api.asset.StringAsset; +import org.jboss.shrinkwrap.api.spec.WebArchive; +import org.junit.jupiter.api.AfterEach; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; +import org.junit.jupiter.api.TestInfo; +import org.junit.jupiter.api.extension.ExtendWith; + +import ee.jakarta.tck.ws.rs.common.JAXRSCommonClient; +import ee.jakarta.tck.ws.rs.lib.util.TestUtil; + +/* + * @class.setup_props: webServerHost; + * webServerPort; + * ts_home; + */ +@ExtendWith(ArquillianExtension.class) +public class DefaultExceptionMapperIT extends JAXRSCommonClient { + + public DefaultExceptionMapperIT() { + setContextRoot("/jaxrs_resource_webappexception_defaultmapper_web/resource"); + } + + @Deployment(testable = false) + public static WebArchive createDeployment() throws IOException { + + InputStream inStream = DefaultExceptionMapperIT.class.getClassLoader().getResourceAsStream("ee/jakarta/tck/ws/rs/ee/resource/webappexception/defaultmapper/web.xml.template"); + // Replace the servlet_adaptor in web.xml.template with the System variable set as servlet adaptor + String webXml = editWebXmlString(inStream); + + WebArchive archive = ShrinkWrap.create(WebArchive.class, "jaxrs_resource_webappexception_defaultmapper_web.war"); + archive.addClasses( + TSAppConfig.class, + Resource.class, + OverriddenDefaultExceptionMapper.class + ); + archive.setWebXML(new StringAsset(webXml)); + + return archive; + } + + @BeforeEach + void logStartTest(TestInfo testInfo) { + super.setup(); + TestUtil.logMsg("STARTING TEST : "+testInfo.getDisplayName()); + } + + @AfterEach + void logFinishTest(TestInfo testInfo) { + TestUtil.logMsg("FINISHED TEST : "+testInfo.getDisplayName()); + } + + /* + * @testName: overrideDefaultExceptionMapperTest + * + * @test_Strategy: The default ExceptionMapper must be able to be overridden. + */ + @Test + public void overrideDefaultExceptionMapperTest() throws Fault { + setProperty(REQUEST, buildRequest(GET, "throwable")); + setProperty(STATUS_CODE, "512"); + invoke(); + } +} \ No newline at end of file diff --git a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/ee/resource/webappexception/defaultmapper/OverriddenDefaultExceptionMapper.java b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/ee/resource/webappexception/defaultmapper/OverriddenDefaultExceptionMapper.java new file mode 100644 index 000000000..83c8c0ade --- /dev/null +++ b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/ee/resource/webappexception/defaultmapper/OverriddenDefaultExceptionMapper.java @@ -0,0 +1,41 @@ +/* + * Copyright (c) 2024 Contributors to the Eclipse Foundation + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v. 2.0, which is available at + * http://www.eclipse.org/legal/epl-2.0. + * + * This Source Code may also be made available under the following Secondary + * Licenses when the conditions for such availability set forth in the + * Eclipse Public License v. 2.0 are satisfied: GNU General Public License, + * version 2 with the GNU Classpath Exception, which is available at + * https://www.gnu.org/software/classpath/license.html. + * + * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 + */ + +package ee.jakarta.tck.ws.rs.ee.resource.webappexception.defaultmapper; + +import jakarta.ws.rs.core.Response; +import jakarta.ws.rs.ext.ExceptionMapper; +import jakarta.ws.rs.ext.Provider; + +@Provider +public class OverriddenDefaultExceptionMapper implements ExceptionMapper { + + /* + * 4.4. Exception Mapping Providers states: + * "A JAX-RS implementation MUST include a default exception mapping provider + * that implements ExceptionMapper and which SHOULD set the + * response status to 500." + * + * This class should override the default ExceptionMapper and set the + * response status to 512 to verify that the default ExceptionMapper + * was overriden. + */ + @Override + public Response toResponse(Throwable throwable) { + return Response.status(512).build(); + } + +} diff --git a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/ee/resource/webappexception/defaultmapper/Resource.java b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/ee/resource/webappexception/defaultmapper/Resource.java new file mode 100644 index 000000000..a30480489 --- /dev/null +++ b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/ee/resource/webappexception/defaultmapper/Resource.java @@ -0,0 +1,32 @@ +/* + * Copyright (c) 2024 Contributors to the Eclipse Foundation + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v. 2.0, which is available at + * http://www.eclipse.org/legal/epl-2.0. + * + * This Source Code may also be made available under the following Secondary + * Licenses when the conditions for such availability set forth in the + * Eclipse Public License v. 2.0 are satisfied: GNU General Public License, + * version 2 with the GNU Classpath Exception, which is available at + * https://www.gnu.org/software/classpath/license.html. + * + * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 + */ + +package ee.jakarta.tck.ws.rs.ee.resource.webappexception.defaultmapper; + +import jakarta.ws.rs.GET; +import jakarta.ws.rs.Path; +import jakarta.ws.rs.core.Response; + +@Path("resource") +public class Resource { + + @GET + @Path("/throwable") + public Response throwable() throws Throwable { + throw new Throwable(); + } + +} \ No newline at end of file diff --git a/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/ee/resource/webappexception/defaultmapper/TSAppConfig.java b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/ee/resource/webappexception/defaultmapper/TSAppConfig.java new file mode 100644 index 000000000..bcf517409 --- /dev/null +++ b/jaxrs-tck/src/main/java/ee/jakarta/tck/ws/rs/ee/resource/webappexception/defaultmapper/TSAppConfig.java @@ -0,0 +1,31 @@ +/* + * Copyright (c) 2024 Contributors to the Eclipse Foundation + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v. 2.0, which is available at + * http://www.eclipse.org/legal/epl-2.0. + * + * This Source Code may also be made available under the following Secondary + * Licenses when the conditions for such availability set forth in the + * Eclipse Public License v. 2.0 are satisfied: GNU General Public License, + * version 2 with the GNU Classpath Exception, which is available at + * https://www.gnu.org/software/classpath/license.html. + * + * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 + */ + +package ee.jakarta.tck.ws.rs.ee.resource.webappexception.defaultmapper; + +import java.util.HashSet; +import java.util.Set; + +import jakarta.ws.rs.core.Application; + +public class TSAppConfig extends Application { + public java.util.Set> getClasses() { + Set> resources = new HashSet>(); + resources.add(Resource.class); + resources.add(OverriddenDefaultExceptionMapper.class); + return resources; + } +} \ No newline at end of file diff --git a/jaxrs-tck/src/main/resources/ee/jakarta/tck/ws/rs/ee/resource/webappexception/defaultmapper/web.xml.template b/jaxrs-tck/src/main/resources/ee/jakarta/tck/ws/rs/ee/resource/webappexception/defaultmapper/web.xml.template new file mode 100644 index 000000000..21dc0041d --- /dev/null +++ b/jaxrs-tck/src/main/resources/ee/jakarta/tck/ws/rs/ee/resource/webappexception/defaultmapper/web.xml.template @@ -0,0 +1,32 @@ + + + + + + CTS_JAXRS_WEBAPPEXCEPTION_MAPPER + servlet_adaptor + + jakarta.ws.rs.Application + ee.jakarta.tck.ws.rs.ee.resource.webappexception.defaultmapper.TSAppConfig + + 1 + + + CTS_JAXRS_WEBAPPEXCEPTION_MAPPER + /* + + + 30 + + \ No newline at end of file