ยังงง กับ คำว่า Test Driven Development (TDD) คืออะไร ?

 " เอ้!.. TDD คืออะไร "

ความหมายของ TDD 

            

            คำว่า "TDD" เป็นคำย่อของ Test Driven Development เป็นรูปแบบหรือกระบวนการพัฒนาซอฟต์แวร์เพื่อช่วยลดข้อผิดพลาด แล้วได้โค๊ดที่มีประสิทธิภาพ โดยการลดบั๊กต่างๆ ที่อาจจะเกิดขึ้น ที่ตรงกับความต้องการของลูกค้า 

ประวัติของ TDD
            TDD เริ่มใช้ในในปี 1990 โดย Kent Beck ผู้คิดค้น TDD ใช้กับ Extreme Programming  และได้เริ่มใช้ตัว TEST ที่สร้างขึ้นมาเอง  
    ในปี ในปี 1997 ทางหน่วยงาน Junit.org ทีมงานของ Beck และ Erich Gamma พัฒนา TDD ชื่อ JUnit framwork  เพื่อทำให้การเขียน TEST และเรียกใช้งานคำสั่ง TEST นั่นง่ายมากขึ้น และนับจากนั้น JUnit ก็ได้พัฒนาไปใช้กับภาษาอื่นๆ อีกหลายภาษาา เช่น .NET , C++ , Python , PHP เป็นต้น ซึ่งเป็นที่เรียกกันอย่างแพร่หลายในชื่อ xUnit Frameworks

วงจรการพัฒนาซอฟต์แวร์ Test Driven Development (TDD Model)



ภาพแสดงวงจรการพัฒนาซอฟต์แวร์แบบ TDD

    ตามภาพวงจรของการพัฒนาซอฟต์แวร์แบบ TDD ประกอบด้วย 3 ส่วน ดังนี้ 
            1. Red เป็นการเขียน Test Case ที่มีความผิดพลาดจะกำหนดให้เป็นสีแดง ทำการแก้ไขโค๊ดให้มีถูกต้อง
            2. Green เมื่อ Test Case ผ่านแล้วจะมีสีเขียว ก็สามารถนำไปพัฒนาโค๊ดใช้งานจริง
            3. Refactor เป็นส่วนการปรับปรุงโค๊ดให้สมบูรณ์และถูกต้อง 

" น่าจะรู้จัก TDD จากความหมายนี้ "

        TDD หมายถึง   "กระบวนการพัฒนาซอฟต์แวร์โดยอาศัยข้อกำหนดของซอฟต์แวร์ที่จะถูกแปลงเป็นกรณีทดสอบก่อนที่ซอฟต์แวร์จะได้รับการพัฒนาอย่างสมบูรณ์ และติดตามการพัฒนาซอฟต์แวร์ทั้งหมดโดยการทดสอบซอฟต์แวร์ซ้ำๆ กับกรณีทดสอบทั้งหมด ซึ่งต่างจากการพัฒนาซอฟต์แวร์ก่อนและกรณีทดสอบที่สร้างขึ้นในภายหลัง"

ประโยชน์ของ TDD มีอะไรบ้าง
  • ระบบทำงานตาม Requirement ของลูกค้า 
  • ลดการการเขียนโค้ด เพราะทีมงานได้เขียน Test Case และทำการ Runผ่าน เขียนเท่าที่จำเป็น
  • ช่วยลดความก Defect และ Effort ในการพัฒนาได้
  • ช่วยลดความซับซ้อนของ Code และช่วยให้ Code อ่านได้ง่ายขึ้นเพราะมี Phase ที่ Refactor อยู่ตลอดเวลา

" ขั้นตอนการทำ  TDD มีอะไรบ้าง ทำอย่างไง"

ภาพแสดง Work Flow TDD

ภาพขั้นตอนการทำ TDD อย่างละเอียด


ในการขั้นตอนการใช้งานตามรูปแบบ TDD ในภาพ มีรายละเอียด ดังนี้

  1. การวางแผนและเขียนเทส Test 
  2. รันเทสที่สร้าง 
  3. การเขียน Code
  4. รันเทสอีกครั้ง
  5. Refactor Code 
การพัฒนาซอฟต์แวร์ระหว่าง TDD Model กับ  Agile Sprint Model


มีรายละเอียดขั้นตอน 

เปรียบเทียบการพัฒนาซอฟต์แวร์ระหว่าง TDD Model กับ V-shape Model

ความคิดเห็น