String strText = "910"; String strTextResult = "._.|_|..|.....|..|._.|.||_|";String strOutput = digitalSegment.DisplaySegmentDigital(strText);assertEquals(strOutput , strTextResult);
public String DisplaySegmentDigital(String strText) {return "._.|_|..|.....|..|._.|.||_|";}
String strText = "3456"; String strTextResult = "????????";
问题接着出来了:这串问号该填什么?这样测试真的有意义么?几乎所有的人都直觉得发现这里有问题。简短的讨论后,结论是应该测试每个数字的显示,而非一个字符串。于是,测试变为:
String strText = "9"; String strTextResult = "._.|_|..|";
String strOutput = digitalSegment.DisplaySegmentDigital(strText);
assertEquals(strOutput , strTextResult);
实现变为:
public String DisplaySegmentDigital(String strText) {
if(strText == "9")
return "._.|_|..|";
else
return null;
}
实现后,接着测试:
strText = "1"; strTextResult = ".....|..|";
strOutput = digitalSegment.DisplaySegmentDigital(strText);
assertEquals(strOutput , strTextResult);
实现也变为:
public String DisplaySegmentDigital(String strText) {
String[] strResult=new String[10];
strResult[0]="._.|.||_|";
strResult[1]=".....|..|";
strResult[9]="._.|_|..|";
return strResult[Integer.parseInt(strText)];
}
至此,很显然我们的算法也就自然而然的诞生了。可能与很多人自己开始的算法设计不太一样,但也不应该差到哪里:)。这就是TDD演进式设计。
但有个问题,._.|_|..|是什么东东?我怎么知道最终输出是正确的。因此,我们稍微改变了一下写法:
String strText = "9"; String strTextResult = "._." +
"|_|" +
"..|";String strOutput = digitalSegment.DisplaySegmentDigital(strText);
assertEquals(strOutput , strTextResult);
strText = "1";
strTextResult = "..." +
"..|" +
"..|";
strOutput = digitalSegment.DisplaySegmentDigital(strText);
assertEquals(strOutput , strTextResult);
实现变为:
public String DisplaySegmentDigital(String strText) {
String[] strResult=new String[10];
strResult[0]="._." +
"|.|" +
"|_|";
strResult[1]="..." +
"..|" +
"..|";
strResult[9]="._." +
"|_|" +
"..|";
return strResult[Integer.parseInt(strText)];
}
现在直观多了。
为什么一定要变得直观,其目的不单纯是为了程序的易读性,更重要的是:测试不应该抄实现的代码,实现也不要抄测试的代码,否则后果很严重。写测试代码时,必须是含着测试的心态,含着使用者的心态去写测试代码,而非一门心思去想实现。如果这样,TDD就失败了。这也是为什么TDD要求先写测试代码,再写实现代码的原因。因为我们一旦先想到了实现,那么接下来的测试,必然会跟着实现的逻辑走,从而违背“测试独立性”的原则。实现发生错误,测试也无法发现。
接下来需要整理一下代码,显然DisplaySegmentDigital这个函数名不是那么准确,后来议论了一番,得出的名字是:GetDigitalDisplayContent。结束后,我想GetDigitalFont可能更好。
好了,有关第一次道场就写到这里,留一个小小的问题:到目前为止我们还没有设计显示的算法。为了便于输出,目前的设计如何改进?