我希望NLog目标停止收听日志.该RemoveTarget方法似乎并没有工作.这是一个失败的测试.
public class when_stopping_to_listen
{
static Logger Logger;
static MemoryTarget target;
Establish context = () =>
{
var config = new LoggingConfiguration();
Logger = LogManager.GetLogger("TestLogger");
target = new MemoryTarget {Layout = "${message}", Name = "TestTarget"};
config.AddTarget(target.Name, target);
config.LoggingRules.Add(new LoggingRule("*", LogLevel.Trace, target));
LogManager.Configuration = config;
};
Because of = () =>
{
var config = LogManager.Configuration;
config.RemoveTarget(target.Name);
LogManager.Configuration = config;
Logger.Info("Test");
};
It should_be_empty = () => target.Logs.ShouldBeEmpty();
}
Run Code Online (Sandbox Code Playgroud)
提前致谢.
nem*_*esv 10
我不知道为什么RemoveTarget不起作用.但是,如果您从每个规则中删除目标,则测试通过:
Because of = () =>
{
foreach (var rule in config.LoggingRules)
{
rule.Targets.Remove(target);
}
Logger.Info("Test");
};
Run Code Online (Sandbox Code Playgroud)
如果你删除LoggingRule而不是目标它也有效:
public class when_stopping_to_listen
{
//...
static LoggingRule rule;
Establish context = () =>
{
//...
rule = new LoggingRule("*", LogLevel.Trace, target);
config.LoggingRules.Add(rule);
LogManager.Configuration = config;
};
Because of = () =>
{
var config = LogManager.Configuration;
config.LoggingRules.Remove(rule);
LogManager.Configuration = config;
Logger.Info("Test");
};
//...
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2369 次 |
| 最近记录: |