从命令行运行SpecRun作为持续集成设置的一部分,并且最近一个被忽略的(@ignore
)测试在SpecRun完成时生成了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 ==========
我在论坛中找到了错误代码列表:https://groups.google.com/forum/?fromgroups=#!主题/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中检查更高的错误代码。