Hi Michael,
please excuse my ignorance, now I finally understand what the
difference between the jdori and iut targets is.
Having read http://issues.apache.org/jira/browse/JDO-357 I only then
happened to have a look at RunRules.html, which was very informative ;-)
It seems that running the iut target will find the
jpox-core-SNAPSHOT.jar in the maven repository and use it, so that the
iut target will run even when iut_jars is empty. Maybe that's a little
confusing (and I'd wonder which will be found first in the classpath if
both JPOX is present in the maven repo and some other implementation in
iut_jars).
Regards,
Jörg
Michael Bouschen schrieb:
Hi Jörg,
Thanks Michelle and Erik for your answers. I
simply dropped the jpox-enhancer-SNAPSHOT.jar into iut_jars, and now it
works. It's just the CompletenessTest failing once per kind of identity
now, and I guess that's as currently expected.
On my side companyPMInterface.conf is the only configuration that is
failing for both identity types.
Just wondering a bit whether the tck20 project shouldn't claim the
jpox-enhancer-SNAPSHOT.jar as a maven dependency?
It already does. The goal 'maven runtck.jdori' runs the tck using the
jdori i.e. JPOX. Then everything gets setup automatically and there is
no need to copy any jars to the iut_jars directory. You use the goal
'maven runtck.iut' if you want to run a JDO implementation (called
Implemnentation Under Test) against the tck. This does not any JPOX
jars. Instead it puts all the jars in the iut_jars directory in the
classpath.
Regards Michael
Regards,
Jörg
Michelle Caisse schrieb:
Hi Jörg ,
I think you just need to drop the jpox enhancer jar file into the
iut_jars directory of your tck installation, or otherwise get it onto
your classpath.
-- Michelle
Jörg von Frantzius wrote:
Hi,
when I run the tests, I see the following error. Is there anything I
can do about this myself per chance?
Thanks for even more hints,
Jörg
1)
test(org.apache.jdo.tck.models.fieldtypes.TestArrayCollections)javax.jdo.JDOFatalException:
The JPOX "implementation creator" was not found in the CLASSPATH.
To use PersistenceManager.newInstance() you need to have the JPOX
Enhancer in the CLASSPATH.
at
org.jpox.PMFContext.getImplementationCreator(PMFContext.java:90)
at
org.jpox.store.rdbms.table.ColumnCreator.createColumnsForReferenceField(ColumnCreator.java:288)
at
org.jpox.store.rdbms.table.ColumnCreator.createColumnsForField(ColumnCreator.java:411)
at
org.jpox.store.rdbms.table.ColumnCreator.createColumnsForJoinTables(ColumnCreator.java:145)
at
org.jpox.store.rdbms.table.ArrayTable.initialize(ArrayTable.java:93)
at
org.jpox.store.rdbms.RDBMSManager$ClassAdder.addClassTablesAndValidate(RDBMSManager.java:2613)
at
org.jpox.store.rdbms.RDBMSManager$ClassAdder.run(RDBMSManager.java:2225)
at
org.jpox.store.rdbms.RDBMSManager$MgmtTransaction.execute(RDBMSManager.java:2081)
at
org.jpox.store.rdbms.RDBMSManager.addClasses(RDBMSManager.java:576)
at
org.jpox.store.rdbms.RDBMSManager.addClass(RDBMSManager.java:590)
at
org.jpox.store.StoreManager.getDatastoreClass(StoreManager.java:983)
at
org.jpox.state.StateManagerImpl.populateStrategyFields(StateManagerImpl.java:770)
at
org.jpox.state.StateManagerImpl.<init>(StateManagerImpl.java:575)
at
org.jpox.AbstractPersistenceManager.internalMakePersistent(AbstractPersistenceManager.java:1149)
at
org.jpox.AbstractPersistenceManager.makePersistent(AbstractPersistenceManager.java:1205)
at
org.apache.jdo.tck.models.fieldtypes.TestArrayCollections.runTest(TestArrayCollections.java:97)
at
org.apache.jdo.tck.models.fieldtypes.TestArrayCollections.test(TestArrayCollections.java:73)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native
Method)
at
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at org.apache.jdo.tck.JDO_Test.runBare(JDO_Test.java:237)
at
org.apache.jdo.tck.util.BatchTestRunner.doRun(BatchTestRunner.java:107)
at
org.apache.jdo.tck.util.BatchTestRunner.start(BatchTestRunner.java:147)
at
org.apache.jdo.tck.util.BatchTestRunner.main(BatchTestRunner.java:122)
NestedThrowablesStackTrace:
java.lang.ClassNotFoundException:
org.jpox.enhancer.ImplementationCreatorImpl
at java.net.URLClassLoader$1.run(URLClassLoader.java:200)
at java.security.AccessController.doPrivileged(Native
Method)
at
java.net.URLClassLoader.findClass(URLClassLoader.java:188)
at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
at
sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:268)
at java.lang.ClassLoader.loadClass(ClassLoader.java:251)
at
java.lang.ClassLoader.loadClassInternal(ClassLoader.java:319)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:242)
at
org.jpox.PMFContext.getImplementationCreator(PMFContext.java:77)
at
org.jpox.store.rdbms.table.ColumnCreator.createColumnsForReferenceField(ColumnCreator.java:288)
at
org.jpox.store.rdbms.table.ColumnCreator.createColumnsForField(ColumnCreator.java:411)
at
org.jpox.store.rdbms.table.ColumnCreator.createColumnsForJoinTables(ColumnCreator.java:145)
at
org.jpox.store.rdbms.table.ArrayTable.initialize(ArrayTable.java:93)
at
org.jpox.store.rdbms.RDBMSManager$ClassAdder.addClassTablesAndValidate(RDBMSManager.java:2613)
at
org.jpox.store.rdbms.RDBMSManager$ClassAdder.run(RDBMSManager.java:2225)
at
org.jpox.store.rdbms.RDBMSManager$MgmtTransaction.execute(RDBMSManager.java:2081)
at
org.jpox.store.rdbms.RDBMSManager.addClasses(RDBMSManager.java:576)
at
org.jpox.store.rdbms.RDBMSManager.addClass(RDBMSManager.java:590)
at
org.jpox.store.StoreManager.getDatastoreClass(StoreManager.java:983)
at
org.jpox.state.StateManagerImpl.populateStrategyFields(StateManagerImpl.java:770)
at
org.jpox.state.StateManagerImpl.<init>(StateManagerImpl.java:575)
at
org.jpox.AbstractPersistenceManager.internalMakePersistent(AbstractPersistenceManager.java:1149)
at
org.jpox.AbstractPersistenceManager.makePersistent(AbstractPersistenceManager.java:1205)
at
org.apache.jdo.tck.models.fieldtypes.TestArrayCollections.runTest(TestArrayCollections.java:97)
at
org.apache.jdo.tck.models.fieldtypes.TestArrayCollections.test(TestArrayCollections.java:73)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native
Method)
at
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at org.apache.jdo.tck.JDO_Test.runBare(JDO_Test.java:237)
at
org.apache.jdo.tck.util.BatchTestRunner.doRun(BatchTestRunner.java:107)
at
org.apache.jdo.tck.util.BatchTestRunner.start(BatchTestRunner.java:147)
at
org.apache.jdo.tck.util.BatchTestRunner.main(BatchTestRunner.java:122)
|