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
-
Sous le nom du référentiel, cliquez sur Demandes de tirage.
-
Dans la liste des demandes de tirage, cliquez sur la demande de tirage que vous souhaitez modifier.
-
Dans la zone de fusion, cliquez sur les instructions de ligne de commande. Suivez la séquence d’étapes pour afficher la demande de tirage proposée.
-
Si vous le souhaitez, pour afficher les modifications proposées dans GitHub Desktop, à côté du bouton Fusionner la demande de tirage, cliquez sur Ouvrir dans GitHub Desktop .
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 demande de tirage ne répond pas aux demandes ou a supprimé leur duplication, les modifications proposées dans cette demande de tirage peuvent toujours être fusionnées via une nouvelle demande de tirage. 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 Enterprise Server 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.
-
Sous le nom de votre référentiel, cliquez sur Problèmes ou sur Demandes de tirage.
-
Dans la liste « Demandes de tirage », cliquez sur la demande de tirage que vous souhaitez fusionner.
-
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.
-
Ouvrez TerminalTerminalGit Bash.
-
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
-
Basculez vers la nouvelle branche basée sur cette demande de tirage :
[main] $ git switch BRANCH_NAME > Switched to a new branch 'BRANCH_NAME'
-
À 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.
-
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://HOSTNAME/USERNAME/REPOSITORY.git > * [new branch] BRANCH_NAME -> BRANCH_NAME
-
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
.