根据我读过的所有内容,应该通过以下测试方法。我试图理解它失败的原因。私有异步方法中的第一个断言按预期传递。但是,一旦任务返回并等待。检索时,CallContext中设置的值现在为空。
[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");
});
}
答案 0 :(得分:10)
使用async
关键字修饰的方法在调用时创建子上下文。对此子上下文所做的任何更改都不会传播到父上下文。
因此,PerformSimpleAsyncWork
获取一个子上下文,该上下文可以看到调用者放入上下文的任何内容,但是它所做的任何更改都不可用于调用者(LogicalCallContextBlockingTest
)。 / p>
如果您想了解更多信息,Stephen Cleary对此行为有good writeup。