2

我正在尝试将应用程序从 NHibernate 1.x 迁移到 2.1,我注意到一些奇怪的事情:我的不可变对象在我的集成测试中被删除了。

例如,这个测试曾经通过:

[Test, ExpectedException(typeof(NHibernate.HibernateException))]
public void DeleteExistingInstanceThrows()
{
    // Note: NHib transaction is opened/rolled back in test setup/teardown
    m_testRecordId = CreateRecordInDB();
    var dao = new NHibFactory().GetTransDao();
    var obj = dao.GetById((long)m_testRecordId, false);

    dao.Delete(obj);
    dao.CommitChanges();

    Assert.IsFalse(TestRecordExists(m_testRecordId));
}

应该抛出对 CommitChanges 的调用,因为试图删除其类型映射为 mutable="false" 的实例。然而,在更新了预期的异常类型之后,这个测试现在失败了(因为没有抛出异常)。我检查了数据库并通过测试进行了跟踪,创建了记录,加载了实例,然后再次删除了记录。

有问题的类与另一个类映射到同一个表 - 它或多或少旨在作为该数据子集的只读视图。这是类映射:

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2">
    <class name="Sample.Trans, Sample" table="tblTrans" mutable="false">

        <id name="Id" column="transId" unsaved-value="0">
            <generator class="identity" />
        </id>

        <property name="Amount" column="amount" type="Decimal" />

        <!-- ...a half dozen other mapped fields... -->
    </class>
</hibernate-mapping>

我希望我遗漏了一些基本的东西,但是我一直在网上搜索 mutable 属性可能被忽略的任何原因,但我发现是空的。

更新:

使用 Log4Net 进行日志记录,很明显 NHibernate 正在向数据库发送删除命令。

4

2 回答 2

3

深入研究后,我发现在 DefaultDeleteEventListener 的 OnDelete 方法中注释掉了这段代码:

/*
if ( !persister.isMutable() ) {
throw new HibernateException(
"attempted to delete an object of immutable class: " +
MessageHelper.infoString(persister)
);
}*/

因此,在尝试删除不可变实例时不会引发异常,并且删除确实会在之后发生,就好像该实例是可变的一样。

我已经用我的发现向 NHibernate 维护者发送了一条说明 - 对我来说看起来像是一个错误。

另一张海报指出,此问题已在 2009 年 10 月 31 日的 2.1.1 版中修复。

更新:

截至 2011 年 2 月,NHibernate 现在能够再次删除不可变类实例。不可变对象应该是可删除的——它们最初不是的事实是实际的错误。

于 2009-10-08T15:00:17.470 回答
0

我在相同的情况下遇到了完全相同的问题(从 1.x 升级)。该错误已在 10 月 31 日发布的 2.1.1 中修复。

/埃米尔

于 2009-11-09T08:09:54.137 回答