好的,所以在这个例子中我有一个名为Template的父实体.模板始终具有类型.类型是很可能已经存在的FK.创建新模板并向其添加类型时会出现问题.添加类型后,如果要添加模板,则会收到错误.您收到的错误取决于方法.有谁知道如何处理这种情况?
public static void AddTemplate(Template template)
{
using (TheEntities context = new TheEntities())
{
//if (template.TemplateType.EntityKey != null)
//{
// context.Attach(template.TemplateType);
//}
context.AddToTemplates(template);
context.SaveChanges();
context.RemoveTracking(template);
}
}
Run Code Online (Sandbox Code Playgroud)
我试过尝试附加现有密钥而不是.底部对RemoveTracking的调用只是在模板和可能已加载的任何子实体上调用detach的扩展.
这是单元测试.
[TestMethod]
public void CanAddAndDeleteATemplate()
{
Template template = new Template();
template.Name = "Test";
template.Description = "Test";
TemplateType type = TemplateManager.FindTemplateTypeByName("Round");
if (type == null)
{
type = new TemplateType();
type.Name = "Round";
}
template.TemplateType = type;
TemplateManager.AddTemplate(template);
template = TemplateManager.FindTemplateByID(template.TemplateID);
Assert.IsNotNull(template);
TemplateManager.DeleteTemplate(template);
template = TemplateManager.FindTemplateByID(template.TemplateID);
Assert.IsNull(template);
}
Run Code Online (Sandbox Code Playgroud)
单元测试完美地假设模板类型"Round"尚不存在.我开始怀疑这种东西在独立的环境中是否可行.
UPDATE
好的,我将AddTemplate的代码更改为此,现在它可以正常工作..
public …Run Code Online (Sandbox Code Playgroud) 根据我读过的所有内容,以下测试方法应该通过.我试图理解它失败的原因.私有异步方法中的第一个断言按预期传递.但是,一旦任务返回并等待.检索时,CallContext中设置的值现在为null.
[TestMethod]
public void LogicalCallContextBlockingTest()
{
PerformSimpleAsyncWork().Wait();
var result = CallContext.LogicalGetData("test");
Assert.AreEqual(result, "expected");
}
private async Task PerformSimpleAsyncWork()
{
await Task.Run(() =>
{
System.Threading.Thread.Sleep(100);
CallContext.LogicalSetData("test", "expected");
var result = CallContext.LogicalGetData("test");
Assert.AreEqual(result, "expected");
});
}
Run Code Online (Sandbox Code Playgroud)