Quando si lavora in progetti molto complessi, è probabile che per mantenere i costi non ci siano sufficienti runner/agent assegnati per garantire che tutte le policy (ad esempio le pipeline/workflow per compilare il nostro codice). Questo implica che i workflow potrebbero essere eseguiti anche dopo ore, un tempo non sufficientemente comodo per gli sviluppatori che, spesso, vogliono un feedback molto velocemente.
Sebbene lo script seguente non aiuti in questo senso, proprio perchè l'unica soluzione sarebbe quella di acquistare più runner per avviare più workflow in parallelo, l'idea è che, perlomeno, avvisiamo l'utente che abbiamo ricevuto la sua pull request e che tutte le policy verranno valutate quanto prima.
name: Thanks on: pull_request: types: [opened, reopened] jobs: submit-comment: runs-on: ubuntu-latest steps: - name: 'Comment on PR' uses: actions/github-script@v6 with: github-token: ${{ secrets.GITHUB_TOKEN }} script: | await github.rest.issues.createComment({ owner: context.repo.owner, repo: context.repo.repo, issue_number: context.issue.number, body: 'Grazie per aver creato una PR! Processeremo le policy il prima possibile' });
L'esempio qui sopra, infatti, non è nient'altro che un altro workflow che verrà messo in esecuzione, sicuramente però più breve di quelli che compileranno l'applicazione o che dovranno effettuare check di compliance complessi (esempio esecuzione di static code analysis, sicurezza di componenti di terze parti etc.). Quando una pull request verrà aperta, infatti, il workflow verrà messo in esecuzione immediatamente (a seconda della disponibilità dei runner) e verrà mandato un messaggio sulla issue corrispondente alla pull request avvisando che stiamo processando la richiesta.
Di nuovo, non stiamo evitando il problema che c'è alla radice ma, se non altro, stiamo provvedendo a dare un feedback adeguato agli utenti che rimanrranno in attesa.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Evitare (o ridurre) il repo-jacking sulle GitHub Actions
Evitare la script injection nelle GitHub Actions
Load test di ASP.NET Core con k6
Utilizzare il trigger SQL con le Azure Function
Gestire la cancellazione di una richiesta in streaming da Blazor
Come EF 8 ha ottimizzato le query che usano il metodo Contains
Le novità di Angular: i miglioramenti alla CLI
Eseguire query manipolando le liste contenute in un oggetto mappato verso una colonna JSON
Gestire liste di tipi semplici con Entity Framework Core
Autenticarsi in modo sicuro su Azure tramite GitHub Actions
Registrare servizi multipli tramite chiavi in ASP.NET Core 8