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
Caricare un asset come parte di una release con un workflow di GitHub
Usare gateway dedicati con Azure Cosmos DB per migliorare le prestazioni
Taggare automaticamente un repository con un workflow di GitHub
Mostrare una preview durante l'upload di un'immagine in Blazor
Limitare lo spazio dei repository di Azure Container Registry con uno script bash e Azure CLI
Terminare l'esecuzione di un workflow di GitHub
Monitorare e prevenire problemi in produzione
Fare automaticamente il merge di una pull request con un workflow di GitHub
Condividere i workflow tra più repository in GitHub
Pubblicare un pacchetto di NuGet nel feed di GitHub
Bloccare una pull request che arriva da branch non definiti in GitHub
Raggruppare i parametri di una minimal API in un singolo oggetto in ASP.NET Core