type=page status=published title=Setup and Configuration next=using.html prev=install.html ~~ attributes.conf Setup and Configuration
4 Setup and Configuration
[NOTE] ==== The Jakarta EE Specification process provides for any number of compatible implementations. As additional implementations become available, refer to project or product documentation from those vendors for specific TCK setup and operational guidance. ==== This chapter describes how to set up the {TechnologyShortName} TCK . Before proceeding with the instructions in this chapter, be sure to install all required software, as described in link:install.html#GBFTP[Chapter 3, "Installation."] After completing the instructions in this chapter, proceed to link:using.html#GBFWO[Chapter 5, "Executing Tests,"] for instructions on running the {TechnologyShortName} TCK. [NOTE] ==== The {TechnologyShortName} TCK is not depended on any particular build tool to run the tests. It will be convenient and advisable to create a Apache Maven project to setup and run the TCK. This chapter will henceforth use instructions and steps to provide setup with Apache Maven as a build tool. ==== /////////////////////////////////////////////////////////////////////// NOTE TO WRITERS: The following sections should be customized for the technology. This text was originally from the JAX-RS TCK. Most references to JAX-RS 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. The major sections 4.1, 4.2, and 4.3 should be preserved. If their titles are changed, the links at the top of config.adoc will need to be changed as well as well as toc.adoc. /////////////////////////////////////////////////////////////////////// [[GBFVU]][[configuring-your-environment-to-run-the-tck-against-the-reference-implementation]] 4.1 Configuring Your Environment to Run the TCK Against the Compatible Implementation ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ After configuring your environment as described in this section, continue with the instructions in link:#GBFWO[Chapter 5, "Executing Tests."] [NOTE] ======================================================================= In these instructions, variables in angle brackets need to be expanded for each platform. For example, `<JAVA_HOME>` becomes `$JAVA_HOME` on Solaris/Linux and `%JAVA_HOME%` on Windows. In addition, the forward slashes (`/`) used in all of the examples need to be replaced with backslashes (`\`) for Windows. Finally, be sure to use the appropriate separator for your operating system when specifying multiple path entries (`;` on Windows, `:` on UNIX/Linux). On Windows, you must escape any backslashes with an extra backslash in path separators used in any of the following properties, or use forward slashes as a path separator instead. ======================================================================= 1. Set the following environment variables in your shell environment: a. `JAVA_HOME` to the directory in which Java SE {SEversion} is installed b. `M2_HOME` to the directory in which the Apache Maven build tool is installed. c. +{TechnologyTCKHomeEnv}+ to the directory in which the {TechnologyShortName} {TechnologyVersion} TCK has been installed d. `PATH` to include the following directories: `JAVA_HOME/bin`, and `M2_HOME/bin` 2. Set the following System properties: a. `jsonp-impl.groupId` property is set to the Maven Group Id of the CI to test. b. `jsonp-impl.artifactId` property is set to the Maven Artifact Id of the CI to test. c. `jsonp-impl.version` property is set to the Maven Version of the CI to test. d. `jimage.dir` property is set to extract the Java SE {SEversion} modules for running the signature tests. 3. Set the below jars to the classpath a. JAR file for the {TechnologyShortName} {TechnologyVersion} API. + `jakarta.json-api.jar`. b. JUnit 5 jars ({JunitVersion}) c. sigtest-maven-plugin (1.4) to run the signature tests. d. {TechnologyShortName} TCK tests (`jakarta.json:jakarta.json-tck-tests`) or {TechnologyShortName} TCK pluggability tests (`jakarta.json:jakarta.json-tck-tests-pluggability`) depending on which test suite to run. + .Example: Maven configuration [source,oac_no_warn,xml] ---- <dependencyManagement> <dependencies> <dependency> <groupId>jakarta.json</groupId> <artifactId>jakarta.json-tck</artifactId> <version>2.1.0</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> .... <dependencies> <dependency> <groupId>org.eclipse.parsson</groupId> <artifactId>parsson</artifactId> <version>1.1.0</version> <scope>test</scope> </dependency> <dependency> <groupId>jakarta.json</groupId> <artifactId>jakarta.json-api</artifactId> <version>2.1.0</version> <scope>test</scope> </dependency> <dependency> <groupId>org.junit.jupiter</groupId> <artifactId>junit-jupiter-api</artifactId> <scope>test</scope> </dependency> <dependency> <groupId>org.junit.jupiter</groupId> <artifactId>junit-jupiter-engine</artifactId> <scope>test</scope> </dependency> <dependency> <groupId>org.netbeans.tools</groupId> <artifactId>sigtest-maven-plugin</artifactId> <scope>test</scope> </dependency> <dependency> <groupId>jakarta.json</groupId> <artifactId>jakarta.json-tck-tests</artifactId> <!-- or jakarta.json-tck-tests-pluggability --> <scope>test</scope> </dependency> </dependencies> ---- + [[GCLHU]][[configuring-your-environment-to-repackage-and-run-the-tck-against-the-vendor-implementation]] 4.2 Configuring Your Environment to Run the TCK Against the Vendor Implementation ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ After configuring your environment as described in this section, continue with the instructions in link:#GBFWO[Chapter 5, "Executing Tests."] [NOTE] ======================================================================= In these instructions, variables in angle brackets need to be expanded for each platform. For example, `<JAVA_HOME>` becomes `$JAVA_HOME` on Solaris/Linux and `%JAVA_HOME%` on Windows. In addition, the forward slashes (`/`) used in all of the examples need to be replaced with backslashes (`\`) for Windows. Finally, be sure to use the appropriate separator for your operating system when specifying multiple path entries (`;` on Windows, `:` on UNIX/Linux). On Windows, you must escape any backslashes with an extra backslash in path separators used in any of the following properties, or use forward slashes as a path separator instead. ======================================================================= 1. Set the following environment variables in your shell environment: a. `JAVA_HOME` to the directory in which Java SE {SEversion} is installed b. `M2_HOME` to the directory in which the Apache Maven build tool is installed. c. +{TechnologyTCKHomeEnv}+ to the directory in which the {TechnologyShortName} {TechnologyVersion} TCK has been installed d. `PATH` to include the following directories: `JAVA_HOME/bin`, and `M2_HOME/bin` 2. Set the following System properties: a. `jsonp-api.groupId` property is set to the Maven Group Id of the VI to test. b. `jsonp-api.artifactId` property is set to the Maven Artifact Id of the VI to test. c. `jsonp-api.version` property is set to the Maven Version of the VI to test. d. `jimage.dir` property is set to extract the Java SE {SEversion} modules for running the signature tests. 3. Set the below jars to the classpath a. JAR file for the {TechnologyShortName} {TechnologyVersion} CI. + `parsson.jar`. b. JUnit 5 jars ({JunitVersion}) c. sigtest-maven-plugin (1.4) to run the signature tests. d. {TechnologyShortName} TCK tests (`jakarta.json:jakarta.json-tck-tests`) or {TechnologyShortName} TCK pluggability tests (`jakarta.json:jakarta.json-tck-tests-pluggability`) depending on which test suite to run. + .Example: Maven configuration [source,oac_no_warn,xml] ---- <dependencyManagement> <dependencies> <dependency> <groupId>jakarta.json</groupId> <artifactId>jakarta.json-tck</artifactId> <version>2.1.0</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> .... <dependencies> <dependency> <groupId>org.eclipse.parsson</groupId> <artifactId>parsson</artifactId> <version>1.1.0</version> <scope>test</scope> </dependency> <dependency> <groupId>org.junit.jupiter</groupId> <artifactId>junit-jupiter-api</artifactId> <scope>test</scope> </dependency> <dependency> <groupId>org.junit.jupiter</groupId> <artifactId>junit-jupiter-engine</artifactId> <scope>test</scope> </dependency> <dependency> <groupId>org.netbeans.tools</groupId> <artifactId>sigtest-maven-plugin</artifactId> <scope>test</scope> </dependency> <dependency> <groupId>jakarta.json</groupId> <artifactId>jakarta.json-tck-tests</artifactId> <!-- or jakarta.json-tck-tests-pluggability --> <scope>test</scope> </dependency> </dependencies> ---- + [[GHGDG]][[publishing-the-test-applications]] 4.3 Publishing the Test Applications ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ Not needed for the {TechnologyShortName} TCK.