- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
据我了解,在TDD中,您必须先编写一个失败的测试,然后编写代码使其通过,然后进行重构。但是,如果您的代码已经解决了您要测试的情况,该怎么办?
例如,假设我正在TDD'排序算法(这只是假设)。我可能会针对两种情况编写单元测试:
输入= 1,2,3
输出= 1,2,3
输入= 4,1,3,2
输出= 1,2,3,4
等等...
为了使测试通过,我最后使用了一个快速的“n脏泡沫排序”。然后,我将其重构并替换为更有效的合并排序算法。后来,我意识到我们需要一种稳定的排序方式,因此我也为此编写了一个测试。当然,测试不会失败,因为合并排序是一种稳定的排序算法!无论如何,我仍然需要此测试,以防有人再次对其进行重构以使用其他可能不稳定的排序算法。
这是否打破了始终编写失败测试的TDD口号?我怀疑有人会建议我浪费时间实现不稳定的排序算法,只是为了测试测试用例,然后重新实现合并排序。您多久遇到一次类似情况,您会怎么做?
最佳答案
首先编写失败的测试然后再运行它们有两个原因。
首先是检查测试是否实际上在测试您编写的内容。您首先检查它是否失败,然后更改代码以进行测试运行,然后检查它是否运行。看起来很愚蠢,但是我有好几次为已经运行的代码添加了一个测试,以便以后发现我在测试中犯了一个错误,使它始终可以运行。
第二个也是最重要的原因是防止您编写过多的测试。测试反射(reflect)了您的设计,而设计则反射(reflect)了您的需求和需求变更。发生这种情况时,您不需要重写很多测试。一个好的经验法则是,使每个测试仅出于一个原因而失败,并且仅使一个测试因该原因而失败。 TDD尝试通过对代码库中的每个测试,每个功能和每个更改重复标准的红绿重构周期来强制执行此操作。
但是当然要打破规则。如果您牢记为什么首先要制定这些规则,则可以灵活地使用它们。例如,当您发现自己的测试可以测试多项功能时,可以将其拆分。实际上,您已经编写了两个从未见过失败的新测试。破坏然后修复代码以查看新测试失败是重新检查事情的一种好方法。
关于TDD-什么时候可以编写不失败的测试?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/360849/
我知道 TDD 有很多优点(其中一些在下面)。我怎么不确定它是如何驱动设计的? 作为文档 在实际代码之前编写测试有助于最大限度地提高测试覆盖率 帮助确定输入值边界 通常当我们开始实现新功能时,我们会对
我们的团队使用 TDD 进行开发,在实现新功能时,有时会在故事结束时所有卡片都变成绿色时出现“集成卡片”,这意味着将已实现的组件放在一起以相互配合。我对这张卡感觉很糟糕,因为这意味着,没有人在现实生活
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 5 年前。 Improve
我在浏览StackOverflow时遇到this题。这里作者提到了他/她的调试风格: I am wondering how to do debugging. At present the steps
我对 TDD 很陌生,我想到的第一个问题是我是否应该对每个开发的组件应用单元测试。我之所以这么问是因为我观察到单元测试需要很多时间,尤其是在对需求进行了一些更改时。那么,您能否提出一些类似于 TDD
假设您正在实现包含各种新功能并增加代码库复杂性的用户故事。现有代码已经很好地涵盖了,您刚刚决定了接口(interface)。您开始实现从测试开始的功能。 现在您有相当复杂的基于需求的测试用例,但实现远
我正在使用VS 2012,但这并不是很重要。 重要的是,我正在尝试通过首先编写所有测试然后创建代码来进行一些TDD。 但是,该应用程序将无法编译,因为我的对象或方法都不存在。 现在,在我看来,我应该能
我对单元测试和 TDD“相对较新”。直到最近,我才完成了我的第一个(至少在理论上)代码覆盖率为 100% 的生产应用程序。我在以前的项目中也做过一段时间的单元测试,但不是以真正的 TDD 方式和良好的
关闭。这个问题是opinion-based .它目前不接受答案。 想改进这个问题?更新问题,以便 editing this post 可以用事实和引用来回答它. 5年前关闭。 Improve this
我真的很想在我工作的车间内插入 TDD 开发。那里的很多前辈不从事单元测试工作,或者进行了会影响数据库的单元测试。 我很想带来一些好的论据、培训书籍、可能的教练来缓解过渡。 最佳答案 我发现通常很难从
请注意,我还没有在 TDD 上“看到曙光”,也没有真正理解为什么它的主要支持者宣扬了它的所有好处。我并没有否认它 - 我只是有我的保留意见,这可能是出于无知。所以无论如何都要笑下面的问题,只要你能纠正
我工作的所有项目都与一个硬件接口(interface),这通常是软件的主要目的。有什么有效的方法可以将 TDD 应用于与硬件一起工作的代码? 更新:对不起,我的问题没有更清楚。 我使用的硬件是从相机捕
我团队中的一位同事说,某些方法应该同时具有前提条件和后置条件。但重点是代码覆盖率,这些条件不会被调用(未测试),直到实现了无效的实现(仅在单元测试中使用)。让我们看下面的例子。 public inte
关闭。这个问题是opinion-based .它目前不接受答案。 想改进这个问题?更新问题,以便 editing this post 可以用事实和引用来回答它. 4年前关闭。 Improve this
我不明白下面的代码如何不遵守TDD FIRST principle。 这些是我关于FIRST原则的说明: Fast: run (subset of) tests quickly (since you'
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 11 年前。 Improve thi
在引用涉及 TDD 的项目/任务的估算时是否有任何指导方针? 例如,与正常开发需要 1 天才能完成的任务相比,TDD 驱动的任务需要多花多少时间?多出 50% 的时间还是多出 70% 的时间?假设开发
总结: 您在 TD 设计与开发中包含和/或交付了哪些模型和图表,为什么? 详细信息: 新的 4 位开发人员项目,在我们逐渐取得进展的商店中,让管理层在 TDD 采用/期望方面从“购买”升级到“行动”。
我的公司想在我们的项目中应用 TDD,我们 5 个月前开始研究 TDD。我们从编写单元到验收测试开始(您可以在 http://uet.vnu.edu.vn/~chauttm/TDD/ 中看到)。然后我
几周前,我开始了我的第一个 TDD 项目。到目前为止,我只读过一本关于它的书。 我主要关心的是:如何为复杂的方法/类编写测试。我写了一个计算二项分布的类。因此,该类的方法将 n、k 和 p 作为输入,
我是一名优秀的程序员,十分优秀!