Skip to content

Commit

Permalink
Merge branch 'main' into webjpa3
Browse files Browse the repository at this point in the history
  • Loading branch information
starksm64 authored Jan 12, 2025
2 parents 057bba4 + 2696d32 commit d6530e0
Show file tree
Hide file tree
Showing 4 changed files with 134 additions and 131 deletions.
2 changes: 2 additions & 0 deletions glassfish-runner/persistence-platform-tck/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -453,6 +453,8 @@
<include>ee/jakarta/tck/persistence/ee/cdi/*Test.java</include>
</includes>

<skipITs>${cdi.skip}</skipITs>

<systemPropertyVariables>
<arquillian.xml>rest-arquillian.xml</arquillian.xml>
</systemPropertyVariables>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,8 @@ public Client() {
/*
* @class.setup_props:
*/
@BeforeEach
@Override
@BeforeEach
public void setup() throws Exception {
logTrace( "setup");
try {
Expand All @@ -47,9 +48,9 @@ public void setup() throws Exception {

/*
* @testName: JarFileElementsTest
*
*
* @assertion_ids: PERSISTENCE:SPEC:957
*
*
* @test_Strategy: With the above archive (jar-file elements), deploy, create
* entities persist, then find.
*
Expand All @@ -64,11 +65,13 @@ public void JarFileElementsTest() throws Exception {
getEntityManager().persist(a);
logTrace( "persisted order " + a.toString());
}

for (int i = 1 + count; i <= count + count; i++) {
C c = new C(Integer.toString(i), "name_" + Integer.toString(i), i);
getEntityManager().persist(c);
logTrace( "persisted order " + c.toString());
}

for (int i = 1; i <= count; i++) {
B b = new B(Integer.toString(i), "name_" + Integer.toString(i), i);
getEntityManager().persist(b);
Expand All @@ -87,6 +90,7 @@ public void JarFileElementsTest() throws Exception {
pass = false;
}
}

for (int i = 1 + count; i <= count + count; i++) {
C c = getEntityManager().find(C.class, Integer.toString(i));
if (c != null) {
Expand All @@ -96,6 +100,7 @@ public void JarFileElementsTest() throws Exception {
pass = false;
}
}

for (int i = 1; i <= count; i++) {
B b = getEntityManager().find(B.class, Integer.toString(i));
if (b != null) {
Expand All @@ -110,7 +115,8 @@ public void JarFileElementsTest() throws Exception {
}
}

@BeforeEach
@Override
@BeforeEach
public void cleanup() throws Exception {
logTrace( "cleanup");
removeTestData();
Expand Down
Original file line number Diff line number Diff line change
@@ -1,16 +1,28 @@
package ee.jakarta.tck.persistence.jpa.ee.packaging.jar;

import ee.jakarta.tck.persistence.jpa.ee.packaging.jar.Client;
import com.sun.ts.lib.harness.EETest;
import com.sun.ts.lib.harness.ServiceEETest;
import com.sun.ts.tests.common.vehicle.VehicleClient;
import com.sun.ts.tests.common.vehicle.VehicleRunnable;
import com.sun.ts.tests.common.vehicle.VehicleRunnerFactory;
import com.sun.ts.tests.common.vehicle.ejb3share.EJB3ShareBaseBean;
import com.sun.ts.tests.common.vehicle.ejb3share.EJB3ShareIF;
import com.sun.ts.tests.common.vehicle.ejb3share.EntityTransactionWrapper;
import com.sun.ts.tests.common.vehicle.ejb3share.NoopTransactionWrapper;
import com.sun.ts.tests.common.vehicle.ejb3share.UseEntityManager;
import com.sun.ts.tests.common.vehicle.ejb3share.UseEntityManagerFactory;
import com.sun.ts.tests.common.vehicle.ejb3share.UserTransactionWrapper;
import com.sun.ts.tests.common.vehicle.pmservlet.PMServletVehicle;
import com.sun.ts.tests.common.vehicle.servlet.ServletVehicle;

import java.net.URL;

import org.jboss.arquillian.container.test.api.Deployment;
import org.jboss.arquillian.container.test.api.OperateOnDeployment;
import org.jboss.arquillian.container.test.api.OverProtocol;
import org.jboss.arquillian.container.test.api.TargetsContainer;
import org.jboss.arquillian.junit5.ArquillianExtension;
import org.jboss.arquillian.test.api.ArquillianResource;
import org.jboss.shrinkwrap.api.ShrinkWrap;
import org.jboss.shrinkwrap.api.asset.StringAsset;
import org.jboss.shrinkwrap.api.exporter.ZipExporter;
import org.jboss.shrinkwrap.api.spec.EnterpriseArchive;
import org.jboss.shrinkwrap.api.spec.JavaArchive;
import org.jboss.shrinkwrap.api.spec.WebArchive;
Expand All @@ -19,143 +31,124 @@
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestMethodOrder;
import org.junit.jupiter.api.extension.ExtendWith;

import ee.jakarta.tck.persistence.common.PMClientBase;
import tck.arquillian.porting.lib.spi.TestArchiveProcessor;
import tck.arquillian.protocol.common.TargetVehicle;



@ExtendWith(ArquillianExtension.class)
@Tag("persistence")
@Tag("platform")
@Tag("web")
@Tag("tck-javatest")

@TestMethodOrder(MethodOrderer.MethodName.class)
public class ClientPmservletTest extends ee.jakarta.tck.persistence.jpa.ee.packaging.jar.Client {

private static final long serialVersionUID = 1L;
static final String VEHICLE_ARCHIVE = "jpa_ee_packaging_jar_pmservlet_vehicle";

/**
EE10 Deployment Descriptors:
jpa_ee_packaging_jar: META-INF/persistence.xml,META-INF/orm.xml,myMappingFile.xml,myMappingFile2.xml
jpa_ee_packaging_jar_appmanaged_vehicle_client: META-INF/application-client.xml
jpa_ee_packaging_jar_appmanaged_vehicle_ejb: jar.sun-ejb-jar.xml
jpa_ee_packaging_jar_pmservlet_vehicle_web: WEB-INF/web.xml
jpa_ee_packaging_jar_stateful3_vehicle_client: META-INF/application-client.xml
jpa_ee_packaging_jar_stateful3_vehicle_ejb: jar.sun-ejb-jar.xml
jpa_ee_packaging_jar_stateless3_vehicle_client: META-INF/application-client.xml
jpa_ee_packaging_jar_stateless3_vehicle_ejb: jar.sun-ejb-jar.xml
jpa_ee_packaging_jar_vehicles:
jpa_ee_packaging_jar1:
jpa_ee_packaging_jar2:
Found Descriptors:
War:
/com/sun/ts/tests/common/vehicle/pmservlet/pmservlet_vehicle_web.xml
starksm@Scotts-Mac-Studio jar % jar -tf jpa_ee_packaging_jar_pmservlet_vehicle_web.war
WEB-INF/classes/com/sun/ts/lib/harness/EETest$Fault.class
WEB-INF/classes/com/sun/ts/lib/harness/EETest$SetupException.class
WEB-INF/classes/com/sun/ts/lib/harness/EETest.class
WEB-INF/classes/com/sun/ts/lib/harness/ServiceEETest.class
WEB-INF/classes/com/sun/ts/tests/common/vehicle/VehicleClient.class
WEB-INF/classes/com/sun/ts/tests/common/vehicle/VehicleRunnable.class
WEB-INF/classes/com/sun/ts/tests/common/vehicle/VehicleRunnerFactory.class
WEB-INF/classes/com/sun/ts/tests/common/vehicle/ejb3share/EJB3ShareBaseBean.class
WEB-INF/classes/com/sun/ts/tests/common/vehicle/ejb3share/EJB3ShareIF.class
WEB-INF/classes/com/sun/ts/tests/common/vehicle/ejb3share/EntityTransactionWrapper.class
WEB-INF/classes/com/sun/ts/tests/common/vehicle/ejb3share/NoopTransactionWrapper.class
WEB-INF/classes/com/sun/ts/tests/common/vehicle/ejb3share/UseEntityManager.class
WEB-INF/classes/com/sun/ts/tests/common/vehicle/ejb3share/UseEntityManagerFactory.class
WEB-INF/classes/com/sun/ts/tests/common/vehicle/ejb3share/UserTransactionWrapper.class
WEB-INF/classes/com/sun/ts/tests/common/vehicle/pmservlet/PMServletVehicle.class
WEB-INF/classes/com/sun/ts/tests/common/vehicle/servlet/ServletVehicle.class
WEB-INF/classes/com/sun/ts/tests/jpa/common/PMClientBase.class
WEB-INF/classes/com/sun/ts/tests/jpa/ee/packaging/
WEB-INF/classes/com/sun/ts/tests/jpa/ee/packaging/jar/
WEB-INF/classes/com/sun/ts/tests/jpa/ee/packaging/jar/Client.class
WEB-INF/lib/jpa_ee_packaging_jar.jar
WEB-INF/lib/jpa_ee_packaging_jar1.jar
WEB-INF/lib/jpa_ee_packaging_jar2.jar
WEB-INF/web.xml
*/
@TargetsContainer("tck-javatest")
@OverProtocol("javatest")
@Deployment(name = VEHICLE_ARCHIVE, order = 2)
public static WebArchive createDeploymentVehicle(@ArquillianResource TestArchiveProcessor archiveProcessor) {
/**
* EE10 Deployment Descriptors: jpa_ee_packaging_jar:
* META-INF/persistence.xml,META-INF/orm.xml,myMappingFile.xml,myMappingFile2.xml
* jpa_ee_packaging_jar_appmanaged_vehicle_client: META-INF/application-client.xml
* jpa_ee_packaging_jar_appmanaged_vehicle_ejb: jar.sun-ejb-jar.xml jpa_ee_packaging_jar_pmservlet_vehicle_web:
* WEB-INF/web.xml jpa_ee_packaging_jar_stateful3_vehicle_client: META-INF/application-client.xml
* jpa_ee_packaging_jar_stateful3_vehicle_ejb: jar.sun-ejb-jar.xml jpa_ee_packaging_jar_stateless3_vehicle_client:
* META-INF/application-client.xml jpa_ee_packaging_jar_stateless3_vehicle_ejb: jar.sun-ejb-jar.xml
* jpa_ee_packaging_jar_vehicles: jpa_ee_packaging_jar1: jpa_ee_packaging_jar2:
*
* Found Descriptors: War:
*
* /com/sun/ts/tests/common/vehicle/pmservlet/pmservlet_vehicle_web.xml Ear:
*
*/
@TargetsContainer("tck-javatest")
@OverProtocol("javatest")
@Deployment(name = VEHICLE_ARCHIVE, order = 2)
public static WebArchive createDeploymentVehicle(@ArquillianResource TestArchiveProcessor archiveProcessor) {
// War
// the war with the correct archive name
WebArchive jpa_ee_packaging_jar_pmservlet_vehicle_web = ShrinkWrap.create(WebArchive.class, "jpa_ee_packaging_jar_pmservlet_vehicle_web.war");
// The class files
jpa_ee_packaging_jar_pmservlet_vehicle_web.addClasses(
com.sun.ts.tests.common.vehicle.ejb3share.EJB3ShareBaseBean.class,
ee.jakarta.tck.persistence.jpa.ee.packaging.jar.Client.class,
com.sun.ts.tests.common.vehicle.VehicleRunnerFactory.class,
com.sun.ts.tests.common.vehicle.ejb3share.UseEntityManager.class,
com.sun.ts.tests.common.vehicle.ejb3share.EJB3ShareIF.class,
com.sun.ts.lib.harness.EETest.Fault.class,
com.sun.ts.tests.common.vehicle.ejb3share.UseEntityManagerFactory.class,
ee.jakarta.tck.persistence.common.PMClientBase.class,
com.sun.ts.tests.common.vehicle.servlet.ServletVehicle.class,
com.sun.ts.tests.common.vehicle.VehicleRunnable.class,
com.sun.ts.tests.common.vehicle.ejb3share.UserTransactionWrapper.class,
com.sun.ts.lib.harness.EETest.class,
com.sun.ts.lib.harness.ServiceEETest.class,
com.sun.ts.tests.common.vehicle.ejb3share.EntityTransactionWrapper.class,
com.sun.ts.tests.common.vehicle.pmservlet.PMServletVehicle.class,
com.sun.ts.lib.harness.EETest.SetupException.class,
com.sun.ts.tests.common.vehicle.VehicleClient.class,
com.sun.ts.tests.common.vehicle.ejb3share.NoopTransactionWrapper.class
);
// The web.xml descriptor
URL warResURL = Client.class.getResource("/com/sun/ts/tests/common/vehicle/pmservlet/pmservlet_vehicle_web.xml");
// the war with the correct archive name
WebArchive jpa_ee_packaging_jar_pmservlet_vehicle_web = ShrinkWrap.create(WebArchive.class,
"jpa_ee_packaging_jar_pmservlet_vehicle_web.war");

// The class files
jpa_ee_packaging_jar_pmservlet_vehicle_web.addClasses(
EJB3ShareBaseBean.class,
Client.class,
VehicleRunnerFactory.class,
UseEntityManager.class,
EJB3ShareIF.class, Fault.class,
UseEntityManagerFactory.class,
PMClientBase.class,
ServletVehicle.class,
VehicleRunnable.class,
UserTransactionWrapper.class,
EETest.class,
ServiceEETest.class,
EntityTransactionWrapper.class,
PMServletVehicle.class,
SetupException.class,
VehicleClient.class,
NoopTransactionWrapper.class);

// The web.xml descriptor
URL warResURL = Client.class.getResource("/com/sun/ts/tests/common/vehicle/pmservlet/pmservlet_vehicle_web.xml");
if (warResURL != null) {
jpa_ee_packaging_jar_pmservlet_vehicle_web.addAsWebInfResource(warResURL, "web.xml");

// Any libraries added to the war
URL libURL;
JavaArchive jpa_ee_packaging_jar2_lib = ShrinkWrap.create(JavaArchive.class, "jpa_ee_packaging_jar2.jar");
// The class files
jpa_ee_packaging_jar2_lib.addClasses(
ee.jakarta.tck.persistence.jpa.ee.packaging.jar.C.class
);
jpa_ee_packaging_jar_pmservlet_vehicle_web.addAsLibrary(jpa_ee_packaging_jar2_lib);

JavaArchive jpa_ee_packaging_jar1_lib = ShrinkWrap.create(JavaArchive.class, "jpa_ee_packaging_jar1.jar");
// The class files
jpa_ee_packaging_jar1_lib.addClasses(
ee.jakarta.tck.persistence.jpa.ee.packaging.jar.B.class
);
jpa_ee_packaging_jar_pmservlet_vehicle_web.addAsLibrary(jpa_ee_packaging_jar1_lib);

// Call the archive processor
archiveProcessor.processWebArchive(jpa_ee_packaging_jar_pmservlet_vehicle_web, Client.class, warResURL);

// PAR
JavaArchive jpa_ee_packaging_jar = ShrinkWrap.create(JavaArchive.class, "jpa_ee_packaging_jar.jar");
jpa_ee_packaging_jar.addClass(A.class);
System.out.println("Client.cs: "+Client.class.getProtectionDomain().getCodeSource());
URL parURL = Client.class.getResource("/ee/jakarta/tck/persistence/ee/packaging/jar/persistence.xml");
System.out.println("persistence.xml: "+parURL);
jpa_ee_packaging_jar.addAsManifestResource(parURL,"persistence.xml");
parURL = Client.class.getResource("/ee/jakarta/tck/persistence/ee/packaging/jar/orm.xml");
System.out.println("orm.xml: "+parURL);
jpa_ee_packaging_jar.addAsManifestResource(parURL, "orm.xml");
parURL = Client.class.getResource("/ee/jakarta/tck/persistence/ee/packaging/jar/myMappingFile.xml");
jpa_ee_packaging_jar.addAsResource(parURL, "myMappingFile.xml");
parURL = Client.class.getResource("/ee/jakarta/tck/persistence/ee/packaging/jar/myMappingFile2.xml");
jpa_ee_packaging_jar.addAsResource(parURL, "myMappingFile2.xml");
jpa_ee_packaging_jar_pmservlet_vehicle_web.addAsLibrary(jpa_ee_packaging_jar);

return jpa_ee_packaging_jar_pmservlet_vehicle_web;
}

@Test
@Override
@TargetVehicle("pmservlet")
public void JarFileElementsTest() throws java.lang.Exception {
super.JarFileElementsTest();
// The sun-web.xml descriptor
warResURL = Client.class.getResource("/com/sun/ts/tests/common/vehicle/pmservlet/pmservlet_vehicle_web.war.sun-web.xml");
if (warResURL != null) {
jpa_ee_packaging_jar_pmservlet_vehicle_web.addAsWebInfResource(warResURL, "sun-web.xml");
}

// Any libraries added to the war
URL libURL;
JavaArchive jpa_ee_packaging_jar2_lib = ShrinkWrap.create(JavaArchive.class, "jpa_ee_packaging_jar2.jar");

// The class files
jpa_ee_packaging_jar2_lib.addClasses(C.class);

jpa_ee_packaging_jar_pmservlet_vehicle_web.addAsLibrary(jpa_ee_packaging_jar2_lib);
JavaArchive jpa_ee_packaging_jar1_lib = ShrinkWrap.create(JavaArchive.class, "jpa_ee_packaging_jar1.jar");

// The class files
jpa_ee_packaging_jar1_lib.addClasses(B.class);

jpa_ee_packaging_jar_pmservlet_vehicle_web.addAsLibrary(jpa_ee_packaging_jar1_lib);
JavaArchive jpa_ee_packaging_jar_lib = ShrinkWrap.create(JavaArchive.class, "jpa_ee_packaging_jar.jar");

// The class files
jpa_ee_packaging_jar_lib.addClasses(A.class);

// The resources
libURL = Client.class.getResource("/ee/jakarta/tck/persistence/ee/packaging/jar/persistence.xml");
jpa_ee_packaging_jar_lib.addAsManifestResource(libURL, "persistence.xml");

libURL = Client.class.getResource("/ee/jakarta/tck/persistence/ee/packaging/jar/orm.xml");
jpa_ee_packaging_jar_lib.addAsManifestResource(libURL, "orm.xml");

libURL = Client.class.getResource("/ee/jakarta/tck/persistence/ee/packaging/jar/myMappingFile.xml");
jpa_ee_packaging_jar_lib.addAsResource(libURL, "myMappingFile.xml");

libURL = Client.class.getResource("/ee/jakarta/tck/persistence/ee/packaging/jar/myMappingFile2.xml");
jpa_ee_packaging_jar_lib.addAsResource(libURL, "myMappingFile2.xml");

jpa_ee_packaging_jar_pmservlet_vehicle_web.addAsLibrary(jpa_ee_packaging_jar_lib);


// Call the archive processor
archiveProcessor.processWebArchive(jpa_ee_packaging_jar_pmservlet_vehicle_web, Client.class, warResURL);

return jpa_ee_packaging_jar_pmservlet_vehicle_web;
}

@Test
@Override
@TargetVehicle("pmservlet")
public void JarFileElementsTest() throws java.lang.Exception {
super.JarFileElementsTest();
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -18,10 +18,11 @@
-->

<persistence xmlns="https://jakarta.ee/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="https://jakarta.ee/xml/ns/persistence
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="https://jakarta.ee/xml/ns/persistence
https://jakarta.ee/xml/ns/persistence/persistence_3_2.xsd"
version="3.2">
version="3.2">

<persistence-unit name="CTS-EM" transaction-type="JTA">
<description>Persistence Unit for CTS EE Package Tests</description>
<jta-data-source>jdbc/DB1</jta-data-source>
Expand All @@ -30,6 +31,7 @@
<jar-file>jpa_ee_packaging_jar1.jar/</jar-file>
<jar-file>jpa_ee_packaging_jar2.jar/</jar-file>
</persistence-unit>

<persistence-unit name="CTS-EM2" transaction-type="JTA">
<description>Persistence Unit for CTS EE Package Tests</description>
<jta-data-source>jdbc/DB1</jta-data-source>
Expand Down

0 comments on commit d6530e0

Please sign in to comment.