我正在尝试使用Powershell脚本自动执行分支操作,如下所示:
$fromUrl = 'svn://some/from/url'
$toUrl = 'svn://some/to/url.'
[Array]$arguments = "copy", "-q", $fromUrl, $toUrl, "-m", "New branch"
echo "Branching from: " $fromUrl
echo "Branching to: " $toUrl
$copyResult = & svn $arguments
echo "Result: " $copyResult
echo "Switching to: " $toUrl
$switchResult = svn switch -q $toUrl ho-til-test
echo "Result: " $switchResult
Run Code Online (Sandbox Code Playgroud)
只要对SVN的调用有效,这应该可以正常工作; 然而,我想要的是捕获结果,并在调用失败时使用错误消息停止脚本.上面的脚本显然因为无效的URL而失败,但是结果没有被捕获,$copyResult
并且$switchResult
正如我所期望的那样.结果输出如下; 状态消息显示在我的两个结果变量的输出之前,它们是空的:
PS > .\PsExampleForSO.ps1
Branching from:
svn://some/from/url
Branching to:
svn://some/to/url.
svn: E731001: Unable to connect to a repository at URL 'svn://some/from/url'
svn: E731001: Unknown hostname 'some'
Result:
Switching to:
svn://some/to/url.
svn: E731001: Unable to connect to a repository at URL 'svn://some/to/url.'
svn: E731001: Unknown hostname 'some'
Result:
PS >
Run Code Online (Sandbox Code Playgroud)
这与我正在进行的其他几个调用不同,输出结果可以在变量中捕获并稍后检查.
这两个电话有没有办法实现这个目的?
外部命令的退出代码存储在$LastExitCode
环境变量中.如果您希望脚本在发生错误时停止,您应该检查该变量:
$copyResult = & svn $arguments
if ($LastExitCode -ne 0) {
exit
}
Run Code Online (Sandbox Code Playgroud)
我建议在日志文件而不是变量中捕获常规和错误输出,但是:
& svn $arguments >'C:\path\to\output.log' 2>'C:\path\to\error.log'
if ($LastExitCode -ne 0) {
exit
}
Run Code Online (Sandbox Code Playgroud)