Кажется, что моя локальная установка git
(версия 2.10.2) такова, что всякий раз, когда я git push
, она интерпретируется как git push -f
. Есть ли переменная конфигурации, которую я мог бы установить неправильно, чтобы вызвать такое поведение?
Больше фона
Недавно сервер, которым я пользуюсь, обновил свою установку GitLab (под управлением Community Edition 8.14.2 b9442a5eb0, к сожалению, у меня нет простого способа узнать, какой была предыдущая версия). Для каждого проекта, которым я владею (и у которого есть разрешение мастера), я получаю
[Tue Dec 06 02:21 PM] ArchDesktop $ git push
Counting objects: 4, done.
Delta compression using up to 8 threads.
Compressing objects: 100% (4/4), done.
Writing objects: 100% (4/4), 765 bytes | 0 bytes/s, done.
Total 4 (delta 3), reused 0 (delta 0)
remote: GitLab: You are not allowed to force push code to a protected branch on this project.
To REDACTED
! [remote rejected] master -> master (pre-receive hook declined)
error: failed to push some refs to 'REDACTED'
Я предполагаю, что это связано с внедрением "защищенных веток" в более поздних версиях GitLab. Теперь я должен иметь возможность продвигать вещи, так как у меня есть доступ Мастера к моим собственным проектам. Кроме того, если бы это были просто проблемы с разрешениями, сообщение об ошибке, я понимаю, должно быть
remote: GitLab: You are not allowed to force push code to a protected branch
без упоминания о силовом толкании. Таким образом, вопрос на самом деле таков: почему Git пытается принудительно заставить мои коммиты, когда я этого не говорил?
Еще больше фона
Давным-давно я прочитал о том, как работает Git, и действительно понял это. Тогда я начал использовать это и в значительной степени забыл. Поэтому вполне возможно, что я делаю что-то совершенно неправильно и не понимаю этого. Я даже не уверен, как диагностировать эту проблему. Так что любые комментарии о том, что мне нужно включить в этот вопрос или какие очевидные вещи я должен проверить, приветствуются!
Дополнительная информация
По запросу: git config --list
выдает только (в дополнение к моему имени, email и URL репо)
user.name=*******
user.email=******
push.default=simple
core.repositoryformatversion=0
core.filemode=true
core.bare=false
core.logallrefupdates=true
remote.origin.url=**************
remote.origin.fetch=+refs/heads/*:refs/remotes/origin/*
branch.master.remote=origin
branch.master.merge=refs/heads/master
Слегка отредактированный вывод GIT_TRACE=1 git push
:
09:13:50.859273 git.c:349 trace: built-in: git 'push'
09:13:50.859524 run-command.c:336 trace: run_command: 'ssh' 'git@gitlab.REDACTED' 'git-receive-pack '\''REDACTED.git'\'''
09:13:54.097551 run-command.c:336 trace: run_command: 'pack-objects' '--all-progress-implied' '--revs' '--stdout' '--thin' '--delta-base-offset' '--progress'
09:13:54.098218 exec_cmd.c:120 trace: exec: 'git' 'pack-objects' '--all-progress-implied' '--revs' '--stdout' '--thin' '--delta-base-offset' '--progress'
09:13:54.100884 git.c:349 trace: built-in: git 'pack-objects' '--all-progress-implied' '--revs' '--stdout' '--thin' '--delta-base-offset' '--progress'
Counting objects: 4, done.
Delta compression using up to 8 threads.
Compressing objects: 100% (4/4), done.
Writing objects: 100% (4/4), 389 bytes | 0 bytes/s, done.
Total 4 (delta 3), reused 0 (delta 0)
remote: GitLab: You are not allowed to force push code to a protected branch on this project.
To REDACTED
! [remote rejected] master -> master (pre-receive hook declined)
error: failed to push some refs to 'REDACTED'