按道理来说,单元测试中基本没有对于日志的需求,这是由于单元测试的定位来决定的。
因为单元测试的思想就是针对的都是小段代码的测试,逻辑明确,如果测试运行不通过,简单调试一下,就能很容易地排查问题。但是单元测试也是一个简便好用的的启动器。总不能调试任何代码,都要我启动一个Windows或者Web项目吧,这样太笨重了,而且项目越大,启动时间越长。在把单元测试用作启动器的情况下,就会有需求使用log4net.
进入正题
如何在一个单元测试项目中,配置log4net:
1. 添加log4net配置文件
这里的重点不在于配置文件的内容,而在于配置文件的名字。
- 如果测试项目的名字为A, 那么配置文件的名字应该是A.dll.config
- 邮件配置文件->属性,把属性“Copy to output Directory”改成”Copy alwasy”
2. 修改Assembly.cs文件
在文件的末尾,添加上下面的一行代码
[assembly: log4net.Config.XmlConfigurator(Watch = true)]
3. 单元测试中定义全局启动,执行Log4net加载配置文件
[AssemblyInitialize] public static void AssemblyInitialize(TestContext context) { log4net.Config.XmlConfigurator.Configure(); }
如何在单元测试中配置log4net,技巧就这些,希望能帮到有这个需求的博客园朋友。