- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在从事一个已经存在多年的项目。构建包含所有测试的项目所花费的时间几乎是惊人的(不是一个好的方式)。这主要是由于大量的模块以及大量的单元测试,它们使用存储库来设置测试数据,而不是模拟所需的行为。使用存储库的单元测试需要花费大量时间来进行测试设置,并且运行速度非常慢。由于系统相当大,这会增加很多时间。
我们通过使用 Mockito 来模拟存储库来编写所有新的单元测试(除非我们实际上明显地测试存储库)。只要有时间和机会,我们还尝试重写所有现有的单元测试,以使用存储库的模拟而不是实际的存储库。在我们的测试中完全消除存储库的使用对运行测试所需的时间有巨大影响。
许多遗留代码通过使用构建器和测试实用程序来设置其测试数据,而构建器和测试实用程序又使用存储库。由于域非常复杂,这通常涉及设置相当数量的对象以及它们如何相互关联。因此,重新编写一类测试(例如约 15 个测试)以仅使用模拟对象可能会非常耗时。与其他地方一样,时间并不是无限的资源。
如果我们要向一个类添加一些新功能,那么只编写一个新的存储库测试(除了现有的 15 个测试之外)会比通过使用来准确找出测试数据需要如何设置要容易得多不同的模拟对象。
我试图找到一些关于测试设置如何以及在多大程度上影响运行测试所需的实际时间的信息,但我未能找到任何有用的信息。我唯一的“事实”是我在运行测试类时所做的观察。存储库测试的测试设置可能很容易需要约 10 秒,而模拟测试类的测试设置只需不到一秒即可开始。
注意:我知道我可以使用 JUnit Stopwatch 对单个或一组测试进行基准测试,但我的问题更关心的是最佳实践,而不是我运行测试所需的确切时间。
我有两个问题:
假设我遇到一个测试类,它已经有 15 个单元测试,其中没有一个测试模拟任何行为。我编写了一个测试并在类里面做了一个小修复。我没有时间将整个测试类重写为模拟对象。我是否应该添加一个新的测试而不模拟任何行为并遵循现有的(和坏的)模式?我有 15 个非模拟测试和 1 个模拟测试,还是有 16 个非模拟测试,这真的很重要吗?
在我的包含 15 个单元测试的测试类中,某些测试比其他测试更容易重构。仅使用模拟对象重写五个测试是否值得?拥有一个测试类,其中一些测试使用模拟,而另一些则不使用,这是否违反最佳实践或以任何其他方式不好?
最佳答案
您的问题确实很主观,但我会尝试建议您可以探索的一些选项。这完全取决于您愿意花多少钱。
Should I just add a new test without mocking any behavior and follow the existing (and bad) pattern? Does it really matter whether I have 15 non-mocked tests and 1 mocked test or if I have 16 non-mocked tests?
这不仅仅是一项新测试。如果你仍然以糟糕/缓慢的模式写作,那么你只是在增加技术债务。您必须自己制定编写新单元测试的最佳实践。
In my test class with 15 unit tests, some of the tests are easier to refactor than others. Is it worth it to re-write only five of the tests to using mocked objects?
绝对是的。为什么不?您为自己讲述了通过遵循更新的代码风格所获得的改进。
Is it against best practice or in any other way not good to have a test class where some of the tests uses mocks and some don't? Well one best practice is to have consistent code everywhere. Mix of old styled repositories and newer one with mocks does not go too well as far as best practices are concerned. But I'd be more concerned if the code you write is not well covered with unit tests, whatever style if may be.
最终,您需要做出决定并考虑所有权衡,例如通过更新的模拟存储库可以实现多少构建时间改进,构建的频率是多少,以及这是否可以通过硬件改进和其他因素来实现。
关于java - 在 JUnit 中设置测试的成本 - 使用模拟对象与遗留代码中的存储库测试,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50756436/
我获得了一些源代码示例,我想测试一些功能。不幸的是,我在执行程序时遇到问题: 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 创建,我是测试方面的新手。 现在我有一个关于图像的组件,它有
我是一名优秀的程序员,十分优秀!