I checked in a fix (similar to your patch + minor modifications in method) and a new test in AnonymousFieldsTest. The test fails with NPE when using QueryReferenceBroker version 1.15 and pass with latest version.
Hope this will solve your problem too.
Thank you very much!
regards, java-dumbhead Armin
Armin Waibel wrote:
Hi Andrew,
seems you patch will do the job. I will check this ASAP. Thanks!
regards, Armin
Clute, Andrew wrote:
I created what I think is an appropriate patch -- it fixed my issue. Here it is.
Index: QueryReferenceBroker.java =================================================================== RCS file: /home/cvspublic/db-ojb/src/java/org/apache/ojb/broker/core/QueryReferenc eBroker.java,v retrieving revision 1.15 diff -u -r1.15 QueryReferenceBroker.java --- QueryReferenceBroker.java 6 May 2004 19:45:57 -0000 1.15 +++ QueryReferenceBroker.java 12 May 2004 21:47:44 -0000 @@ -425,6 +425,7 @@ { return new Identity(referencedObject, pb); } + return null; } else {
-----Original Message-----
From: Clute, Andrew [mailto:[EMAIL PROTECTED] Sent: Wednesday, May 12, 2004 5:37 PM
To: OJB Users List; OJB Developers List
Subject: Bug in QueryReferenceBroker?
I recently updated to HEAD and am finding a weird issue now.
I have an object Session, that has a reference to an Object called Person. Now Person is a proxy object. I am using an Anonymous FK to reference Person from Session.
When I try to restore Session when it has no Person hanging on it, it restores the Session object with a Person Proxy object hanging off of it (it shouldn't!), and the Proxy's PK being a collection of null.
I think I might have narrowed down why it is happening:
Method getReferencedObjectIdentity(), here is a code snipet:
if (hasNullifiedFKValue) { if(isAnonymousKeyReference(cld, rds)) { Object referencedObject = rds.getPersistentField().get(obj); if(referencedObject != null) { return new Identity(referencedObject, pb); } } else { return null; } }
// ensure that top-level extents are used for Identities return new Identity(rds.getItemClass(), pb.getTopLevelClass(rds.getItemClass()), fkValues);
In my case, I have a nullifiedFKValue, so it goes into the first If block, and then it sees that it is an AnonymousKeyReference, but then my referencesObject us null (like it should be). But instead of returning null, it jums out to the bottom where it returns a new Identity!! Why is it doing that? I can see where Armin has made some changes to handle better AnonymousFK's, is this a side-effect of that?
-ANdrew
--------------------------------------------------------------------- To unsubscribe, e-mail: [EMAIL PROTECTED] For additional commands, e-mail: [EMAIL PROTECTED]
--------------------------------------------------------------------- To unsubscribe, e-mail: [EMAIL PROTECTED] For additional commands, e-mail: [EMAIL PROTECTED]
--------------------------------------------------------------------- To unsubscribe, e-mail: [EMAIL PROTECTED] For additional commands, e-mail: [EMAIL PROTECTED]