Quando si inizia ad avere un sistema piuttosto complesso da dover manutenere in produzione, è bene assicurarsi che ci sia una buona tracciabilità di tutte le modifiche che vengono applicate ad esso.
La prima accortenzza la possiamo applicare fin dal momento iniziale di sviluppo: si possono, infatti, collegare i git commit a specifici work item all'interno del backlog di Azure Boards semplicemente aggiungendo "#{id}" al messaggio di commit, dove {id} rappresenta il numero identificativo del work item. Se apriamo il work item nella board a commit (e push) effettuato, noteremo come si sarà aggiornato collegandosi ad un branch e ad un commit specifico.
Allo stesso modo, ogni pipeline (che sia Build o Release management), è associata ad un certo numero di commit e, di conseguenza, può essere agganciata a determinati work item. Tuttavia, questa volta il collegamento è automatico a livello di UI, ma se abbiamo bisogno di recuperare questi stessi work item automaticamente, dobbiamo ricorrere, come abbiamo già visto, alle REST API.
$uri = "https://dev.azure.com/$(Organization)/$(Project)/_apis/build/builds/$env:BUILD_BUILDID/workitems?api-version=5.0" $workItems = Invoke-RestMethod $uri -Method GET -Headers @{Authorization=("Bearer {0}" -f $env:SYSTEM_ACCESSTOKEN)}
Questa prima chiamata HTTP ci restituirà l'elenco dei work item collegati alla build corrente, identificata dalla variabile d'ambiente Build.BuildId. A questo punto sappiamo già tutti gli ID dei work item, ma non avremo i loro dettagli. Per recuperare tutte le informazioni necessarie come, ad esempio, il titolo, dobbiamo effettuare una nuova chiamata all'endpoint dedicato ai work items:
$ids = [string]::Join(',', $workItems.value.id) $uri = "https://dev.azure.com/$(Organization)/$(Project)/_apis/wit/workitems?ids=$ids&api-version=5.0" $workItems = Invoke-RestMethod $uri -Method GET -Headers @{Authorization=("Bearer {0}" -f $env:SYSTEM_ACCESSTOKEN)} # Print work items in the output window Write-Host "Found $($result.count) associated to the current build:" foreach ($item in $result.value) { Write-Host "#$($item.id) - $($item.fields.'System.Title')" }
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Triggerare una pipeline su un altro repository di Azure DevOps
Rinnovare il token di una GitHub App durante l'esecuzione di un workflow
Managed deployment strategy in Azure DevOps
Utilizzare l nesting nativo dei CSS
Abilitare automaticamente il force push di un gruppo su Azure DevOps
Eliminare una project wiki di Azure DevOps
Creare agenti facilmente con Azure AI Agent Service
Gestire i dati con Azure Cosmos DB Data Explorer
Recuperare l'ultima versione di una release di GitHub
Rendere le variabili read-only in una pipeline di Azure DevOps
Utilizzare Hybrid Cache in .NET 9
Autenticazione di git tramite Microsoft Entra ID in Azure DevOps
I più letti di oggi
- Novità nella gestione del modello asincrono in C# 5 e VB 11
- Eseguire query con LINQ to SQL
- Conoscere il rendering Server o WebAssembly a runtime in Blazor
- Gestione file Javascript in Blazor con .NET 9
- Migliorare la velocità delle connessioni ai database
- #vs2017 sarà rilasciato il 07/03, in concomitanza con i suoi 20 anni https://aspit.co/bfn
- #VS2017 Community è già disponibile al download da questa pagina https://aspit.co/bgb
- #VS2017 non ha un'ISO, ma è possibile creare un installer offline seguendo la guida ufficiale: https://aspit.co/bgd
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!