OOAD - การทดสอบและการประกันคุณภาพ

เมื่อเขียนโค้ดโปรแกรมแล้วจะต้องทดสอบเพื่อตรวจจับและจัดการข้อผิดพลาดทั้งหมดในภายหลัง มีการใช้โครงร่างจำนวนหนึ่งเพื่อวัตถุประสงค์ในการทดสอบ

สิ่งสำคัญอีกประการหนึ่งคือความเหมาะสมของจุดประสงค์ของโปรแกรมที่ตรวจสอบว่าโปรแกรมนั้นตอบสนองวัตถุประสงค์ที่ตั้งเป้าหมายไว้หรือไม่ ฟิตเนสกำหนดคุณภาพซอฟต์แวร์

การทดสอบระบบเชิงวัตถุ

การทดสอบเป็นกิจกรรมต่อเนื่องระหว่างการพัฒนาซอฟต์แวร์ ในระบบเชิงวัตถุการทดสอบครอบคลุมสามระดับ ได้แก่ การทดสอบหน่วยการทดสอบระบบย่อยและการทดสอบระบบ

การทดสอบหน่วย

ในการทดสอบหน่วยจะมีการทดสอบแต่ละคลาส จะเห็นว่าแอตทริบิวต์คลาสถูกนำไปใช้ตามการออกแบบหรือไม่และวิธีการและอินเทอร์เฟซนั้นปราศจากข้อผิดพลาดหรือไม่ การทดสอบหน่วยเป็นความรับผิดชอบของวิศวกรแอปพลิเคชันที่ดำเนินการตามโครงสร้าง

การทดสอบระบบย่อย

สิ่งนี้เกี่ยวข้องกับการทดสอบโมดูลเฉพาะหรือระบบย่อยและเป็นความรับผิดชอบของผู้นำระบบย่อย มันเกี่ยวข้องกับการทดสอบความสัมพันธ์ภายในระบบย่อยตลอดจนปฏิสัมพันธ์ของระบบย่อยกับภายนอก การทดสอบระบบย่อยสามารถใช้เป็นการทดสอบการถดถอยสำหรับระบบย่อยแต่ละเวอร์ชันที่เพิ่งออกใหม่

การทดสอบระบบ

การทดสอบระบบเกี่ยวข้องกับการทดสอบระบบโดยรวมและเป็นความรับผิดชอบของทีมประกันคุณภาพ ทีมงานมักใช้การทดสอบระบบเป็นการทดสอบการถดถอยเมื่อประกอบรุ่นใหม่

เทคนิคการทดสอบเชิงวัตถุ

การทดสอบกล่องสีเทา

กรณีทดสอบประเภทต่างๆที่สามารถออกแบบมาสำหรับการทดสอบโปรแกรมเชิงวัตถุเรียกว่ากรณีทดสอบกล่องสีเทา การทดสอบกล่องสีเทาที่สำคัญบางประเภท ได้แก่ -

  • State model based testing - ครอบคลุมถึงความครอบคลุมของรัฐการครอบคลุมการเปลี่ยนแปลงของรัฐและการครอบคลุมเส้นทางการเปลี่ยนสถานะ

  • Use case based testing - แต่ละสถานการณ์ในแต่ละกรณีการใช้งานได้รับการทดสอบ

  • Class diagram based testing - แต่ละคลาสคลาสที่ได้รับการเชื่อมโยงและการรวมจะถูกทดสอบ

  • Sequence diagram based testing - มีการทดสอบวิธีการในข้อความในแผนภาพลำดับ

เทคนิคการทดสอบระบบย่อย

สองแนวทางหลักของการทดสอบระบบย่อยคือ -

  • Thread based testing - คลาสทั้งหมดที่จำเป็นในการใช้งานกรณีเดียวในระบบย่อยจะถูกรวมเข้าด้วยกันและทดสอบ

  • Use based testing- มีการทดสอบอินเทอร์เฟซและบริการของโมดูลในแต่ละระดับของลำดับชั้น การทดสอบเริ่มต้นจากแต่ละคลาสไปจนถึงโมดูลขนาดเล็กที่ประกอบด้วยคลาสค่อยๆไปจนถึงโมดูลที่ใหญ่ขึ้นและสุดท้ายระบบย่อยที่สำคัญทั้งหมด

ประเภทของการทดสอบระบบ

  • Alpha testing - ดำเนินการโดยทีมทดสอบภายในองค์กรที่พัฒนาซอฟต์แวร์

  • Beta testing - ดำเนินการโดยกลุ่มลูกค้าร่วมปฏิบัติการที่เลือก

  • Acceptance testing - ลูกค้าจะต้องดำเนินการก่อนที่จะยอมรับการส่งมอบ

การประกันคุณภาพซอฟต์แวร์

คุณภาพซอฟต์แวร์

Schulmeyer และ McManus ได้กำหนดคุณภาพซอฟต์แวร์ไว้ว่าเป็น "ความเหมาะสมสำหรับการใช้ผลิตภัณฑ์ซอฟต์แวร์ทั้งหมด" ซอฟต์แวร์คุณภาพดีทำในสิ่งที่ควรจะทำและตีความในแง่ของความพึงพอใจของข้อกำหนดข้อกำหนดที่ผู้ใช้วางไว้

