InvalidCastException when deleting entities containing uninitialized lazy components

Description

When trying to delete an entity having an uninitialized lazy component, InvalidCastException is thrown: Unable to cast object of type 'NHibernate.Intercept.UnfetchedLazyProperty' to type xxx.

I believe the problem lies at NHibernate.Engine.ForeignKeys.Nullifier, at NullifyTransientReferences. This method will try to walk through the component's property values regardless they have been initialized or not, and does not initialize the properties itself, nor does it throw any meaningful exception.
It would be nice if the uninitialized properties were initialized, or better the lazy properties were initialized only when there are any properties under the component's hierarchy which need to be nullified.
As we don't use associations and collections in out components, our workaround was to skip "nullification" of uninitialized components at all.

I have tested this using the following setups, and behavior was all the same: .NET 4.0 + Oracle.DataAccess, .NET 4.0 + System.Data.SQLite, .NET 2.0 + System.Data.SQLite

The attached test cases are to be imported into the standard NHibernate.Test project.

Environment

None

Attachments

2

Activity

Show:

Alex Zaytsev May 1, 2017 at 3:37 AM

Closing issues resolved in 4.0.3

Alex Zaytsev January 20, 2015 at 8:20 AM

Merged to 4.0.x at 569b49c4ead3f026f0a161c1b9b6833fb92e7216

Gabor Szecsi September 9, 2014 at 1:17 PM

I have attached the workaround we used. The xml documentation comments on the classes are in Hungarian, which basically means the same as the bug report in this issue.
As a long time has passed I don't remember this issue exactly. I will try to dig myself into this later, when a little spare time is available for me.

July 10, 2014 at 12:33 AM

Hello! About your workaround, what do you mean with "nullification" of uninitialized components? Can you provide us an example?

Fixed

Details

Assignee

Reporter

Labels

Components

Fix versions

Affects versions

Priority

Who's Looking?

Open Who's Looking?
Created May 28, 2013 at 4:06 PM
Updated May 1, 2017 at 3:37 AM
Resolved January 20, 2015 at 8:20 AM
Who's Looking?