1

我正在尝试将 tSQLt / SQLTest 与 CruiseControl.NET 集成我的测试正在运行,并且我已经编写了 xsl 文件来显示结果,但是如果任何测试失败,我需要知道如何将构建标记为失败。

我的 CCNet 高管是:

<exec executable="$(sqlCmdPath)">
    <description>Run Unit Tests</description>
    <buildArgs>-E -d MyDatabase 
       -i "\CruiseControlProjects\Configuration\CI_SQL\RunTests.sql"
    </buildArgs>
    <baseDirectory>\Artifacts\MyDatabase</baseDirectory>
    <successExitCodes>0,63</successExitCodes>
</exec>

运行测试.sql:

IF EXISTS (SELECT * FROM sys.objects WHERE OBJECT_ID = OBJECT_ID(N'[tSQLt].[RunAll]')
AND TYPE IN (N'P',N'PC'))
BEGIN
EXECUTE [tSQLt].[RunAll]
END

测试运行,我有一个后续任务,它在 xml 中生成结果,然后合并到构建日志中:

<exec executable="$(sqlCmdPath)">
    <description>Get Unit Tests</description>
    <buildArgs>-E -b -d MyDatabase -h-1 -y0 -I 
       -i "\CruiseControlProjects\Configuration\CI_SQL\GetTestResults.sql" 
       -o "\CruiseControlProjects\Configuration\CI_SQL\Results\TestResults.xml"
    </buildArgs>
    <baseDirectory>\Artifacts\MDatabase</baseDirectory>
    <successExitCodes>0,63</successExitCodes>
</exec>

那么如何让整体构建失败呢?

4

1 回答 1

1

如果你使用sqlcmd的 -b 参数,你应该会发现当批处理失败时它会抛出一个非零代码的错误(如果 tSQLt 至少有一个测试失败,就会发生这种情况)。

但是,我有一个潜在的建议要探索。如果您可以在 Cruise Control 中加载 XML 文件,则可以加载测试,因为 XML 文件的格式与 nUnit 测试输出文件的格式相同。(注意 - 我在TeamCity和 Jenkins 上使用过这种方法,但没有尝试使用 Cruise Control)。这会将测试视为测试,而不是“全有或全无”的方法,并使您能够跟踪哪些测试反复失败。

希望有帮助,

戴夫。

于 2012-12-07T07:23:21.683 回答