การประกันคุณภาพ

การประกันคุณภาพซอฟต์แวร์เป็นวิธีการที่กำหนดขอบเขตที่ผลิตภัณฑ์ซอฟต์แวร์เหมาะสมกับการใช้งาน กิจกรรมที่รวมอยู่ในการกำหนดคุณภาพซอฟต์แวร์ ได้แก่ -

  • Auditing
  • การพัฒนามาตรฐานและแนวปฏิบัติ
  • การผลิตรายงาน
  • การทบทวนระบบคุณภาพ

ปัจจัยด้านคุณภาพ

  • Correctness - ความถูกต้องเป็นตัวกำหนดว่าตรงตามข้อกำหนดของซอฟต์แวร์หรือไม่

  • Usability - ความสามารถในการใช้งานเป็นตัวกำหนดว่าซอฟต์แวร์สามารถใช้กับผู้ใช้ประเภทต่างๆได้หรือไม่ (ผู้เริ่มต้นผู้ไม่ใช้เทคนิคและผู้เชี่ยวชาญ)

  • Portability - ความสามารถในการพกพาเป็นตัวกำหนดว่าซอฟต์แวร์สามารถทำงานในแพลตฟอร์มต่างๆด้วยอุปกรณ์ฮาร์ดแวร์ที่แตกต่างกันได้หรือไม่

  • Maintainability - การบำรุงรักษาเป็นตัวกำหนดความสะดวกในการแก้ไขข้อผิดพลาดและสามารถอัปเดตโมดูลได้

  • Reusability - ความสามารถในการนำกลับมาใช้ใหม่กำหนดว่าโมดูลและคลาสสามารถนำกลับมาใช้เพื่อพัฒนาผลิตภัณฑ์ซอฟต์แวร์อื่น ๆ ได้หรือไม่

เมตริกเชิงวัตถุ

เมตริกสามารถแบ่งออกเป็นสามประเภทอย่างกว้าง ๆ ได้แก่ เมตริกโครงการเมตริกผลิตภัณฑ์และเมตริกกระบวนการ

เมตริกโครงการ

Project Metrics ช่วยให้ผู้จัดการโครงการซอฟต์แวร์สามารถประเมินสถานะและประสิทธิภาพของโครงการที่กำลังดำเนินอยู่ เมตริกต่อไปนี้เหมาะสำหรับโครงการซอฟต์แวร์เชิงวัตถุ -

  • จำนวนสคริปต์สถานการณ์
  • จำนวนคลาสที่สำคัญ
  • จำนวนคลาสการสนับสนุน
  • จำนวนระบบย่อย

เมตริกผลิตภัณฑ์

เมตริกผลิตภัณฑ์จะวัดคุณลักษณะของผลิตภัณฑ์ซอฟต์แวร์ที่ได้รับการพัฒนา เมตริกผลิตภัณฑ์ที่เหมาะสำหรับระบบเชิงวัตถุ ได้แก่ -

  • Methods per Class- กำหนดความซับซ้อนของคลาส หากถือว่าเมธอดทั้งหมดของคลาสมีความซับซ้อนเท่า ๆ กันคลาสที่มีเมธอดมากกว่านั้นจะซับซ้อนกว่าและทำให้เกิดข้อผิดพลาดได้ง่ายขึ้น

  • Inheritance Structure- ระบบที่มีโครงร่างการสืบทอดขนาดเล็กหลายแบบมีโครงสร้างที่ดีกว่าระบบที่มีช่องตาข่ายการสืบทอดขนาดใหญ่เพียงช่องเดียว ตามกฎทั่วไปต้นไม้มรดกไม่ควรมีจำนวนเลเวลมากกว่า 7 (± 2) และต้นไม้ควรมีความสมดุล

  • Coupling and Cohesion - โมดูลที่มีการเชื่อมต่อต่ำและการเชื่อมต่อกันสูงได้รับการพิจารณาว่าได้รับการออกแบบที่ดีกว่าเนื่องจากอนุญาตให้ใช้ซ้ำและบำรุงรักษาได้มากขึ้น

  • Response for a Class - วัดประสิทธิภาพของเมธอดที่เรียกใช้โดยอินสแตนซ์ของคลาส

เมตริกกระบวนการ

เมตริกของกระบวนการช่วยในการวัดประสิทธิภาพของกระบวนการ จะถูกรวบรวมในทุกโครงการในช่วงเวลาอันยาวนาน ใช้เป็นตัวบ่งชี้สำหรับการปรับปรุงกระบวนการซอฟต์แวร์ในระยะยาว เมตริกกระบวนการบางอย่าง ได้แก่ -

  • จำนวน KLOC (รหัสกิโลบรรทัด)
  • ประสิทธิภาพในการกำจัดข้อบกพร่อง
  • จำนวนความล้มเหลวโดยเฉลี่ยที่ตรวจพบระหว่างการทดสอบ
  • จำนวนข้อบกพร่องแฝงต่อ KLOC