Unenhanced generated id field of a primitive wrapper type causes NPE
--------------------------------------------------------------------
Key: OPENJPA-315
URL: https://issues.apache.org/jira/browse/OPENJPA-315
Project: OpenJPA
Issue Type: Bug
Reporter: Dain Sundstrom
Priority: Critical
Fix For: 1.0.0
Unenhanced generated id field of a primitive wrapper type causes NPE because
the field value is null. This bug only occurs when the id field is an object
type as primitive fields are automatically initialized to 0. I believe this is
a critical bug because when using a primitive field the system appears to work
but the id field is always 0 which could cause data corruption. The following
stack trace shows the bug:
<openjpa-0.0.0-r420667:564688M nonfatal general error>
org.apache.openjpa.persistence.PersistenceException: null
at org.apache.openjpa.kernel.BrokerImpl.persist(BrokerImpl.java:2437)
at org.apache.openjpa.kernel.BrokerImpl.persist(BrokerImpl.java:2251)
at
org.apache.openjpa.kernel.DelegatingBroker.persist(DelegatingBroker.java:1010)
at
org.apache.openjpa.persistence.EntityManagerImpl.persist(EntityManagerImpl.java:541)
at
org.apache.openjpa.enhance.AbstractUnenhancedClassTest.getObjectIdHelper(AbstractUnenhancedClassTest.java:134)
at
org.apache.openjpa.enhance.AbstractUnenhancedClassTest.testGetObjectIdOnOpenJPAType(AbstractUnenhancedClassTest.java:115)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at
com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:40)
Caused by: java.lang.NullPointerException
at
org.apache.openjpa.util.ApplicationIds.fromPKValues(ApplicationIds.java:152)
at
org.apache.openjpa.enhance.ReflectingPersistenceCapable.pcNewObjectIdInstance(ReflectingPersistenceCapable.java:257)
at
org.apache.openjpa.util.ApplicationIds.create(ApplicationIds.java:384)
at org.apache.openjpa.kernel.BrokerImpl.persist(BrokerImpl.java:2405)
... 23 more
The attached patch reproduces this bug. The patch is a clone of
TestUnenhancedFieldAccess that simply changes the id field to type Integer.
--
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.