Quando ci troviamo a lavorare in un ambiente più o meno complesso, sicuramente vogliamo proteggere il codice sorgente, o meglio qualche branch principale come main/master, da commit non inattesi. Possiamo, infatti, impostare quelle che vengono chiamate branch policies o branch protection rules, per fare in modo che l'update di un determinato branch possa essere fatto solo ed esclusivamente tramite pull request, così che tutte le change possano essere validate manualmente (tramite un approval review) oppure automaticamente (grazie ad una o più GitHub Action che possono testare la build, il lint, eseguire i test e così via).
Spesso però accade che non è sufficiente un solo commit e quindi non sempre abbiamo bisogno che vengano eseguiti tutti i check ad ogni update della pull request stessa. Per fare in modo che questi sistemi non partano in automatico, è sufficiente aggiungere nel messaggio di commit una stringa tra [skip ci], [ci skip], [no ci], [skip actions], o [actions skip].

Come si può notare dall'immagine, il primo commit non includeva nessuna delle stringhe che escludevano i trigger, quindi la GitHub Action associata alla branch protection rule è partita automaticamente e ha validato il sistema (da notare il tick verde). Nel secondo update, invece, è stata aggiunta la magic string che fa in modo che non parta nessun check. In questo secondo caso è bene notare che, tuttavia, la pull request non può essere mergiata poichè non rispetta la branch protection rule e, quindi, questo sistema può essere utilizzato solamente per update intermedi di una pull request.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Configurare e gestire sidecar container in Azure App Service
Loggare le query più lente con Entity Framework
Autenticazione di git tramite Microsoft Entra ID in Azure DevOps
Rinnovare il token di una GitHub App durante l'esecuzione di un workflow
Effettuare il log delle chiamate a function di GPT in ASP.NET Web API
Gestire eccezioni nei plugin di Semantic Kernel in ASP.NET Core Web API
Recuperare automaticamente un utente e aggiungerlo ad un gruppo di Azure DevOps
Utilizzare la funzione EF.Parameter per forzare la parametrizzazione di una costante con Entity Framework
Configurare il nome della run di un workflow di GitHub in base al contesto di esecuzione
Recuperare l'ultima versione di una release di GitHub
Usare i settings di serializzazione/deserializzazione di System.Text.Json di ASP.NET all'interno di un'applicazione non web