Note
Les exécuteurs hébergés sur GitHub ne sont pas pris en charge sur GitHub Enterprise Server. Vous pouvez voir plus d’informations sur le support futur planifié dans la GitHub public roadmap.
Vue d’ensemble
Note
Un travail ignoré signale son état comme « Réussite ». Il n’empêche pas une demande de tirage (pull request) de fusionner, même s’il s’agit d’une vérification requise.
Vous pouvez utiliser le jobs.<job_id>.if
conditionnel pour empêcher l’exécution d’un travail, sauf si une condition est remplie. Vous pouvez utiliser n’importe quel contexte et n’importe quelle expression pris en charge pour créer un conditionnel. Pour plus d’informations sur les contextes pris en charge dans cette clé, consultez Accès à des informations contextuelles sur l’exécution d’un workflow.
Note
La condition jobs.<job_id>.if
est évaluée avant que jobs.<job_id>.strategy.matrix
soit appliqué.
Quand vous utilisez des expressions dans un conditionnel if
, vous pouvez omettre la syntaxe de l’expression ${{ }}
parce que GitHub Actions évalue automatiquement le conditionnel if
en tant qu’expression. Toutefois, cette exception ne s’applique pas partout.
Vous devez utiliser la syntaxe d’expression ${{ }}
ou l’échappement avec ''
, ""
ou ()
lorsque l’expression commence par !
, car !
est une notation réservée au format YAML. Par exemple :
if: ${{ ! startsWith(github.ref, 'refs/tags/') }}
Pour plus d’informations, consultez « Évaluer les expressions dans les workflows et les actions ».
Exemple : Exécuter un travail uniquement pour un dépôt spécifique
Cet exemple utilise if
pour contrôler le moment où le travail production-deploy
peut s’exécuter. Il s’exécute uniquement si le dépôt se nomme octo-repo-prod
, et s’il se trouve dans l’organisation octo-org
. Sinon, le travail est marqué comme étant ignoré.
name: example-workflow on: [push] jobs: production-deploy: if: github.repository == 'octo-org/octo-repo-prod' runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - uses: actions/setup-node@v4 with: node-version: '14' - run: npm install -g bats
name: example-workflow
on: [push]
jobs:
production-deploy:
if: github.repository == 'octo-org/octo-repo-prod'
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: '14'
- run: npm install -g bats
Dans le cas d'un travail ignoré, le message « This check was skipped » (cette vérification a été ignorée) devrait apparaître.
Note
Dans certaines parties du workflow, vous ne pouvez pas utiliser de variables d’environnement. Au lieu de cela, vous pouvez utiliser des contextes pour accéder à la valeur d’une variable d’environnement. Pour plus d’informations, consultez « Stocker des informations dans des variables ».