2016-11-17 76 views
0

嗨,我其實是新的PowerShell。我正在嘗試執行ETL數據庫部署,因此在給定時間之後,我需要在tfs文件夾中包含所有文件。我建立了與TFS連接,但我能夠下載文件,但如果一個文件有兩個簽入我與以前籤獲取文件,而不是最新的使用powershell從tfs文件夾獲取最新的簽入文件

我的代碼:

$TfsUrl = "http://tfs2013-xxx02.ad.xxx.com:8080/tfs/abcd-xxx243" 

    # Load TFS assemblies for connecting to the TFS server 
    Add-Type -Path "E:\Microsoft Visual Studio 14.0\Common7\IDE\TestAgent\Microsoft.TeamFoundation.Client.dll" 
    Add-Type -Path "E:\Microsoft Visual Studio 14.0\Common7\IDE\TestAgent\Microsoft.TeamFoundation.Common.dll" 
    Add-Type -Path "E:\Microsoft Visual Studio 14.0\Common7\IDE\Extensions\4qvjm2or.ipa\Microsoft.TeamFoundation.Lab.Client.dll" 
    Add-Type -Path "E:\Microsoft Visual Studio 14.0\Common7\IDE\Extensions\4qvjm2or.ipa\Microsoft.TeamFoundation.Lab.Common.dll" 
    Add-Type -Path "E:\Microsoft Visual Studio 14.0\Common7\IDE\Extensions\4qvjm2or.ipa\Microsoft.TeamFoundation.VersionControl.Client.dll" 

    #Get TFS Instance 
    $Tfs = [Microsoft.TeamFoundation.Client.TfsTeamProjectCollectionFactory]::GetTeamProjectCollection($TfsUrl) 

    # use the account credentials of the process running the script 
    try 
    { 
     $Tfs.EnsureAuthenticated() 
     Write-Output "TFS Connection is successful" 
    } 
    catch 
    { 
     Write-Output "Error trying to connect to tfs server. Check your tfs permissions and path: $_ " 
     Exit(1) 
    } 

    #Write-Message $LogFileName "THIS IS INSIDE Connect-ToTFS" 
    #Write-Message $LogFileName "TFS IS $Tfs" 

$DeploymentFilePath= "$/xxxx/FutureReleases/Database/ReportingETLs" 

$TFSInstance = $Tfs.GetService([Microsoft.TeamFoundation.VersionControl.Client.VersionControlServer]) 
$LatestVersion = [Microsoft.TeamFoundation.VersionControl.Client.VersionSpec]::Latest 
$RecursionType = [Microsoft.TeamFoundation.VersionControl.Client.RecursionType]::Full 


$DateFrom = "D2016-10-08T01:59" 

# Get the From and To date-time in version format to be passed to TFS API 
$VersionFrom = $null 
$VersionFrom = [Microsoft.TeamFoundation.VersionControl.Client.VersionSpec]::ParseSingleSpec($DateFrom, "")  

$FileHistory = @($TFSInstance.QueryHistory($DeploymentFilePath,$LatestVersion,0,$RecursionType,$null,$null,$null,[int32]::MaxValue, $true ,$true, $true)) 

#Write-Output "Filehistory is: $FileHistory" 

#$ChangeSetCount = $FileHistory.Count 
#Write-Output "ChangeSetCount is: $ChangeSetCount" 


$TFSGetFullPath = "E:\temp\" 
$chArray = @() 
$checkin ="" 

foreach ($history in $FileHistory) 
{ 
    foreach ($change in $history.Changes) 
    { 
     foreach ($item in $change.item) 
     { 

      if($item.CheckinDate -gt $VersionFrom.Date) 
      { 
       $chArray += $history.ChangesetId 


      } 
     } 
    } 
} 

Write-Output "ChangesetArray is: $chArray" 
foreach ($ch in $chArray) 
{ 
    foreach ($lastdeployedHistory in $FileHistory)  
    {  
     if($lastdeployedHistory.ChangesetId -eq $ch) 
     { 
      foreach ($workitem in $lastdeployedHistory.Changes) 
      { 
       $workitem.Item.DownloadFile([IO.Path]::GetFullPath($TFSGetFullPath) + $workitem.Item.ServerItem.Split('/')[$workitem.Item.ServerItem.Split('/').Length - 1]); 
      } 
     }                             
    } 
} 

回答

0

這是由$ chArray中的對象順序引起的。 $ chArray中的變更集從新到舊排序。當你下載文件時,它首先下載新文件,然後下載舊文件。

例如,一個文件有兩個變更集:111和112,腳本中的代碼Write-Output "ChangesetArray is: $chArray",您應該看到如下輸出:ChangesetArray is: 112 111。下載文件時,首先下載112版本的文件,然後下載111版本覆蓋最新版本。

可以在$沙爾賴數組排序來解決這個問題:

Write-Output "ChangesetArray is: $chArray" 

$sortcsarray = $chArray | Sort-Object 

Write-Output "ChangesetArray is: $sortcsarray" 

foreach ($ch in $sortcsarray) 
+0

嗨@avk,你有沒有解決這個問題? –

相關問題