如何从Powershell检查调用SVN的结果

Kja*_*tan 3 svn powershell

我正在尝试使用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)

这与我正在进行的其他几个调用不同,输出结果可以在变量中捕获并稍后检查.

这两个电话有没有办法实现这个目的?

Ans*_*ers 7

外部命令的退出代码存储在$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)