2012-09-20 18 views
6

TeamCity'i Powershell ile yapı günlüğündeki iletileri almak için nasıl alabilirim?Powershell iletilerini tanımak için TeamCity'i edinme

TeamCity 7.1 kullanıyorum. enter image description here

script:

write-host "##teamcity[message 'Getting production info']" 

if ($LASTEXITCODE -ne 0) { 
    write-host "##teamcity[message 'Production Remote Not Found: Creating Remote']" 

    write-host "##teamcity[message 'Pushing to Remote']" 
    #git push production 

} else { 
    write-host "##teamcity[message 'write-output: Production Remote Found: Pushing to Remote']" 
    #git push production 
} 

Ve inşa günlüğüne alıyorum tek şey:

[17:02:58]Skip checking for changes - changes are already collected 
[17:02:59]Publishing internal artifacts (1s) 
[17:03:00][Publishing internal artifacts] Sending build.start.properties.gz file 
[17:02:59]Clearing temporary directory: C:\BuildAgent2\temp\buildTmp 
[17:02:59]Checkout directory: C:\BuildAgent2\work\7669b6a04f96908d 
[17:02:59]Updating sources: agent side checkout 
[17:02:59][Updating sources] VCS Root: Portal Master 
[17:02:59][VCS Root: Portal Master] revision: c5c6a9a0d491ee2c64ce98e48b0d67c422237698 
[17:02:59][VCS Root: Portal Master] Resetting Portal Master in C:\BuildAgent2\work\7669b6a04f96908d to revision c5c6a9a0d491ee2c64ce98e48b0d67c422237698 
[17:02:59]Starting: C:\Windows\sysnative\cmd.exe /c C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe -NonInteractive -File C:\BuildAgent2\temp\buildTmp\powershell1349912883332714566.ps1 
[17:02:59]in directory: C:\BuildAgent2\work\7669b6a04f96908d 
[17:03:00] 
[17:03:00] 
[17:03:00] 
[17:03:00]Process exited with code 0 
[17:03:00]Publishing internal artifacts 
[17:03:00][Publishing internal artifacts] Sending build.finish.properties.gz file 
[17:03:00]Build finished 

cevap

14

açıklandığı üzere Burada

benim Powershell Yapı Adım olduğunu documentation "message" servis mesajında ​​birden fazla argüman bulunabilir, bu yüzden en azından 'text' argümanını belirtmeniz gerekir: "##teamcity[message text='Getting production info']"

Senaryonuz http://confluence.jetbrains.com/display/TCD8/Build ([docs] göre,

write-host "##teamcity[message text='Getting production info']" 

if ($LASTEXITCODE -ne 0) { 
    write-host "##teamcity[message text='Production Remote Not Found: Creating Remote']" 

    write-host "##teamcity[message text='Pushing to Remote']" 
    #git push production 

} else { 
    write-host "##teamcity[message text='write-output: Production Remote Found: Pushing to Remote']" 
    #git push production 
} 
+1

+1 @JoeYoung Sadece bununla birlikte, bu bir ile soktu olacak + Script + Etkileşim + + ile TeamCity # BuildScriptInteractionwithTeamCity-ServiceMessages) 'text' özelliğini açıkça tanımlamanız gerekmemelidir; Bu bir * tek öznitelik iletisi * olarak ele alınır ve çalışmalıdır. Ancak, 'metin' kullanmaz ve kullanmaz. – James

İlgili konular