2026/1/20 21:52:36
网站建设
项目流程
手机分销网站建设,房屋设计装修app,苏州市建设厅网站首页,阿里云访问wordpress目标
使用 branch_a 分支的完整代码内容覆盖 branch_b 分支#xff0c;并通过 Gerrit 代码评审系统提交。
问题描述
在执行 git reset --hard 将本地历史替换为 branch_a 后#xff0c;尝试推送到 Gerrit 时#xff0c;遇到以下错误#xff1a;
! [remote rejected] branch…目标使用branch_a分支的完整代码内容覆盖branch_b分支并通过Gerrit 代码评审系统提交。问题描述在执行git reset --hard将本地历史替换为branch_a后尝试推送到 Gerrit 时遇到以下错误! [remote rejected] branch_b - refs/for/branch_b (no new changes)根本原因Gerrit 通过Change-Id:跟踪变更。直接重置后本地提交的 ID 或Change-Id与远程分支上已存在或已被拒绝的变更重叠Gerrit 误认为没有“新的”变更因此拒绝。解决方案强制生成新的 Change-Id为了让 Gerrit 接受替换操作必须基于远程branch_b的最新提交创建一个全新的、唯一的提交来封装替换内容。操作步骤步骤 1: 准备内容 (Content Preparation)先重置回远程分支再将目标内容检出到工作区。# 1. 切换到目标分支 git checkout branch_b # 2. 将本地分支重置回远程 branch_b 的最新提交基于它的历史 git reset --hard origin/branch_b # 3. 检出 branch_a 的所有文件内容到工作区/暂存区替换内容 git checkout origin/branch_a -- .步骤 2: 修改提交 (Amend Commit)使用git commit --amend将所有替换内容打包进branch_b的最新提交并强制生成新的Change-Id。# 4. 确保所有差异文件已暂存 git add . # 5. 修改最新的提交 (Commit)并将替换后的内容打包进去 # 会打开文本编辑器 git commit --amend在打开的编辑器中修改提交信息(Commit Message)。关键操作找到Change-Id:所在行手动修改最后一位数字或字母如If12345改为If12346。步骤 3: 推送到 Gerrit新的提交包含替换内容和新Change-Id会被 Gerrit 接受为一个新的评审。# 6. 将新的提交推送到 Gerrit git push origin HEAD:refs/for/branch_b成功推送后请联系管理员在 Gerrit 界面上进行评审和提交Submit。