blob: b69a067168ace66a7418ad8cde1eb163a8085184 [file] [log] [blame]
///////////////////////////////////////////////////////////////////////////////
Copyright (c) 2020, 2021 Oracle and/or its affiliates. All rights reserved.
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
///////////////////////////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////////////////
NOTE TO WRITERS:
The following sections should be customized for the technology.
This text was originally from the {TechnologyShortName} TCK. Most references
to {TechnologyShortName} have been parameterized to serve as a simple starting
point for customization. There are still many details that will
need to be changed or removed.
///////////////////////////////////////////////////////////////////////
[[GCLIZ]]
[[b-packaging-the-test-applications-in-servlet-compliant-war-files-with-vi-specific-information]]
B Packaging the Test Applications in Servlet-Compliant WAR Files With VI-Specific Information
---------------------------------------------------------------------------------------------
[Note]
====
If you are using a compatible implementation, other than {TechnologyRI}, please consult documentation
which may contain additional details specific for that implementation.
====
The {TechnologyShortName} {TechnologyVersion} specification specifies
how {TechnologyShortName} applications are to be published in a Java SE
environment, {TechnologyShortName} endpoint, or Servletcompliant Web container.
The {TechnologyShortName} TCK comes with prebuilt test WAR files for
deployment on Jakarta EE {JakartaEEVersion} CI, Eclipse GlassFish 6.1,
which provides a Servletcompliant Web
container. The WAR files are {TechnologyRI}-specific, with {TechnologyRI}'s servlet
class and {TechnologyRI}'s servlet defined in the `web.xml` deployment
descriptor. To run the TCK tests against the VI in a Servletcompliant
Web container, the tests need to be repackaged to include the
VI-specific servlet, and the VI-specific servlet must be defined in the
deployment descriptor.
The {TechnologyShortName} TCK makes it easier for the vendor by
including template WAR files that contain all of the necessary files
except for the VI-specific servlet adaptor class. The
{TechnologyShortName} TCK provides a tool to help with the repackaging
task.
This appendix contains the following sections:
* link:#GCLIO[Overview]
* link:#GCLLW[Creating the VI-Specific ServletCompliant WAR
Files]
[[GCLIO]][[b.1-overview]]
B.1 Overview
~~~~~~~~~~~~
The classes that ship with the {TechnologyShortName} TCK were built
using the Eclipse GlassFish 6.1, Compatible
Implementation. The archives for tests are built and deployed in the runtime.
[[GCLLW]][[b.2-creating-the-vi-specific-servletcompliant-war-files]]
B.2 Creating the TCK VI-Specific ServletCompliant WAR Files
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
All resource and application class files are already compiled.
All tests also come with a `web.xml.template` file that is used
for generating deployment descriptor files.
Each test that has a {TechnologyShortName} resource class to publish, comes with a
template deployment descriptor file. For example, the file
`jakarta/ws/rs/tck/ee/rs/get/web.xml.template`
contains the following elements:
[source,oac_no_warn]
----
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="5.0" xmlns="https://jakarta.ee/xml/ns/jakartaee" \
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" \
xsi:schemaLocation="https://jakarta.ee/xml/ns/jakartaee \
https://jakarta.ee/xml/ns/jakartaee/web-app_5_0.xsd">
<servlet>
<servlet-name>CTSJAX-RSGET</servlet-name>
<servlet-class>servlet_adaptor</servlet-class>
<init-param>
<param-name>jakarta.ws.rs.core.Application</param-name>
<param-value>jakarta.ws.rs.tck.ee.rs.get.TSAppConfig</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>CTSJAX-RSGET</servlet-name>
<url-pattern>/*</url-pattern>
</servlet-mapping>
<session-config>
<session-timeout>30</session-timeout>
</session-config>
</web-app>
----
In this example, the `<servlet-class>` element has a value of
`servlet_adaptor`, which is a placeholder for the
implementation-specific Servlet class. A {TechnologyRI}-specific
deployment descriptor also comes with the {TechnologyShortName} TCK,
and has the values for the
`org.glassfish.jersey.servlet.ServletContainer`:
[source,oac_no_warn]
----
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="5.0" xmlns="https://jakarta.ee/xml/ns/jakartaee" \
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" \
xsi:schemaLocation="https://jakarta.ee/xml/ns/jakartaee \
https://jakarta.ee/xml/ns/jakartaee/web-app_5_0.xsd">
<servlet>
<servlet-name>CTSJAX-RSGET</servlet-name>
<servlet-class>
org/glassfish/jersey/servlet/ServletContainer
</servlet-class>
<init-param>
<param-name>jakarta.ws.rs.core.Application</param-name>
<param-value>jakarta.ws.rs.tck.ee.rs.get.TSAppConfig</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>CTSJAX-RSGET</servlet-name>
<url-pattern>/*</url-pattern>
</servlet-mapping>
<session-config>
<session-timeout>30</session-timeout>
</session-config>
</web-app>
----
[[GCLMA]][[b.2.1-to-create-a-vi-specific-deployment-descriptor]]
B.2.1 To Create a VI-Specific Deployment Descriptor
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1. Set the VI Servlet class property. +
Set the `servlet_adaptor` property as System property. This property
will be used to set the value of the `<servlet-class>` element in the
deployment descriptor before packaging and deploying the archive.