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
Utilizzare Container Queries nominali
Utilizzare il metodo CountBy di LINQ per semplificare raggruppamenti e i conteggi
Creare una libreria CSS universale - Rotazione degli elementi
Rendere i propri workflow e le GitHub Action utilizzate più sicure
Rinnovare il token di una GitHub App durante l'esecuzione di un workflow
Garantire la provenienza e l'integrità degli artefatti prodotti su GitHub
Esporre i propri servizi applicativi con Semantic Kernel e ASP.NET Web API
Utilizzare la funzione EF.Parameter per forzare la parametrizzazione di una costante con Entity Framework
Utilizzare Azure Cosmos DB con i vettori
Introduzione ai web component HTML
Bloccare l'esecuzione di un pod in mancanza di un'artifact attestation di GitHub
Managed deployment strategy in Azure DevOps
I più letti di oggi
- Eseguire query in contemporanea con EF
- Fissare una versione dell'agent nelle pipeline di Azure DevOps
- .NET Aspire per applicazioni distribuite
- Utilizzare Locust con Azure Load Testing
- Autenticazione di git tramite Microsoft Entra ID in Azure DevOps
- Repaint, Reflow e Compositing: Come Funziona il Rendering nel Browser
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!