我做了 2 个项目来测试 .NET Framework 4.6.1 标准控制台应用程序和 .NET Standard 2.0 库上的 NLog。我的意图是将尽可能多的代码移植到 .NET Standard 2.0 以实现未来的多平台兼容性。
两者共享相同的代码,但 .NET Standard 版本会产生异常。
这是代码
Console.WriteLine("Writing log");
Logger _errorLog = LogManager.GetLogger("ErrorsLogger");
Logger _tradesLog = LogManager.GetLogger("TradesLogger");
_errorLog.Error("This is the log message!!!");
Console.WriteLine("End log");
Console.Read();
这是 App.Config
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<section name="nlog" type="NLog.Config.ConfigSectionHandler, NLog"/>
</configSections>
<nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<targets>
<target name="ErrorsLogger" xsi:type="File" fileName="ErrorsLog.txt" />
<target name="TradesLogger" xsi:type="File" fileName="TradesLog.txt" />
</targets>
<rules>
<logger name="ErrorsLogger" minlevel="Info" writeTo="ErrorsLogger" />
<logger name="TradesLogger" minlevel="Info" writeTo="TradesLogger" />
</rules>
</nlog>
</configuration>
我在 .NET 4.6.1 控制台应用程序中得到了很好的日志,并生成了预期的日志文件,其中包含日志消息。
如果我通过一些 Microsoft 单元测试项目运行 .NET Standard 2.0 库,当它尝试调用 _errorLog.GetLogger 时会出现此异常
UnitTestProject.UnitTest1.TestMethod1 抛出异常:System.TypeInitializationException:'NLog.LogManager' 的类型初始化程序抛出异常。---> System.TypeInitializationException:'NLog.LogFactory' 的类型初始化程序引发了异常。---> System.MissingMethodException:找不到方法:'System.AppDomainSetup System.AppDomain.get_SetupInformation()'。
非静态方法中抛出的异常:
关于获得更好异常的非静态方法:
在 GetLogger("X") 级别抛出异常,这是一个非静态构造函数。初始化例程甚至在尝试记录某些内容之前就崩溃了。
此外,我在错误列表中收到警告(黄色感叹号):
警告 'configuration' 元素未声明。
添加内部日志不会产生任何输出。这是我使用的配置,从他们的内部日志指南开始:
InternalLogger.LogLevel = LogLevel.Trace;
InternalLogger.LogFile = @"C:\temp\int.txt";
InternalLogger.LogToConsole = true;
InternalLogger.LogToConsoleError = true;
InternalLogger.LogWriter = new StringWriter(new StringBuilder());
InternalLogger.LogToTrace = true;
LogManager.ThrowConfigExceptions = true;
LogManager.ThrowExceptions = true;
Logger logger = LogManager.GetLogger("foo");
我是管理员,Visual Studio 2017 以管理员身份启动,我有权在 C:\temp 中写入,而 .NET 4.6.1 控制台应用程序能够在该文件夹中写入,并且位于同一个项目中。
内部日志文件为空,单元测试项目运行测试成功。
我不知道发生了什么。现在没有抛出错误。
欢迎任何调试问题的建议。
GitHub 上的ISSUE已打开。
这是我为您展示的测试解决方案(密码: logging123)。现在我已更新到 Nlog 4.5,您将看到 .NET 框架解决方案在尝试获取旧版本的 Nlog(我从未引用过)时抛出错误,并且 .NET Core 单元测试解决方案有效但没有产生任何文件。