我尝试通过编写以下内容来获取具有PowerShell和TCM的特定TestPlan的所有TestSuite的列表.exe:
$listOfSuites = & "C:Program Files (x86)Microsoft Visual Studio 12.0Common7IDETCM.exe" suites /list /planid:1234
我得到了正确的结果,但它被格式化为单个字符串,如下所示:
Id Name --------- ---------------------------------------------------------------- 1235 Test Project 1236 Test Project -> Manual Tests -> First TestSuite 1237 Test Project -> Manual Tests -> Second TestSuite
是否可以以列表或表格的形式获取结果,以便我可以遍历这些套件?
问候Johannes
如果执行外部程序,则始终会得到一个字符串。为了接收字符串表,您首先调用
$listOfSuites.split("`r`n")
要获取字符串数组,则需要通过填充行的字符串中这些字符串的偏移量来解析这些字符串(在您的情况下,0 到 9 是"id",11 到 end 是"Name")。示例(取自此脚本):
$starters = New-Object psobject -Property @{"SessionName" = 0; "Username" = 0;
"ID" = 0; "State" = 0; "Type" = 0; "Device" = 0;};
foreach($line in $c) {
if($line.trim().substring(0, $line.trim().indexof(" ")) -eq "SESSIONNAME") {
$starters.Username = $line.indexof("USERNAME");
$starters.ID = $line.indexof("ID");
$starters.State = $line.indexof("STATE");
$starters.Type = $line.indexof("TYPE");
$starters.Device = $line.indexof("DEVICE");
continue;
}
New-Object psobject -Property @{
"SessionName" = $line.trim().substring(0, $line.trim().indexof(" ")).trim(">")
;"Username" = $line.Substring($starters.Username, $line.IndexOf(" ", $starters.Username) - $starters.Username)
;"ID" = $line.Substring($line.IndexOf(" ", $starters.Username), $starters.ID - $line.IndexOf(" ", $starters.Username) + 2).trim()
;"State" = $line.Substring($starters.State, $line.IndexOf(" ", $starters.State)-$starters.State).trim()
;"Type" = $line.Substring($starters.Type, $starters.Device - $starters.Type).trim()
;"Device" = $line.Substring($starters.Device).trim()
}
$c
是外部命令的结果,该命令没有带短划线的行,并且标题格式如下:
SESSIONNAME USERNAME ID STATE TYPE DEVICE
完成后,您可以将每个字符串转换为New-Object PSObject -property @{"Id"=$parsedid;"Name"=$parsedname}
,并为自己获取要使用的定制对象列表。该技术在同一示例中进行了演示。