小编Mic*_* M.的帖子

实体框架 - 使用分离实体问题

好的,所以在这个例子中我有一个名为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)

c# entity-framework

7
推荐指数
1
解决办法
9048
查看次数

使用异步任务不流动的逻辑CallContext值

根据我读过的所有内容,以下测试方法应该通过.我试图理解它失败的原因.私有异步方法中的第一个断言按预期传递.但是,一旦任务返回并等待.检索时,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)

c# asynchronous task-parallel-library

6
推荐指数
1
解决办法
1990
查看次数