我正在尝试将已经存在的git存储库导入到gerrit中,其中包含多个分支和标记.我正在关注https://gerrit-review.googlesource.com/Documentation/install-quick.html#_already_existing_project上的官方指南.
但是,当发出push命令时,除了我当前所在的"master"之外的所有分支和标签都是"Gerrit禁止的".输出是这样的:
user@host:~/my-project$ git push ssh://user@localhost:29418/demo-project *:*
[....]
* [new branch] master -> master
! [remote rejected] origin/Branch1 -> origin/Branch1 (prohibited by Gerrit)
! [remote rejected] origin/Branch2 -> origin/Branch2 (prohibited by Gerrit)
[....]
! [remote rejected] Tag1 -> Tag1 (prohibited by Gerrit)
! [remote rejected] Tag2 -> Tag2 (prohibited by Gerrit)
[....]
Run Code Online (Sandbox Code Playgroud)
我是管理员,所以它不应该是访问权限问题.
更新: 通过使用blahdiblah的脚本(/sf/answers/1126697001/),我成功地移动了所有分支.为了能够传输所有标签,我首先必须使用gerrit web界面为组管理员提供*refs/tags/**的"创建参考"权限.之后,我可以使用git push --tags推送它们.
refs/*为了将现有存储库导入Gerrit而允许的最小权限集是我们的:
Create Reference (很明显)Forge Author Identity和Forge Committer Identity(因为你正在推动其他人的提交)Push (很明显)Push Merge Commit(这不包括在内Push,你可能会有合并提交)Push Annotated Tag (我们在某些标签中使用注释)Push Signed Tag显然,如果你有签名标签,你还需要允许.
最后,如果您计划在某个过渡期间多次运行导入以逐步同步存储库,则还需要允许Read并启用Force Push所有Push权限.
| 归档时间: |
|
| 查看次数: |
4137 次 |
| 最近记录: |