L'uso delle pipeline di Azure DevOps (o GitHub) è molto comodo in qualsiasi scenario in cui vogliamo automatizzare dei processi. Internamente in azienda, per esempio, si potrebbe voler automatizzare la creazione dei progetti o di repository preconfigurati in Azure DevOps, anche a persone che non hanno l'accesso come organizational admin, semplicemente costruendo una interfaccia web che funzioni da proxy. Così facendo, una pipeline eseguirà in modo controllato e con tutti i permessi del caso tutte le operazioni di setup iniziale e l'utente richiedente non avrà alcuna visibilità, se non del progetto finale creato.
Per realizzare questo scenario, possiamo fare uso delle REST API di Azure DevOps, oppure, direttamente del client che viene fornito in diversi flavor (per .NET, JavaScript, etc.).
In prima istanza abbiamo bisogno di creare una connessione verso Azure DevOps. Per farlo è necessario munirci di un Personal Access Token (PAT) che verrà creato da Azure, all'interno del proprio profilo (per questo è consigliato fare un account di servizio).
private VssConnection _connection; public VssConnection Connection { get { if (_connection == null) { var pat = "{get-this-from-azure-devops}"; var creds = new VssBasicCredential(string.Empty, pat); _connection = new VssConnection(new Uri($"https://dev.azure.com/{organization}"), creds); } return _connection; } }
Ottenute le credenziali, possiamo quindi ottenere il client che si occupa di gestire le pipeline in Azure DevOps.
var buildClient = await Connection.GetClientAsync<BuildHttpClient>();
E, infine, possiamo recuperare la timeline di esecuzione della pipeline, dato il suo identificativo e il progetto in cui è contenuta (sia per le pipeline YAML che per quelle classiche):
var timeline = await buildClient.GetBuildTimelineAsync("{project}", id);
A questo punto abbiamo a disposizione tutta una serie di record che rappresentano tutti i passaggi della pipeline. Possiamo quindi farne delle query per, ad esempio, capire quali sono i job completati:
var completedJobs = timeline.Records .Where(x => x.RecordType == "Phase" && x.State == TimelineRecordState.Completed) .OrderBy(x => x.FinishTime);
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Evitare il flickering dei componenti nel prerender di Blazor 8
Evitare la command injection in un workflow di GitHub
Determinare lo stato di un pod in Kubernetes
Eseguire query manipolando liste di tipi semplici con Entity Framework Core
Verificare la provenienza di un commit tramite le GitHub Actions
Effettuare il deploy di immagini solo da container registry approvati in Kubernetes
Eseguire una query su SQL Azure tramite un workflow di GitHub
Esportare ed analizzare le issue di GitHub con la CLI e GraphQL
Generare token per autenicarsi sulle API di GitHub
Gestione degli environment per il deploy con un workflow di GitHub
Eseguire una GroupBy per entity in Entity Framework
I più letti di oggi
- Creare un messaggio di posta in diversi formati con ASP.NET 2.0
- Caricare un DTO esposto da un servizio tramite una query LINQ to Entities in Entity Framework
- Utilizzare il metodo reduce in #javascript https://aspit.co/ccc di @morwalpiz
- Elencare gli utenti di un dominio NT con ADSI
- Utilizzare SQL e #linq per eseguire una query con #entityframework Core https://aspit.co/bfv di @sm15455 #efcore1
- Disponibile il codice sorgente di ASP.NET MVC
- Concludiamo in bellezza con Giancarlo Sudano di Microsoft: q# for quantum programming Siamo in live streaming da: https://aspit.co/netconf-22 #aspilive #netconfit
- Caricare i dati di configurazione allo startup di un'applicazione Angular
- rilasciati nuovi template per la #aspnet web pages. funzionano anche con #webmatrix: http://u.aspitalia.com/lu
- Creare automaticamente una pipeline YAML da una sua definizione in Azure DevOps