我在协助小伙伴调试一个只有在 GitHub 的 Action 自动测试时才会炸的问题,而我发现默认的控制台输出是不会在 GitHub 的 Action 显示的,换句话说,在使用 dotnet test 时,代码里面使用的控制台输出不会进行输出

解决方法很简单,只需要在控制台输出的部分逻辑修改为 Console.WriteLine 而不是 Debug.WriteLine 方法

然后在 dotnet test 的命令加上 -l "console;verbosity=detailed" 代码,如下面代码

dotnet test --configuration release -l "console;verbosity=detailed"

这样就能在 GitHub 的 Action 进行单元测试时,输出对应的日志

为什么 Debug.WriteLine 方法没有输出?原因是 --configuration release 配置了不要让 Debug 下输出

更多请看 Console.WriteLine calls during dotnet test are not emitted to the console on Windows · Issue #799 · microsoft/vstest


本文会经常更新,请阅读原文: https://dotnet-campus.github.io//post/dotnet-%E5%A6%82%E4%BD%95%E5%9C%A8-dotnet-test-%E5%8D%95%E5%85%83%E6%B5%8B%E8%AF%95%E6%8E%A7%E5%88%B6%E5%8F%B0%E9%87%8C%E8%BE%93%E5%87%BA%E6%97%A5%E5%BF%97%E5%86%85%E5%AE%B9.html ,以避免陈旧错误知识的误导,同时有更好的阅读体验。

知识共享许可协议 本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。欢迎转载、使用、重新发布,但务必保留文章署名 lindexi (包含链接: https://dotnet-campus.github.io/ ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请 与我联系