我正在使用 Gallio/MbUnit 框架进行 Web 测试,并且测试是从 Jenkins 开始的。我已经安装了 Gallio/MbUnit 插件,它正在发布 xml 报告。我试图找到一种在“测试结果”部分显示测试日志或控制台消息的方法,以便团队可以轻松读取失败,而不是深入研究任何失败的测试运行的“控制台输出”。
当我使用 Icarus 在本地机器上运行这些 Gallio/MbUnit 测试时,一切都非常好地格式化了,但使用 Jenkins 就没有那么多了。我想继续使用它并改进我们显示错误的方式。建议?
对于失败的测试:
Failed
...MainMenuTests.AcctClaimsItems
Failing for the past 4 builds (Since Failed#128 )
Took 47 sec.
add description
Error Message
Expected value to be false.Actual Value : d:\Jenkins\jobs\...\workspace\WebTesting\Base\Helpers.cs:line 90d:\Jenkins\jobs\...\workspace\WebTesting\TigerEye\Tests\MainMenuTests.cs:line 329true
Stacktrace
   at WebTesting.Base.Helpers.Click(IWebDriver driver, IWebElement element) in 
从原始控制台输出:
Start time: 4:21 PM
Initializing the runtime and loading plugins.
Verifying test files.
Initializing the test runner.
Running the tests.
[failed] Test WebTesting/MainMenuTests/AcctClaimsItems
Expected value to be false.
Found System.Web Exception after click to url 
.../Accounting/FETReport.aspx
Actual Value : true
   at WebTesting.Base.Click(IWebDriver driver, IWebElement element) in d:\Jenkins\jobs\...\workspace\WebTesting\Base\StaticHelpers.cs:line 90 at WebTesting...\Tests.MainMenuTests.AcctClaimsItems() in d:\Jenkins\jobs\...\workspace\WebTesting\TigerEye\Tests\MainMenuTests.cs:line 329
代码:
if (driver.PageSource.Contains("System.Web - Exception"))
{
    TestLog.Write("Found exception on page {0}", driver.Url);
    TestLog.Write(driver.PageSource.ToString());
    Console.Write("Found exception on page {0}", driver.Url);
    Console.Write(driver.PageSource.ToString());
    Assert.IsFalse(driver.PageSource.Contains("System.Web - Exception"), "Found      System.Web Exception after click to url {0}",driver.Url);
}