- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们使用具有相当标准设置的 GitFlow:
develop 和 master 之间确实存在一些差异,例如我们希望 master 指向特定版本的 NuGet 依赖项,而 develop 指向这些依赖项的其他版本。
我们发现,当我们进行 GitFlow 修补程序并完成该修补程序时,在它从修补程序分支 merge 到开发时,它会尝试将这些配置差异从 master merge 到开发中,即使这些配置更改不是作为修补程序的一部分完成的。
我的同事断言,当我们最初迁移到 GitFlow 而不是使用 GitFlow Releases 功能时,这个问题很可能是主分支通过从 develop 分支形成的副作用。
是否有人对此类设置或症状有任何经验,或者有任何建议来尝试解决它?我们正在考虑尝试通过使用 GitFlow Release 功能或使用 Git 属性来忽略要 merge 的文件来重新创建 master,但感觉可能有更明智的方法来解决这个问题。
最佳答案
这是由于 master
和 develop
之间的“merge 基础”后,您在 master
上的配置在某处发生了更改。 (粗略地说,“merge 基础”是 master
和 develop
历史上最近的提交。)我想说这意味着你的同事在正确的轨道上。您是否使用特定的 GitFlow 工具并不严格,但是 develop
应该从 master
分支出来(而不是相反),并且(也许更重要)不应将更改直接应用于 master
。
如果您觉得这些陈述不合理,那么您所拥有的并不是 GitFlow 的“相当标准的设置”。
在 GitFlow 设置中,依赖版本与任何代码更改都没有什么不同。通常只有几件事会发生:
最常见的事情应该是,一个功能需要一个依赖项(或新版本的依赖项),以便更改进入功能分支上的构建配置。从那里它最终 merge 到 develop
,然后在 merge 到 master
的发布分支上进行。
另一种可能性是版本号在修补程序中被更改,因为您需要安全补丁或依赖项。当然,这应该 merge 到 master
和 develop
中。
最后,您可以更改发布分支上的依赖项;但同样,这些更改预计会 merge 到 master
和 develop
中。
共同的主题是,这些通常都应该汇聚到一个共同的配置。这不是错误的;如果您声称希望版本在生产中保持不同,那么您就是在说您不希望您的开发人员能够进行准确有效的测试。
如果您遵循 gitflow,那么 develop
与 master
具有不同版本的依赖项的唯一原因是更改尚未流向 主人
;在那种情况下,修补程序 merge 不会认为 master
版本应该覆盖 develop
版本,因为 merge 基础将在 master
上> 版本。
当然,有配置元素在生产环境和开发环境之间应该始终不同(例如连接字符串)。我的建议是在构建过程中解决此问题,而不是在源代码控制工作流程中解决。
关于GitFlow 正在将 master 的不需要的方面 merge 到修复完成的开发中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50008084/
我正在尝试用 C 语言编写一个使用 gstreamer 的 GTK+ 应用程序。 GTK+ 需要 gtk_main() 来执行。 gstreamer 需要 g_main_loop_run() 来执行。
我已经使用 apt-get 安装了 opencv。我得到了以下版本的opencv2,它工作正常: rover@rover_pi:/usr/lib/arm-linux-gnueabihf $ pytho
我有一个看起来像这样的 View 层次结构(基于其他答案和 Apple 的使用 UIScrollView 的高级 AutoLayout 指南): ScrollView 所需的2 个步骤是: 为 Scr
我尝试安装 udev。 udev 在 ./configure 期间给我一个错误 --exists: command not found configure: error: pkg-config and
我正在使用 SQLite 3。我有一个表,forums,有 150 行,还有一个表,posts,有大约 440 万行。每个帖子都属于一个论坛。 我想从每个论坛中选择最新帖子的时间戳。如果我使用 SEL
使用 go 和以下包: github.com/julienschmidt/httprouter github.com/shwoodard/jsonapi gopkg.in/mgo.v2/bson
The database仅包含 2 个表: 钱包(100 万行) 事务(1500 万行) CockroachDB 19.2.6 在 3 台 Ubuntu 机器上运行 每个 2vCPU 每个 8GB R
我很难理解为什么在下面的代码中直接调用 std::swap() 会导致编译错误,而使用 std::iter_swap 编译却没有任何错误. 来自 iter_swap() versus swap() -
我有一个非常简单的 SELECT *用 WHERE NOT EXISTS 查询条款。 SELECT * FROM "BMAN_TP3"."TT_SPLDR_55E63A28_59358" SELECT
我试图按部分组织我的 .css 文件,我需要从任何文件访问文件组中的任何类。在 Less 中,我可以毫无问题地创建一个包含所有文件导入的主文件,并且每个文件都导入主文件,但在 Sass 中,我收到一个
Microsoft.AspNet.SignalR.Redis 和 StackExchange.Redis.Extensions.Core 在同一个项目中使用。前者需要StackExchange.Red
这个问题在这里已经有了答案: Updating from Rails 4.0 to 4.1 gives sass-rails railties version conflicts (4 个答案) 关
我们有一些使用 Azure DevOps 发布管道部署到的现场服务器。我们已经使用这些发布管道几个月了,没有出现任何问题。今天,我们在下载该项目的工件时开始出现身份验证错误。 部署组中的节点显示在线,
Tip: instead of creating indexes here, run queries in your code – if you're missing any indexes, you
你能解释一下 Elm 下一个声明中的意思吗? (=>) = (,) 我在 Elm architecture tutorial 的例子中找到了它 最佳答案 这是中缀符号。实际上,这定义了一个函数 (=>
我需要一个 .NET 程序集查看器,它可以显示低级详细信息,例如元数据表内容等。 最佳答案 ildasm 是 IL 反汇编程序,具有低级托管元数据 token 信息。安装 Visual Studio
我有两个列表要在 Excel 中进行比较。这是一个很长的列表,我需要一个 excel 函数或 vba 代码来执行此操作。我已经没有想法了,因此转向你: **Old List** A
Closed. This question does not meet Stack Overflow guidelines。它当前不接受答案。 想要改善这个问题吗?更新问题,以便将其作为on-topi
我正在学习 xml 和 xml 处理。我无法很好地理解命名空间的存在。 我了解到命名空间帮助我们在 xml 中分离相同命名的元素。我们不能通过具有相同名称的属性来区分元素吗?为什么命名空间很重要或需要
我搜索了 Azure 文档、各种社区论坛和 google,但没有找到关于需要在公司防火墙上打开哪些端口以允许 Azure 所有组件(blob、sql、compute、bus、publish)的简洁声明
我是一名优秀的程序员,十分优秀!