- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们正在考虑将 Gerrit 用于大型项目。此时,了解人们如何处理已批准变更的合并冲突将会很有趣。
想象一下,许多不同规模的变更正在同时等待修订,并且正在逐步审查和验证。由于其中一些人可能会修改同一段代码,因此冲突是不可避免的。如果“集成商”在简单的工作流程中手动接受补丁,这不是问题,小冲突可以在途中解决,但使用 Gerrit 情况就不同了。当更改经过审核和批准后,如果发生合并冲突,据我了解,作者需要重新调整基础并再次插入修订,在这种情况下,修订过程将再次开始。在相对活跃的项目中,每周有超过 50 个外部贡献者提交,如果在每次批准和提交后由于合并拒绝而需要多次修改同一补丁,这可能会变成噩梦,这似乎是效率不高。
问题:
对于预计会出现大量合并冲突的大型事件,Gerrit 并不是一种前进的方式,我这样说对吗?
一些合并冲突可能是微不足道的,有没有办法解决它们而不需要麻烦作者重新提交更改?
如果需要将更改向后移植到稳定分支,我猜想每个分支的单独更改都需要推送进行修订,即使 cherry-pick 是干净的。
<也欢迎对您的 Gerrit 工作流程体验提出一般性评论。
最佳答案
Gerrit 被一些非常庞大的项目使用,例如 Android 和相关的 bsp、内核等存储库。这些项目每周获得超过 50 次外部提交。我认为高通将在大约这段时间内进行数千次提交。
Gerrit 中有一个设置可以自动合并琐碎的冲突。这可以针对每个存储库进行设置。如果设置此选项,则在更改经过审核和验证并且用户按下“提交”按钮后,将根据您的提交策略合并更改(择优选择,必要时合并)。我能找到的最好的文档在这里 http://gerrit-documentation.googlecode.com/svn/Documentation/2.3/cmd-create-project.html#_options在 --use-content-merge 选项下。
是的,这就是我们通常做事的方式。还有其他选项(绕过审查、合并分支等),但挑选所需的分支并进行审查效果很好。
关于Gerrit 修订工作流程 : merge conflicts and re-approval,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10015388/
Postgres 10 和 11 的插入规范说: ON CONFLICT [ conflict_target ] conflict_action 我有一张 table : create table c
我的理解是conflict serializable 隐含serializable。我不确定这如何让他们与众不同。可序列化是否意味着冲突可序列化? 最佳答案 冲突可序列化是可序列化的一个子集,因此仅仅
在数据库理论中,“冲突可序列化”和“冲突等价”有什么区别? 我的教科书有一节是关于冲突可序列化的,但掩盖了冲突等价性。这些可能都是我熟悉的概念,但我不熟悉术语,所以我正在寻找解释。 最佳答案 DBMS
我有一个项目一直在 Xcode 4.4.1 中进行,我想回到以前的分支。(注意分支并不复杂,而是代表线性发展) 当我选择上一个分支时有一个警告 UserInterfaceState.xcusersta
我得到了一个 environment.ubuntu.yml文件,以便能够创建 conda 环境。但是,运行 conda create env --file environment.ubuntu.yml
我浏览了互联网,找不到我的问题的清晰简洁的答案。我想知道如果我将相同强度的信号驱动到同一根电线上会发生什么,其中一个是逻辑 1,另一个是逻辑 0?如果我想要一个“获胜”的信号,因为没有更好的词,我该怎
我在2个网站上有2个不同的图片: http://www.siteA.com/avatar.png http://www.siteB.com/avatar.png 如果我创建具有2个起源的Amazon
我正在 Labview 中开发一个数据采集程序,该程序使用多个转换阶段、相机、高速数字化仪和其他仪器。我正在一台计算机上开发该应用程序,并将其部署到另一台计算机上。开发计算机有labview 2013
能否请您帮助我理解为什么乐观并发更新会有这样的结果。 比如说,我有以下文件: { "phrase": "some phrase", "id": "5d1341797e2ed599", "_
我想安装这两个包: “anahkiasen/前任”:“开发大师” "vespakoen/menu": "dev-master" 但是 composer 说它们每个都依赖于这个包的不同版本: "anah
我在运行 powershell 时遇到以下错误 $thumbprint=$(az webapp config ssl upload --certificate-file $Path --certifi
我不太确定这是否是我使用的 SQLite 版本的问题。但实际上我并没有直接使用 native SQLite (dll),我使用的是 System.Data.SQLite 版本 1.0.108.0 看起
我有一个具有 iBeacon 服务和标准 BLE 服务的芯片。 我想使用 iBeacon 服务在进入 BLE 信号范围时触发我正在开发的应用。 激活后,我希望应用程序使用 CoreBluetooth
建表语句: ? 1
我使用此链接中的示例创建了测试 Telegram 机器人控制台应用程序 https://github.com/TelegramBots/Telegram.Bot.Examples 这是我的主要 pub
我有这个 hpp 文件: struct rte_spinlock_t; class A { public: void init(); private:
我已经从 GitHub 中提取了文件。现在我需要创建一个合并冲突。 如何在 GitHub 上故意创建合并冲突? 最佳答案 在两个分支中编辑同一行,并尝试合并 Merge conflicts in gi
我是这个 repo 的管理员。在这个 PR 中,我删除了多个文件并将这些更改从本地合并到源/开发。将 origin/develop 合并到 origin/master 时,我遇到了我删除的四个文件之一
我使用 Azure 表存储从 MVC 应用程序记录访问者信息,但有时会引发以下异常: [WebException: The remote server returned an error: (409)
我有一张 table : create table c ( e text not null, m text not null, p numeric not null,
我是一名优秀的程序员,十分优秀!