EF中的SaveChanges()是否可以插入未添加的对象?

时间:2011-08-20 03:07:20

标签: c# entity-framework tdd

我有一些代码,这是我第一次为实际工作项目做TDD的努力的结果。在尝试引导时,我创建了一个实体模型,并测试断言所需的数据记录是否存在实现报告,这是我已经确定的第一个具体目标。

我认为它工作得相当好,直到我发现代码看起来有错误,并且 YET测试仍然通过

以下是片段:错误(我认为)是对AddObject()的缺失调用。

如果有人有耐心/倾向于看整件事,我会将其粘贴到gist

测试代码:

TestFactory target = new TestFactory(@"data source=biz2\da;initial catalog=DirectAgents;integrated security=True;");
DirectAgentsEntities actual = target.Create();
Assert.IsNotNull(actual);

var advertisers = actual.Advertisers.OrderBy(c => c.Id).ToList();
Advertiser advertiser1 = advertisers.ElementAt(0);
Assert.AreEqual("Advertiser 1", advertiser1.Name);

实施守则:

 public TestFactory(string connectionString)
 {
     this._connectionString = connectionString;
 }

 public DirectAgentsEntities Create()
 {
    CleanUp(this.DirectAgentsEntities);
    AddAdvertiserClients();
    var db = this.DirectAgentsEntities;
    return db;
}
private void AddAdvertiserClients()
{
    var db = this.DirectAgentsEntities;
    Advertiser a;
    a = new Advertiser
    {
        Name = "Advertiser 1",
        Client = db.Clients.First(c => c.Name == "Client 1")
    };
    db.SaveChanges();
}
private DirectAgentsEntities DirectAgentsEntities
{
    get
    {
        string entityConnectionFormat = @"metadata=res://*/Formss.AB2.Model.ABModel.csdl|res://*/Formss.AB2.Model.ABModel.ssdl|res://*/Formss.AB2.Model.ABModel.msl;provider=System.Data.SqlClient;provider connection string=""{0};multipleactiveresultsets=True;App=EntityFramework""";
        string entityConnectionString = String.Format(entityConnectionFormat, _connectionString);
        return new DirectAgentsEntities(entityConnectionString);
    }
}
private string _connectionString;

如何在不调用AddObject的情况下添加行?我应该仔细查看我的代码以获得一个微妙的错误吗?

1 个答案:

答案 0 :(得分:3)

我相信你说创建AddObject后你觉得需要Advertiser? 如果我误解了这个问题,我很抱歉。

当您将AdvertiserClient相关联时,生成的代码中发生的事情是Advertiser也被添加到另一个Client.Advertisers集合中关系的一面。
这会在Client对象上发生变化,并由SaveChanges调用保存。