0

我有以下单元测试方法:

void TestOrderItemDelete()
{
    using (new SessionScope())
    {
        var order = Order.FindById(1234);
        var originalItemCount = order.OrderItems.Count;
        Assert.IsTrue(originalCount > 0);
        var itemToDelete = order.OrderItems[0];
        itemToDelete.DeleteAndFlush(); // itemToDelete.Delete();
        order.Refresh();
        Assert.AreEqual(originalCount - 1, order.OrderItems.Count);
    }
}

正如您从 DeleteAndFlush 命令后的评论中看到的那样,我必须将其从简单的 Delete 更改为通过单元测试。为什么是这样?对于我添加 OrderItem 的其他单元测试,情况并非如此。这工作得很好:

void TestOrderItemAdd()
{
    using (new SessionScope())
    {
        var order = Order.FindById(1234);
        var originalItemCount = order.OrderItems.Count;
        var itemToAdd = new OrderItem();
        itemToAdd.Order = order;
        itemToAdd.Create(); // Notice, this is not CreateAndFlush
        order.Refresh();
        Assert.AreEqual(originalCount + 1, order.OrderItems.Count);
    }
}

当我开始使用 Order.OrderItems 关系映射的延迟实例化时,所有这些都出现了,并且必须在测试周围添加 using(new SessionScope) 块。

有任何想法吗?

4

1 回答 1

1

如果不知道映射的内容,这很难排除故障,但一种可能性是您使用数据库中的标识字段(或序列等)映射了 OrderItem 的 ID 属性。如果是这种情况,NHibernate 必须访问数据库以生成 ID 字段,因此立即插入 OrderItem。删除不是这样,因此 SQL 删除语句在会话刷新之前不会执行。

于 2008-12-19T20:03:32.530 回答