Matt Watson created CAY-2851: -------------------------------- Summary: Replace Existing OneToOne From New Object Key: CAY-2851 URL: https://issues.apache.org/jira/browse/CAY-2851 Project: Cayenne Issue Type: Bug Components: Core Library Affects Versions: 4.2, 5.0-M2 Reporter: Matt Watson
We have a One to One (belongsTo on both sides) relationships between 2 Models (A & B), very similar to the Painting < - > PaintingInfo in the test environment. When we have an existing {{a1}} related to {{b1}} (and vice-versa b1 to a1), and we create a new b2. Then set {{{}b2.toA = a1{}}}. We find out that {{b1.toA}} is still related to {{a1}} instead of {{null}} The closest test that I found is in {code:java} CDOOneDep2OneIT.testReplace{code} but just need to set from the other side of the relationship instead. I can push up a breaking test soon. Not sure if you prefer it to be on {{master}} or {{{}STABLE-4.2{}}}. It seems that during {{b2.setToA(a1)}} the call to {{setToOneTarget("toA", a1, true)}} triggers a call to {{setReverseRelationship("toA", a1)}} , which triggers a call to {{{}setToOneTarget("toB", b2, false){}}}. In here it accesses the {{oldTarget}} which is {{{}b1{}}}. This is where I feel it should nullify {{b1.toA}} using {{{}unsetReverseRelationship("toB", b1){}}}. However, it does NOT because {{setReverse}} was passed in as {{{}false{}}}. Since it does not, at this point if you check the relationships: {{b2.toA == a1}} _GOOD_ {{a1.toB == b2}} _GOOD_ {{b1.toA == a1}} _BAD_ -- This message was sent by Atlassian Jira (v8.20.10#820010)