Skip to main content
Nous publions des mises à jour fréquentes de notre documentation, et la traduction de cette page peut encore être en cours. Pour obtenir les informations les plus actuelles, consultez la documentation anglaise.

Extraction de demandes de tirage localement

Quand une personne vous envoie une demande de tirage (pull request) à partir d’une duplication (fork) ou d’une branche de votre dépôt, vous pouvez la fusionner localement pour résoudre un conflit de fusion ou pour tester et vérifier les modifications avant d’effectuer une fusion sur GitHub.

Qui peut utiliser cette fonctionnalité

Anyone with write access to a repository can pull a remote pull request down locally.

Remarque : Les auteurs de demandes de tirage peuvent donner aux responsables de référentiel en amont, ou ceux disposant d’un accès push au référentiel en amont, l’autorisation d’effectuer des validations sur la branche de comparaison de leur demande de tirage dans une duplication appartenant à l’utilisateur. Pour plus d’informations, consultez « Autorisation de changements sur une branche de demande de tirage créée à partir d’une duplication ».

Modification d’une demande de tirage active localement

  1. Sous le nom de votre dépôt, cliquez sur Demandes de tirage. Sélection de l’onglet Problèmes et demandes de tirages

  2. Dans la liste des demandes de tirage, cliquez sur la demande de tirage que vous souhaitez modifier.

  3. Pour choisir où ouvrir la demande de tirage, sélectionnez la liste déroulante Code et cliquez sur un des onglets.

    Capture d’écran du titre d’une demande de tirage. Un bouton avec une flèche indiquant un menu déroulant, intitulé « Code », est indiqué en orange foncé.

Pour plus d’informations sur GitHub CLI, consultez « À propos de GitHub CLI ».

Pour extraire une demande de tirage localement, utilisez la sous-commande gh pr checkout. Remplacez pull-request par le nombre, l’URL ou la branche de tête de la demande de tirage.

gh pr checkout PULL-REQUEST

Modification d’une demande de tirage inactive localement

Si l’auteur d’une requête de tirage ne répond pas aux requêtes ou a supprimé sa duplication, la demande de tirage peut toujours être fusionnée. Toutefois, si vous souhaitez apporter des modifications à une demande de tirage et que l’auteur ne répond pas, vous devez effectuer certaines étapes supplémentaires pour mettre à jour la demande de tirage.

Une fois qu’une demande de tirage est ouverte, GitHub stocke toutes les modifications à distance. En d’autres termes, les validations dans une demande de tirage sont disponibles dans un référentiel même avant la fusion de la demande de tirage. Vous pouvez extraire une demande de tirage ouverte et la recréer en tant que la vôtre.

N’importe qui peut utiliser une demande de tirage ouverte précédemment pour continuer à travailler dessus, la tester ou même ouvrir une nouvelle demande de tirage avec des modifications supplémentaires. Toutefois, seuls les collaborateurs disposant d’un accès push peuvent fusionner les demandes de tirage.

  1. Sous le nom de votre référentiel, cliquez sur Problèmes ou sur Demandes de tirage.

    Capture d’écran de la page principale d’un dépôt. Dans la barre de navigation horizontale, deux onglets, intitulés « Problèmes » et « Demandes de tirage », sont indiqués en orange foncé.

  2. Dans la liste « Demandes de tirage », cliquez sur la demande de tirage que vous souhaitez fusionner.

  3. Recherchez le numéro d’ID de la demande de tirage inactive. Il s’agit de la séquence de chiffres juste après le titre de la demande de tirage.

    Capture d’écran du titre d’une demande de tirage. Le numéro d’identification de la demande de tirage est indiqué en orange foncé.

  4. Ouvrez TerminalTerminalGit Bash.

  5. Récupérez la référence à la demande de tirage en fonction de son numéro d’ID, en créant une nouvelle branche au passage.

    $ git fetch origin pull/ID/head:BRANCH_NAME
  6. Basculez vers la nouvelle branche basée sur cette demande de tirage :

    [main] $ git checkout BRANCH_NAME
    > Switched to a new branch 'BRANCH_NAME'
  7. À ce stade, vous pouvez faire tout ce que vous voulez avec cette branche. Vous pouvez exécuter des tests locaux ou fusionner d’autres branches dans la branche.

  8. Lorsque vous êtes prêt, vous pouvez envoyer la nouvelle branche :

    [pull-inactive-pull-request] $ git push origin BRANCH_NAME
    > Counting objects: 32, done.
    > Delta compression using up to 8 threads.
    > Compressing objects: 100% (26/26), done.
    > Writing objects: 100% (29/29), 74.94 KiB | 0 bytes/s, done.
    > Total 29 (delta 8), reused 0 (delta 0)
    > To https://github.com/USERNAME/REPOSITORY.git
    >  * [new branch]      BRANCH_NAME -> BRANCH_NAME
  9. Créez une demande de tirage avec votre nouvelle branche.

Erreur : Échec de l’envoi de certaines références

L’espace de noms distant refs/pull/ est en lecture seule. Si vous essayez d’envoyer des validations là-bas, vous verrez cette erreur :

! [remote rejected] HEAD -> refs/pull/1/head (deny updating a hidden ref)
error: failed to push some refs to 'git@github.local:USERNAME/REPOSITORY.git'

Conseil : Lorsque vous supprimez ou renommez une référence distante, votre espace de noms refs/pull/origin/ local n’est pas affecté par les appels à git-remote.