SpecRun使用@ignore测试返回退出代码120

时间:2013-04-05 23:04:00

标签: continuous-integration specflow exit-code specrun

作为持续集成设置的一部分,从命令行运行SpecRun,最近,当SpecRun完成时,忽略的(@ignore)测试生成退出代码120。

目前,我们打破任何不等于0的退出代码的构建(通用成功指标!)。

退出代码120究竟是什么意思?简单地说“测试被忽略了”吗?或者它意味着更多?

还会返回哪些其他值?

下面的示例构建输出。我们收集所有退出代码(当前1个SpecRun任务,因此只收集1个退出代码),并打印到“退出代码”

58>  Done.
58>  Result: all tests passed (5 ignored)
58>    Total: 478
58>    Succeeded: 473
58>    Ignored: 5
58>    Pending: 0
58>    Skipped: 0
58>    Failed: 0
58>  
58>    Execution Time: 00:00:42.4550000
58>
58>  exit codes 120
58>
58>Build FAILED.
58>
58>Time Elapsed 00:00:44.21
========== Rebuild All: 57 succeeded, 1 failed, 0 skipped ==========

1 个答案:

答案 0 :(得分:2)

我在论坛中找到了错误代码列表:https://groups.google.com/forum/?fromgroups=#!topic/specrun/vPQ7z2kpkbs

按错误代码对列表进行排序后,您将获得:

Unknown = 0,
Succeeded = 110,
Ignored = 120,
Pending = 210 
NothingToRun = 310,
Skipped = 320,
Inconclusive = 410,
CleanupFailed = 420,
RandomlyFailed = 430,
Failed = 440,
InitializationFailed = 450,
FrameworkError = 510,
ConfigurationError = 520,

基于此列表,我们在构建服务器上使用以下命令行脚本来执行测试:

SpecRun.exe [...]

if errorlevel 200 exit /b %errorlevel%

exit /b 0

我们使用exit命令返回错误代码。 对于较高的错误级别代码(> = 200),我们返回错误代码以中断构建。 但是,低于该限制的错误代码将被视为成功,我们将返回0.

使用此限制(200),成功和忽略的案例被视为成功,其他一切都会破坏构建。如果您还想允许待定测试(210),您只需在IF中检查更高的错误代码。