Procedendo sulla scia di quanto mostrato nello script precedente in riferimento ai logging commands di Azure DevOps, ovvero i comandi speciali che possiamo impartire all'agent che esegue le pipeline per creare un logging avanzato, vediamo oggi la possibilità di mostrare il progresso di un task che richiede un lungo lasso di tempo per essere completati.
Esattamente come avviene, ad esempio, negli installer di qualche applicazione, possiamo mostrare una percentuale di avanzamento/completamento all'interno dei log della pipeline.
Write-Host "Processo molto lungo che deve essere eseguito..." $i=0 While ($i -le 100) { Start-Sleep 1 Write-Host "##vso[task.setprogress value=$i;]Progresso..." $i += 10 } Write-Host "Processo completato."
Nell'esempio possiamo notare come abbiamo simulato l'esecuzione di un lungo processo semplicemente tramite un ciclo while e un timer di un secondo che forza la pausa del processo. L'idea è quella di mostrare un avanzamento del 10% ad ogni giro del ciclo, così da far capire a chi guarda i log della pipeline a che punto si trova l'esecuzione del task stesso. Per fare questo, è stato aggiunto il Write-Host con la property task.setprogress che prende un valore intero indicante la percentuale di completamento.
Questo valore non viene in realtà stampato direttamente nei log, come si potrebbe pensare. Al contrario, questo valore sostituirà il tempo di esecuzione mostrato a fianco del nome del task, solamente per il fragente di tempo per il quale il processo è in corso.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Utilizzare QuickGrid di Blazor con Entity Framework
Eseguire query manipolando liste di tipi semplici con Entity Framework Core
Registrare servizi multipli tramite chiavi in ASP.NET Core 8
Referenziare un @layer più alto in CSS
Generare token per autenicarsi sulle API di GitHub
Code scanning e advanced security con Azure DevOps
Eseguire le GitHub Actions offline
Evitare (o ridurre) il repo-jacking sulle GitHub Actions
Ordine e importanza per @layer in CSS
Creare un'applicazione React e configurare Tailwind CSS
Utilizzare un service principal per accedere a Azure Container Registry
I più letti di oggi
- Effettuare il log delle chiamate a function di GPT in ASP.NET Web API
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Utilizzare il metodo CountBy di LINQ per semplificare raggruppamenti e i conteggi
- Creare una libreria CSS universale: Cards
- Eseguire script pre e post esecuzione di un workflow di GitHub