查看全部128种考试
软件水平考试
 考试动态 报考指南 历年真题 模拟试题 复习资料 心得技巧 专业英语 技术文章 软考论坛 考试用书
 程序员 软件设计师 网络管理员 网络工程师 系统分析师 数据库系统工程师
1
2
3
4
5
6
7
8
9
10
yanruijie  
【字体: 从企业的运行价值链说起——我眼中的测试驱动开发(TDD)
从企业的运行价值链说起——我眼中的测试驱动开发(TDD)
spks.exam8.com 来源:考试吧(Exam8.com) 更新:2007-1-25 18:11:29 软件水平考试 考试论坛

  二、通过TDD进行重构)

  “发现价值”的过程远远没有结束。通过测试代码,我们从客户的角度来考虑,会发现一些问题。在已经实现的代码中,SmartAssistor类型实现了Search,Store和List的功能。但这些职责是否真的应该由它承担呢?表面上来看,是这样的。然而根据OO的思想来看,这个SmartAssistor所承担的责任是否太多了?它和搜索的结果、显示的方式耦合度是否太紧密了?这个设计将实现抽象出来了吗?这些都应该是我们考虑的重点。考虑的时机,可以是设计之初,也可以是重构之时。

  在重构的时候,仍然不能放弃TDD,只有它才能保证程序的可靠性,重构的正确性。开始重构吧。

  首先从行为来考虑。搜索的功能会很复杂吗?可能会有精确搜索,模糊搜索;可能是在网上搜索,也可能是本机搜索。那么,存储的功能呢?IO的操作是否频繁,存储的要求是否会根据安全级别而逐步升级?再考虑显示,对于个人智能助理来讲,显示的方式需要多样化吗?显然,以上的行为都是复杂的。

  再从抽象性考虑。需要把这些行为抽象出来吗?也就是说,这些行为的载体是否会有多种类型?显然,搜索可能会是文件的搜索,可能会是文本的搜索,也可能会是数据库的搜索;存储的格式也会有多种多样,文本文件,xml文件,数据库文件。显示的方式可能会通过浏览器显示,也可能会在WinForm中显示。也许用户要求是带滚动条的文本框,也许只是简单的文本显示。对象的形式很多吧,需要抽象吗?显然是的!

  这样考虑之后,我发觉需要重构的东西太多了,应该怎么入手?首先,我们把SmartAssistor的职责先剥离出来,用更单一的对象来完成各自的功能。然后,分别将这些对象提炼出各自的接口。还是先写测试代码吧,考虑搜索功能,首先需要将对象分离出来:
  [Test]
    public void TestSearching()
      {
         SearchEngine engine = new SearchEngine();
         Assert.IsNotNull(engine);
 
          SearchResult result1 = new SearchResult();
          SearchResult result2 = new SearchResult();
          Assert.IsNotNull(result1);
          Assert.IsNotNull(result2);
          result1 = engine.ExactSearch(control.Categaries);
          result2 = engine.BlurSearch(control.Categaries);

          SearchResult tempResult1 = new SearchResult(control.Categaries,”contents”); 
          SearchResult tempResult2 = new SearchResult(control.Categaries,”more contents”); 
 
          Assert.AreEqual(tempResult1,result1);
          Assert.AreEqual(tempResult2,result2);

       }
  在NUnit中运行测试代码,未能通过。然后在程序中创建SearchEngine类型,并实现ExactSearch和BlurSearch方法。直到在NUnit中运行通过,全部显示绿灯。

更多软考资料请访问:考试吧软件水平考试栏目

希望与更多网友交流,请进入考试吧软件水平考试论坛

 

上一页  [1] [2] [3] [4] 下一页

转帖于:软件水平考试_考试吧
文章搜索  
看了本文的网友还看了:
软件水平考试权威辅导教材: 订书电话:010-62168566  更多>>>
网友评论
昵 称: *  评 分: 1分 2分 3分 4分 5分
标题:   匿名发表    (共有条评论)查看全部评论>>
版权声明 -------------------------------------------------------------------------------------
  如果软件水平考试网所转载内容不慎侵犯了您的权益,请与我们联系,我们将会及时处理。如转载本软件水平考试网内容,请注明出处。
关于本站  网站声明  广告服务  联系方式  付款方式  站内导航  客服中心  友情链接  考试论坛  网站地图
Copyright © 2004-2008 考试吧软件水平考试网 All Rights Reserved    
中国科学院研究生院权威支持(北京) 电 话:010-62168566 传 真:010-62192699
百度大联盟黄金认证  十佳网络教育机构  经营许可证号:京ICP060677