我正在Jenkins中测试一个简单的构建过程; “构建”部分具有“执行Windows批处理命令”
echo %ERRORLEVEL%
cscript C:\Users\user\Documents\test.vbs
echo %ERRORLEVEL%
我的test.vbs除了设置ERRORLEVEL
环境变量外什么都不做;我还尝试使用wscript.quit
查看是否对ERRORLEVEL
dim wShell
dim wSysEnv
set wShell = Wscript.CreateObject("WScript.Shell")
set wSysEnv = wShell.Environment("SYSTEM")
WScript.Echo "ERRORLEVEL=" & wSysEnv( "ERRORLEVEL" )
wSysEnv( "ERRORLEVEL" ) = 0
WScript.Echo "ERRORLEVEL=" & wSysEnv( "ERRORLEVEL" )
wSysEnv( "ERRORLEVEL" ) = 2
WScript.Echo "ERRORLEVEL=" & wSysEnv( "ERRORLEVEL" )
WScript.Quit 3
没有帖子构建操作 控制台输出如下:
Started by user anonymous
Building in workspace C:\Program Files (x86)\Jenkins\jobs\TADS Host-Agent client\workspace
[workspace] $ cmd /c call C:\Users\user\AppData\Local\Temp\hudson4571524647235360597.bat
C:\Program Files (x86)\Jenkins\jobs\TADS Host-Agent client\workspace>echo 1
1
C:\Program Files (x86)\Jenkins\jobs\TADS Host-Agent client\workspace>cscript C:\Users\user\Documents\test.vbs
Microsoft (R) Windows Script Host Version 5.8
Copyright (C) Microsoft Corporation. All rights reserved.
ERRORLEVEL=0
ERRORLEVEL=0
ERRORLEVEL=2
C:\Program Files (x86)\Jenkins\jobs\TADS Host-Agent client\workspace>echo 1
1
C:\Program Files (x86)\Jenkins\jobs\TADS Host-Agent client\workspace>exit 1
Build step 'Execute Windows batch command' marked build as failure
Finished: FAILURE
如上面的输出所示,启动脚本之前的ERRORLEVEL
为1。
该脚本成功将ERRORLEVEL
设置为2并以代码3退出。但是,当我检查脚本末尾的ERRORLEVEL
时,它会在启动时返回到1。
我发现一些页面表示环境变量只是为当前进程和任何子进程设置的;那就是会话环境变量。
在哪种情况下,如何设置ERRORLEVEL
以使Jenkins将测试报告为成功或失败?它似乎不会在运行时检查变量,只是在脚本执行开始时。这没有用,因为脚本可能会更改变量的值。
答案 0 :(得分:1)
%ERRORLEVEL%
是一个自动变量,你不应该直接篡改它,甚至更多,因为对SYSTEM
环境的写访问需要管理员权限。
%ERRORLEVEL%
应该由传递给Quit
方法的整数值自动填充。带有行WScript.Quit 3
的VBScript,由批处理脚本调用,如下所示:
@echo off
echo %ERRORLEVEL%
cscript //NoLogo C:\path\to\your.vbs
echo %ERRORLEVEL%
应该产生以下输出:
C:\>C:\path\to\your.cmd
0
3