The following rules apply for each implementation:
EE1 The Product must be able to satisfy all applicable compatibility
requirements, including passing all required TCK tests.
For example, if a Product provides distinct Operating Modes to optimize
performance, then that Product must satisfy all applicable compatibility
requirements for a Product in each Product Configuration, and
combination of Product Configurations, of those Operating Modes.
EE1.1 Each implementation must have at least one configuration that can be used to pass
all required TCK Tests, although such configuration may need adjustment (e.g. whether statically
or via administrative tooling).
EE1.2 An implementation may have mode(s) that provide compatibility with previous Jakarta EE versions.
EE1.3 An API Definition Product is exempt from all functional testing
requirements defined here, except the signature tests.
EE2 Some Conformance Tests may have properties that may be changed.
Properties that can be changed are identified in the configuration
interview. Properties that can be changed are identified in the JavaTest
Environment (.jte) files in the lib directory of the Test Suite
installation. Apart from changing such properties and other allowed
modifications described in this User’s Guide (if any), no source or
binary code for a Conformance Test may be altered in any way without
prior written permission. Any such allowed alterations to the
Conformance Tests will be provided via the Jakarta EE Specification Project
website and apply to all vendor compatible implementations.
EE3 The testing tools supplied as part of the Test Suite or as
updated by the Maintenance Lead must be used to certify compliance.
EE4 The Exclude List associated with the Test Suite cannot be
modified.
EE5 The Maintenance Lead may define exceptions to these Rules. Such
exceptions would be made available as above, and will apply to all vendor implementations.
EE6 All hardware and software component additions, deletions, and
modifications to a Documented supporting hardware/software platform,
that are not part of the Product but required for the Product to satisfy
the compatibility requirements, must be Documented and available to
users of the Product.
EE7 The Product must contain the full set of public and protected
classes and interfaces for all the Libraries. Those classes and
interfaces must contain exactly the set of public and protected methods,
constructors, and fields defined by the Specifications for those
Libraries. No subsetting, supersetting, or modifications of the public
and protected API of the Libraries are allowed except only as
specifically exempted by these Rules.
EE7.1 If a Product includes Technologies in addition to the
Technology Under Test, then it must contain the full set of combined
public and protected classes and interfaces. The API of the Product must
contain the union of the included Technologies. No further modifications
to the APIs of the included Technologies are allowed.
EE7.2 A Product may provide a newer version of an Endorsed Standard.
Upon request, the Maintenance Lead will make available alternate
Conformance Tests as necessary to conform with such newer version of an
Endorsed Standard. Such alternate tests will be made available to and
apply to all implementers. If a Product provides a newer version of an
Endorsed Standard, the version of the Endorsed Standard supported by the
Product must be Documented.
EE7.3 The Maintenance Lead may authorize the use of newer Versions of
a Technology included in the Technology Under Test. A Product that
provides a newer Version of a Technology must meet the Compatibility
Requirements for that newer Version, and must Document that it supports
the newer Version.
For example, the Jakarta Platform, Enterprise Edition Maintenance Lead
could authorize use of a newer version of a Java technology such as
Jakarta XML Web Services.
EE8 Except for tests specifically required by this TCK to be rebuilt
(if any), the binary Conformance Tests supplied as part of the Test
Suite or as updated by the Maintenance Lead must be used to certify
compliance.
EE9 The functional programmatic behavior of any binary class or
interface must be that defined by the Specifications.
EE9.1 A Product may contain Operating Modes that meet all of these
requirements, except Rule EE9, provided that:
-
The Operating Modes must not violate the Java Platform, Standard
Edition Rules.
-
Some Product Configurations of such Operating Modes may provide only
a subset of the functional programmatic behavior required by the
Specifications. The behavior of applications that use more than the
provided subset, when run in such Product Configurations, is
unspecified.
-
The functional programmatic behavior of any binary class or
interface in the above defined subset must be that defined by the
Specifications.
-
Any Product Configuration that invokes this rule must be clearly
Documented as not fully meeting the requirements of the Specifications.
EE10 Each Container must make technically accessible all Java SE
Runtime interfaces and functionality, as defined by the Specifications,
to programs running in the Container, except only as specifically
exempted by these Rules.
EE10.1 Containers may impose security constraints, as defined by the
Specifications.
EE11 A web Container must report an error, as defined by the
Specifications, when processing a Jakarta Server Page that does not conform to the
Specifications.
EE12 The presence of a Java language comment or Java language
directive in a Jakarta Server Page that specifies ”java” as the scripting language,
when processed by a web Container, must not cause the functional
programmatic behavior of that Jakarta Server Page to vary from the functional
programmatic behavior of that Jakarta Server Page in the absence of that Java
language comment or Java language directive.
EE13 The contents of any fixed template data (defined by the
Specifications) in a Jakarta Server Page, when processed by a web Container, must
not affect the functional programmatic behavior of that Jakarta Server Page, except
as defined by the Specifications.
EE14 The functional programmatic behavior of a Jakarta Server Page that
specifies ”java” as the scripting language must be equivalent to the
functional programmatic behavior of the Jakarta Server Page Implementation Class
constructed from that Jakarta Server Page.
EE15 A Deployment Tool must report an error when processing a
Configuration Descriptor that does not conform to the Specifications.
EE16 The presence of an XML comment in a Configuration Descriptor,
when processed by a Deployment Tool, must not cause the functional
programmatic behavior of the Deployment Tool to vary from the functional
programmatic behavior of the Deployment Tool in the absence of that
comment.
EE17 A Deployment Tool must report an error when processing an Jakarta Enterprise Beans
deployment descriptor that includes an Jakarta Enterprise Beans QL expression that does not
conform to the Specifications.
EE18 The Runtime must report an error when processing a Configuration
Descriptor that does not conform to the Specifications.
EE19 An error must be reported when processing a configuration
descriptor that includes a Java Persistence QL expression that does not
conform to the Specifications.
EE20 The presence of an XML comment in a Configuration Descriptor,
when processed by the Runtime, must not cause the functional
programmatic behavior of the Runtime to vary from the functional
programmatic behavior of the Runtime in the absence of that comment.
EE21 Compliance testing for Jakarta EE 10.0 consists of running Jakarta EE 10.0
TCK and the following Technology Compatibility Kits (TCKs). Version details are defined in the Platform EE Specification document (https://jakarta.ee/specifications/platform/10/), see the heading Full Jakarta™ EE Product Requirements:
-
Jakarta Activation
-
Jakarta Authentication
-
Jakarta Batch
-
Jakarta Bean Validation
-
Jakarta Concurrency
-
Jakarta Contexts and Dependency Injection
-
Jakarta Debugging Support for Other Languages
-
Jakarta Dependency Injection
-
Jakarta Faces
-
Jakarta JSON Binding
-
Jakarta JSON Processing
-
Jakarta Mail
-
Jakarta RESTful Web Services
-
Jakarta Security
-
Jakarta XML Binding (If XML Binding is supported)
In addition to the compatibility rules outlined in this TCK User’s
Guide, Jakarta EE 10.0 implementations must also adhere to all of the
compatibility rules defined in the User’s Guides of the aforementioned
TCKs.
EE21.1 If the Jakarta EE 10 implementation uses a runtime which has
already been validated by the Technology Compatibility Kit,
the Jakarta EE 10 implementation may use result of such validation
to claim its compliance with the Technology Compatibility Kit.
EE22 Source Code in WSDL-to-Java Output when compiled by a Reference
Compiler must execute properly when run on a Reference Runtime.
EE23 Source Code in WSDL-to-Java Output must be in source file format
defined by the Java Language Specification (JLS).
EE24 Java-to-WSDL Output must fully meet W3C requirements for the Web
Services Description Language (WSDL) 1.1.
EE25 A Java-to-WSDL Tool must not produce Java-to-WSDL Output from
source code that does not conform to the Java Language Specification
(JLS).