测试的重要性是每个程序员都明白的, 但真正自己去做测试(Unit Test)的却很少, 曾经我也是其中的一员.
因为写个main调用一些方法, 打印出结果或状态, 然后人工肉眼去排查, 若不是迫于无奈, 我相信没有程序员愿意纠结于这些琐碎的东西.
其实, 测试本可以很有趣的.借助JUnit, 我们可以将测试按不同的场景组织起来, 在”一键”之后的红绿条的反馈下, 快速解决代码中存在的问题. 如果你还不太了解JUnit, 请先去这里. 后文将以JUnit为基础, 以Fluent Interface(这个在国内还比较时髦的术语)为切入点, 展示一下更有趣的测试.
在解释什么是Fluent Interface之前, 请先看这样一段测试代码:
public class Calculator { public int sum(int one, int other); } public class CalculatorTest { private final Calculator calc = new Calcuator(); @Test public void onePlusOne() { assertEquals(2, calc.sum(1, 1)); } }
上述代码是基于JUnit4编写的, 用assertEquals来测试Calculator的sum方法对一加一计算的结果. 这种写法很简单, 但从语义上并不是那么流畅, 若换种写法, 如:
public class CalculatorTest { [...] @Test public void assertThatOnePlusOneIsEqualToTwo() { assertThat(calc.sum(1, 1)).isEqualTo(2); } }
这样阅读起来是否感到更为清晰呢? 若是将语句中的符号换成空格:
assert that calc sum 1 and 1 is equal to 2
这几乎就是人类的自然语言了(
建议继续学习:
- web项目和单元测试 (阅读:3395)
- Linux下c/c++项目代码覆盖率的产生方法 (阅读:2064)
- rebar单元测试中源代码的中文乱码问题解决方案 (阅读:1470)
- Clojure世界:单元测试 (阅读:1459)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
扫一扫订阅我的微信号:IT技术博客大学习