- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有几个问题,关于当许多开发人员都在做同一件事(不能进一步拆分)并且您仍然希望每天进行部署时,您如何处理测试和部署。
目前我们遵循 Gitflow,我们有我们的功能分支,每个人都在处理一个独立的功能。功能 merge 到开发分支中。我们时不时地花一些时间来满足用户需求/错误修复/快速功能等。
最终目标是尽快将它们投入生产。我的问题是您建议采用哪种流程:
1) 我们可以在不引入官僚主义的情况下进行部署(例如,在每个月的最后一个星期五发布)。
2) 如果某人提交了引入错误的代码,它不会影响其他提交了无错误代码的人。换句话说,如果编码员 A 试图通过引入新错误来修复错误,而编码员 B 已经修复了他的错误,那么编码员 B 的代码将进一步进入管道,而编码员 A 将延迟修复错误:)
3) 我们不能拥有无限的测试环境。我们也不想花一天时间设置测试环境。我们需要一个可以解决此要求的解决方案(因此除非我遗漏了什么,否则不能对功能分支进行测试)
3) 测试人员确切地知道他们批准什么进入产品。
顺便说一句,我们有一套相当广泛的单元/功能测试,但这个问题是关于过程的,所以这些并不真正相关。
此外,我已经研究了所有其他问题,但没有什么能真正解决我的所有问题。如果您认为有一个可以,我很乐意看一看。
谢谢
最佳答案
在流程方面,与“标准流程”相比,您只需要多一个可选步骤:如果您发现错误(或可能是严重错误),您将回滚所有更改(即包含错误的 merge )。
从开发分支创建一个正在测试的分支,或简称 BUT
特性分支 merge 到测试分支,而不是直接 merge 到开发分支
您有一个 BUT,它现在要么与上一个版本相同,要么在此过程的最后一次迭代中经过良好测试。
现在您将所有功能分支/bugfixes merge 到您准备好的分支中。
你测试一下。如果出现关键问题,即导致下一个版本不希望包含错误的功能/错误修复,您可以通过重置和重做所有 merge 或通过 rebase 和删除提交来撤消该功能的 merge ,这基本上是相同。请注意,这会更改分支的历史记录,因此在测试完成之前,任何人都不应将此分支 merge 到任何内容中。
如果测试迭代成功完成(即没有重大错误),您将其 merge 到开发中。
We can deploy without introducing bureaucracy (e.g. Release on the last Friday of every month).
您仍然像以前一样拥有发布分支。这里没问题。唯一的开销是您可能必须撤消 merge ,如果它们有问题,但我看不出解决这个问题的方法。
If someone commits code that is introducing a bug it doesn't affect someone else that has committed bugless code. In other words, if Coder A tries to fix a bug by introducing a new bug, and coder B has fixed his bug then coder's B code will get further into the pipeline while coder A will stay late fixing the bug
检查
We cannot have unlimited testing environments. We also don't want to spend our day setting up testing environments. We need a solution that can work around this requirements (so test on feature branches is not an option unless I m missing something)
您只需要一个测试环境。更多可能有助于促进多个测试人员的并行工作。但这是可选的。
The testers know exactly without a doubt what they are approving to go into prod.
如果功能分支是 BUT 历史的一部分,您可以很容易地使用标准 git 命令确定,这正是您所需要的。
只要未经测试人员批准,就不会投入生产,也不会与其他人的工作 merge 。这可能成为流程中的瓶颈,特别是如果来自功能分支的内容质量低下。如果测试人员必须取消 merge ,他们将不得不重新测试其余部分(至少我认识的测试人员会坚持这样做,并且有充分的理由)。所以错误会减慢你的速度(这并不新鲜,但在这样的过程中变得非常明显)。
为了限制这种影响,您应该付出很多努力使功能分支尽可能好:
基本上,减少测试人员必须完成的工作量并加快其余工作的一切都会有很大帮助。
你说你不能有很多测试环境。考虑您是否可以拥有部分测试环境,这些环境不需要所有资源,但仍然适合某些测试。
关于.net - Gitflow 和测试/部署,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34989588/
我获得了一些源代码示例,我想测试一些功能。不幸的是,我在执行程序时遇到问题: 11:41:31 [linqus@ottsrvafq1 example]$ javac -g test/test.jav
我想测试ggplot生成的两个图是否相同。一种选择是在绘图对象上使用all.equal,但我宁愿进行更艰巨的测试以确保它们相同,这似乎是identical()为我提供的东西。 但是,当我测试使用相同d
我确实使用 JUnit5 执行我的 Maven 测试,其中所有测试类都有 @ExtendWith({ProcessExtension.class}) 注释。如果是这种情况,此扩展必须根据特殊逻辑使测试
在开始使用 Node.js 开发有用的东西之前,您的流程是什么?您是否在 VowJS、Expresso 上创建测试?你使用 Selenium 测试吗?什么时候? 我有兴趣获得一个很好的工作流程来开发我
这个问题已经有答案了: What is a NullPointerException, and how do I fix it? (12 个回答) 已关闭 3 年前。 基于示例here ,我尝试为我的
我正在考虑测试一些 Vue.js 组件,作为 Laravel 应用程序的一部分。所以,我有一个在 Blade 模板中使用并生成 GET 的组件。在 mounted 期间请求生命周期钩子(Hook)。假
考虑以下程序: #include struct Test { int a; }; int main() { Test t=Test(); std::cout<
我目前的立场是:如果我使用 web 测试(在我的例子中可能是通过 VS.NET'08 测试工具和 WatiN)以及代码覆盖率和广泛的数据来彻底测试我的 ASP.NET 应用程序,我应该不需要编写单独的
我正在使用 C#、.NET 4.7 我有 3 个字符串,即。 [test.1, test.10, test.2] 我需要对它们进行排序以获得: test.1 test.2 test.10 我可能会得到
我有一个 ID 为“rv_list”的 RecyclerView。单击任何 RecyclerView 项目时,每个项目内都有一个可见的 id 为“star”的 View 。 我想用 expresso
我正在使用 Jest 和模拟器测试 Firebase 函数,尽管这些测试可能来自竞争条件。所谓 flakey,我的意思是有时它们会通过,有时不会,即使在同一台机器上也是如此。 测试和函数是用 Type
我在测试我与 typeahead.js ( https://github.com/angular-ui/bootstrap/blob/master/src/typeahead/typeahead.js
我正在尝试使用 Teamcity 自动运行测试,但似乎当代理编译项目时,它没有正确完成,因为当我运行运行测试之类的命令时,我收到以下错误: fatal error: 'Pushwoosh/PushNo
这是我第一次玩 cucumber ,还创建了一个测试和 API 的套件。我的问题是在测试 API 时是否需要运行它? 例如我脑子里有这个, 启动 express 服务器作为后台任务 然后当它启动时(我
我有我的主要应用程序项目,然后是我的测试的第二个项目。将所有类型的测试存储在该测试项目中是一种好的做法,还是应该将一些测试驻留在主应用程序项目中? 我应该在我的主项目中保留 POJO JUnit(测试
我正在努力弄清楚如何实现这个计数。模型是用户、测试、等级 用户 has_many 测试,测试 has_many 成绩。 每个等级都有一个计算分数(strong_pass、pass、fail、stron
我正在尝试测试一些涉及 OkHttp3 的下载代码,但不幸失败了。目标:测试 下载图像文件并验证其是否有效。平台:安卓。此代码可在生产环境中运行,但测试代码没有任何意义。 产品代码 class Fil
当我想为 iOS 运行 UI 测试时,我收到以下消息: SetUp : System.Exception : Unable to determine simulator version for X 堆
我正在使用 Firebase Remote Config 在 iOS 上设置 A/B 测试。 一切都已设置完毕,我正在 iOS 应用程序中读取服务器端默认值。 但是在多个模拟器上尝试,它们都读取了默认
[已编辑]:我已经用 promise 方式更改了我的代码。 我正在写 React with this starter 由 facebook 创建,我是测试方面的新手。 现在我有一个关于图像的组件,它有
我是一名优秀的程序员,十分优秀!