朱雀的IT世界

          每天進步一點點,努力做好自己

           

          同事的一篇Blog 講使用TDD 其實核心不在于測試,而在于測試的回饋:影響設計和后續(xù)的好處

          When asked "Do you write tests?", a lot of developers these days will say "of course" as their answers. However, not everyone can admit to doing TDD (Test Driven Development) correctly. Test Driven Development says, a developer will write a test that fails first, then write code to make the test pass, and refactor when possible, and repeat. This is what most people's TDD rhythm is. For the most part this is fairly easy to do. But to reach the next level, one has to understand TDD as a tool: TDD means more than just test your own code. Here is a couple tips on what the last "D" means:

          Discipline

          It takes a great deal of discipline to even write a failing test before writing the actual code. Sometimes, we write a little seudo-code here, or move a method definition there, or changing code else where trying to see if more new code needs to be written after it, and sooner than you think you are writing the actual implementation of the methods you wanted to test (Test Afterwards Development anyone?). Other times you write the test, but you are too anxious to even run it and see it fails. And other times you want to jump into the actual code immediately when you see your new test fails, but failing for the unexpected reasons.

          Don't fall into these traps. If anything is true, testing is hard, but it is at the same time rewarding and fun. What's also true is, it will pay off. Write the failing test, draw up your list of tests you will need to write, and satisfy them one by one. Having discipline is the cornerstone of becoming a better programmer.

          Design

          It takes too long to write a test? Tests are running too slowly? Are your tests difficult to read? Are they too brittle and fail all the time? Hang in there! You ever had the feeling you saw code in the codebase that irks the living hell out of your mind written by someone else on your team? Well, it is time for you to get some of these feedback about your own code. Yay, your code sucks! Your tests are telling you that! Let's address each of these one by one.

          Slow running tests? You shouldn't be hitting a database or web service in your unit tests, because you can mock/stub them out. Difficult to mock/stub it out? There probably is a better way to design your classes your tests are hitting. Ever heard of Inversion of Control (or Dependency Injection)? Master them. True TDD masters use them extensively.

          Unreadable tests? Is it because of too many mocks/stubs? Or is it the code is 500 lines long and doing high octane 720-double-backflip logic? Either way, you have to learn to like small objects. Check this blog post of mine out.

          Hard to test something? Tests too brittle? Perhaps you have encapsulation issues in your class design. If your classes are referencing 15 other neighbors, of course they are hard to mock/stub. Chances are, you have to spend time to debug your tests to find out what's wrong! Heard of Law of Demeter? Even if you have, take a look at this highly entertaining yet informative post. It might change your perspective a little.

          The bottom line is, TDD is a way to guide you to writing good code, but only if you know how to use it as a tool. Now that you know, hopefully you will have a new perspective next time you write a test.

          posted on 2007-12-06 11:48 朱雀 閱讀(284) 評論(1)  編輯  收藏

          評論

          # re: 同事的一篇Blog 講使用TDD 其實核心不在于測試,而在于測試的回饋:影響設計和后續(xù)的好處[未登錄] 2008-01-12 08:50 Michael Chen

          If we refer another post/article, we always leave the original link for the readers' reference.  回復  更多評論   


          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導航:
           

          導航

          統(tǒng)計

          常用鏈接

          留言簿(5)

          隨筆分類

          隨筆檔案

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 达日县| 江达县| 吉安市| 芮城县| 东乡| 舟山市| 扶沟县| 泉州市| 夏邑县| 卢湾区| 通河县| 镇安县| 图木舒克市| 乌拉特后旗| 额敏县| 武陟县| 台北县| 长乐市| 青河县| 新郑市| 托克逊县| 成武县| 华宁县| 黄冈市| 旺苍县| 横山县| 开鲁县| 康平县| 姚安县| 民勤县| 武川县| 牡丹江市| 蓝山县| 武陟县| 洞口县| 南安市| 神池县| 聂拉木县| 鹤山市| 扎赉特旗| 嫩江县|