इकाई परीक्षण

कंप्यूटर प्रोग्रामिंग में, इकाई परीक्षण एक सॉफ्टवेयर परीक्षण पद्धति है, जिसके द्वारा स्रोत कोड की भिन्न -भिन्न इकाइयां या कंप्यूटर प्रोग्राम मॉड्यूलर प्रोग्रामिंग के साथ -साथ संबंधित नियंत्रण डेटा ,उपयोग प्रक्रिया, और संचालन प्रक्रियाओं के साथ-साथ यह निर्धारित करने के लिए परीक्षण किया जाता है,कि वे उपयोग के योग्य हैं या नही।

इतिहास
इकाई परीक्षण से पहले कैप्चर और रीप्ले परीक्षण उपकरणों,आदर्श थे। 1997 में, केंट बेक और एरिक गामा ने JUnit को विकसित और प्रारंभ किया।इकाई टेस्ट फ्रेमवर्क जो  जावा डेवलपर्स के सापेक्ष लोकप्रिय हुआ। गूगल ने 2005-2006 के आसपास स्वचालित परीक्षण को अपनाया।

विवरण
इकाई परीक्षण समान्यतया सॉफ्टवेयर डेवलपर द्वारा लिखित और चलाए जाने वाले स्वचालित परीक्षण होते हैं, अतएव यह सुनिश्चित किया जा सके कि किसी एप्लिकेशन का एक भाग अपने सॉफ्टवेर प्रारूप को पूर्ण करता है और इच्छित व्यवहार करता है। एक इकाई प्रक्रियात्मक प्रोग्रामिंग में, एक संपूर्ण मॉड्यूल में हो सकती है, परंतु यह समान्यतया एक व्यक्तिगत कार्य या प्रक्रिया है। एक इकाई वस्तु-उन्मुख प्रोग्रामिंग में, प्रायः एक संपूर्ण इंटरफ़ेस होती है, जैसे कि एक क्लास या व्यक्तिगत विधि होती हैं। सबसे छोटी परीक्षण योग्य इकाइयों के लिए पहले परीक्षण लिखकर पुनः उन दोनों के मध्य मिश्रित टेस्ट, जटिल एप्लीकेशन के लिए व्यापक परीक्षण बना सकते हैं।

उत्पन्न होने वाली समस्याओं को पृथक करने के लिए, प्रत्येक परीक्षण स्थिति का स्वतंत्र रूप से परीक्षण किया जाना चाहिए। मेथड स्टब्स,, मॉक ऑब्जेक्ट्स,फेक और टेस्ट हार्नेस जैसे सब्स्टीट्यूट्स का उपयोग पृथक्करण में मॉड्यूल के परीक्षण में सहायता के लिए किया जा सकता है।।

विकास के दौरान, एक सॉफ्टवेयर डेवलपर को इकाई की शुद्धता को सत्यापित करने के लिए परीक्षण में मापदंड, या परिणाम जो सही माने जाते हैं, उसको कोड कर सकता है। टेस्ट केस एक्जीक्यूशन के दौरान, फ्रेमवर्क कंप्यूटर डेटा लॉगिंग टेस्ट जो प्रत्येक मानदंड को विफल कर सकते हैं तथा फ्रेमवर्क कंप्यूटर डेटा लॉगिंग को संक्षेप में रिपोर्ट करते हैं।टेस्ट-फंक्शन-एक्सपेक्टेड वैल्यू अधिकतम उपयोग किया जाने वाला विधि है।

इकाई परीक्षणों को लिखना और बनाए रखना पैरामीटरयुक्त परीक्षण का उपयोग द्वारा तीव्रता से बनाया जा सकता है। यह विभिन्न इनपुट सेटों के सापेक्ष एक परीक्षण को कई बार निष्पादित करने की अनुमति देता हैं, इस प्रकार परीक्षण कोड दोहराव को न्यूनतम करते हैं। पारंपरिक इकाई परीक्षणों के विपरीत, जो समान्यतया बंद विधि हैं तथा अपरिवर्तनीय स्थितियों का परीक्षण करता हैं, पैरामीटरयुक्त परीक्षण के प्रत्येक पैरामीटर सेट कर लेते हैं। पैरामीटरयुक्त परीक्षण टेस्टNG, JUnit और इसके .नेट काउंटरपार्ट, XUnit द्वारा समर्थित हैं। इकाई परीक्षणों के लिए उपयुक्त पैरामीटर मैन्युअल रूप से आपूर्ति किए जा सकते हैं या कुछ घटनाओं में परीक्षण ढांचे के द्वारा स्वचालित रूप से उत्पन्न होते हैं। कुछ वर्षों में अधिक शक्तिशाली परीक्षण लिखने, सिद्धांतों की अवधारणा का लाभ उठाने, समान चरणों को निष्पादित करने वाले परीक्षण घटनाओं के लिए समर्थन भेजा गया था, परंतु रनटाइम पर उत्पन्न परीक्षण डेटा का उपयोग करते हुए, नियमित पैरामीटरयुक्त परीक्षणों के विपरीत, जो इनपुट सेट के सापेक्ष समान निष्पादन चरणों का उपयोग करते हैं जो पूर्व निर्धारित हैं।

लाभ
इकाई परीक्षण का लक्ष्य कार्यक्रम के प्रत्येक भाग को पृथक करना है और यह दर्शाना है कि भिन्न -भिन्न अंग सही हैं। एक इकाई परीक्षण अनुबंध द्वारा एक सख्त, लिखित प्रारूप प्रदान करता है जो कोड के हिस्से को संतुष्ट करना चाहिए। फलस्वरूप, यह कई लाभ प्रदान करता है।

इकाई परीक्षण विकास चक्र के प्रारंभिक समस्याओं का पता लगाता है।प्रोग्रामर के कार्यान्वयन में बग और इकाई के लिए विनिर्देश के दोष या अनुपस्थित हिस्से दोनों सम्मिलित हैं। परीक्षणों का एक संपूर्ण सेट लिखने की प्रक्रिया लेखक को इनपुट, आउटपुट और त्रुटि स्थितियों के माध्यम से सोचने के लिए मजबूर करती है, और इस प्रकार इकाई के वांछित व्यवहार को और अधिक स्पष्ट रूप से परिभाषित करती है। कोडिंग प्रारंभ होने से पहले बग को खोजने की लागत या जब कोड पहली बार लिखा जाता है,तो बग का पता लगाने, पहचानने और ठीक करने की लागत से अत्यधिक न्यूनतम होता है।अंतिम उपयोगकर्ताओं के लिए जारी किए गए कोड में भी बग सॉफ़्टवेयर के महंगी समस्याएँ उत्पन्न कर सकते हैं।  खराब लिखे जाने पर इकाई परीक्षण के लिए कोड असंभव या कठिन हो सकता है, इस प्रकार इकाई परीक्षण डेवलपर्स को उन्नति विधि से संरचना कार्यों और वस्तुओं के लिए मजबूर कर सकता है।

परीक्षण-संचालित विकास (टीडीडी) में, जो प्रायः एक्सट्रीम कार्यक्रम और स्क्रम (सॉफ्टवेयर विकास) दोनों में उपयोग किया जाता है, इसमें कोड लिखे जाने से पहले इकाई परीक्षण बनाए जाते हैं। जब परीक्षण पास हो जाते हैं, तो वह कोड पूर्ण माना जाता है। उसी इकाई परीक्षण को उस फ़ंक्शन के विरुद्ध  प्रायः चलाया जाता है क्योंकि बड़ा कोड बेस विकसित होता है या तो कोड को परवर्तित कर दिया जाता है या स्वचालित प्रक्रिया के माध्यम से निर्माण किया जाता हैं। यदि इकाई परीक्षण विफल हो जाते हैं, तो इसे या तो परवर्तित हुए कोड में या स्वयं परीक्षणों में बग माना जाता है। इकाई परीक्षण त्रुटि या विफलता के स्थान को आसानी से पता लगाने की अनुमति देता है। क्योंकि इकाई परीक्षण समस्या के विकास दल को परीक्षकों या ग्राहकों को कोड सौंपने से पहले सचेत करता है, संभावित समस्याओं को विकास प्रक्रिया में शीघ्र ढुंढ लिया जाता है।

इकाई परीक्षण प्रोग्रामर को उपरांत दिनाक में पुनर्रचना कोड या प्रणाली लाइब्रेरी को अपग्रेड करने की अनुमति देता है, और यह सुनिश्चित करता है कि मॉड्यूल अभी भी सही विधि से कार्य करता है (उदाहरण के लिए, प्रतिगमन परीक्षण में)।सभी प्रक्रिया कार्यों और विधियों के लिए परीक्षण परिस्थितियों लिखने के लिए है अतएव जब भी कोई परिवर्तन त्रुटि का कारण बनता है, तो इसे शीघ्र से पहचाना जा सके। इकाई परीक्षण उन परिवर्तनों का पता लगाते हैं जो अनुबंध द्वारा प्रारूप को तोड़ सकते हैं।

स्वयं इकाई परीक्षण इकाइयों में अनिश्चितता को न्यूनतम कर सकता है और टॉप-डाउन और बॉटम-अप प्रारूप का उपयोग बॉटम-अप परीक्षण शैली दृष्टिकोण में किया जा सकता है। किसी प्रोग्राम के भागों का पहले परीक्षण करके और पुनः उसके भागों के योग का परीक्षण करके, एकीकरण परीक्षण बहुत आसान हो जाता है।

इकाई परीक्षण प्रणाली का एक प्रकार का वर्तमान दस्तावेज प्रदान करता है। इकाई द्वारा कौन सी कार्यक्षमता प्रदान की जाती है, और इसका उपयोग कैसे करना है, यह जानने के इच्छुक डेवलपर्स इकाई के इंटरफ़ेस (एप्लीकेशन प्रोग्रामिंग अंतरफलक) की बुनियादी समझ हासिल करने के लिए इकाई परीक्षण को देख सकते हैं।

इकाई परीक्षण के स्थिति उन विशेषताओं को सम्मिलित करते हैं जो इकाई की सफलता के लिए महत्वपूर्ण हैं। ये विशेषताएँ एक इकाई के उचित/अनुचित उपयोग के साथ-साथ नकारात्मक व्यवहारों को इंगित कर सकती हैं जिन्हें इकाई द्वारा फंसाया जाना है। इकाई परीक्षण स्थिति, अपने आप में, इन महत्वपूर्ण विशेषताओं को प्रलेखित करता है, यद्यपि कई सॉफ्टवेयर विकास वातावरण विकास में उत्पाद को प्रलेखित करने के लिए केवल कोड पर निर्भर नहीं होते हैं।

जब परीक्षण-संचालित दृष्टिकोण का उपयोग करके सॉफ़्टवेयर विकसित किया जाता है, तो इंटरफ़ेस निर्दिष्ट करने के लिए इकाई टेस्ट लिखने का संयोजन और परीक्षण पारित होने के उपरांत की गई रीफैक्टरिंग गतिविधियां औपचारिक प्रारूप का स्थान ले सकती हैं। प्रत्येक इकाई परीक्षण को क्लासेस विधियों और अवलोकनीय व्यवहार को निर्दिष्ट करने वाले एक प्रारूप तत्व के रूप में दर्शाया जा सकता है।

सीमाएं और त्रुटि
परीक्षण कार्यक्रम में हर त्रुटि को नहीं पकड़ेगा, क्योंकि यह प्रत्येक निष्पादन पथ का मूल्यांकन नहीं कर सकता है परंतु सबसे निरर्थक कार्यक्रम है। यह निर्णय समस्या हॉल्टिंग समस्या का सुपरसेट है, जो कि अनिर्णीत समस्या है। इकाई परीक्षण के लिए भी यही सत्य है। इसके अतिरिक्त, परिभाषा के अनुसार इकाई परीक्षण केवल स्वयं इकाइयों की कार्यक्षमता का परीक्षण करता है। इसलिए, यह एकीकरण त्रुटियों या व्यापक प्रणाली-स्तरीय त्रुटियों को नहीं पकड़ेगा। इकाई परीक्षण अन्य सॉफ्टवेयर परीक्षण गतिविधियों के संयोजन में किया जाना चाहिए, क्योंकि वे केवल विशेष त्रुटियों की उपस्थिति या अनुपस्थिति दर्शा सकते हैं; वे त्रुटियों के पूर्ण अभाव को प्रमाणित नहीं कर सकते। प्रत्येक निष्पादन पथ और हर संभव इनपुट के लिए सही व्यवहार की गारंटी देने के लिए, और त्रुटियों की अनुपस्थिति को सुनिश्चित करने के लिए, अन्य तकनीकों की आवश्यकता होती है, अर्थात् यह प्रमाणित करने के लिए औपचारिक विधि का अनुप्रयोग कि सॉफ़्टवेयर घटक में कोई अप्रत्याशित व्यवहार नहीं है।

इकाई परीक्षणों का एक विस्तृत पदानुक्रम एकीकरण परीक्षण के समान नहीं है। परिधीय इकाइयों के सापेक्ष एकीकरण को एकीकरण परीक्षणों में सम्मिलित किया जाना चाहिए, परंतु इकाई परीक्षणों में नहीं। एकीकरण परीक्षण समान्यतयया अभी भी मैन्युअल रूप से मानव परीक्षण पर अत्यधिक निर्भर करता है; उच्च-स्तरीय या वैश्विक-दायरे के परीक्षण को स्वचालित करना कठिन हो सकता है, जैसे मैन्युअल परीक्षण प्रायः तीव्र और सस्ता दिखाई देता है।

सॉफ्टवेयर परीक्षण एक मिश्रित समस्या है। उदाहरण के लिए, प्रत्येक बूलियन निर्णय कथन के लिए न्यूनतम से न्यूनतम दो परीक्षणों की आवश्यकता होती है: एक सत्य परिणाम के सापेक्ष और एक गलत के परिणाम के सापेक्ष होना चाहिए। परिणामस्वरूप, लिखे गए कोड की प्रत्येक पंक्ति के लिए, प्रोग्रामर को प्रायः टेस्ट कोड की 3 से 5 पंक्तियों की आवश्यकता होती है। इसमें स्पष्ट रूप से समय लगता है और निवेश प्रयास के लायक नहीं हो सकता है। ऐसी समस्याएं हैं जिनका आसानी से परीक्षण नहीं किया जा सकता है - उदाहरण के लिए वे जो गैर नियतात्मक एल्गोरिथम हैं या जिसमें कई थ्रेड सम्मिलित हैं। इसके अतिरिक्त, इकाई परीक्षण के लिए कोड उतना ही छोटा होने की संभावना है जितना कोड परीक्षण कर रहा है। द मिथिकल मैन-मंथ में फ्रेड ब्रूक्स उद्धरण: कभी भी दो क्रोनोमीटर के सापेक्ष समुद्र में न जाएं;या तो आप एक क्रोनोमीटर या तीन क्रोनोमीटर लीजिये। अर्थात, अगर दो समुद्री क्रोनोमीटर विरोधाभासी हैं, तो आप कैसे जानेंगे कि कौन सा सही है?

इकाई परीक्षण लिखने से जुड़ी एक अन्य चुनौती यथार्थवादी और उपयोगी परीक्षण स्थापित करने की कठिनाई है। प्रासंगिक प्रारंभिक स्थितियां बनाना आवश्यक है क्योकि परीक्षण किए जा रहे एप्लिकेशन का पूरा हिस्सा प्रणाली के हिस्से की तरह व्यवहार करे। यदि इन प्रारंभिक स्थितियों को सही ढंग से सेट नहीं किया गया है, तो परीक्षण यथार्थवादी संदर्भ में कोड का प्रयोग नहीं करेगा, जो इकाई परीक्षण परिणामों के मूल्य और सटीकता को न्यूनतम कर देता है।

इकाई परीक्षण से इच्छित लाभ प्राप्त करने के लिए, सॉफ्टवेयर विकास प्रक्रिया के दौरान कठोर अनुशासन की आवश्यकता होती है।न केवल किए गए परीक्षणों का सावधानीपूर्वक रिकॉर्ड रखना आवश्यक है, बल्कि इस सॉफ़्टवेयर की किसी अन्य इकाई के स्रोत कोड में किए गए सभी परिवर्तनों का रिकॉर्ड रखना भी आवश्यक है। एक संस्करण नियंत्रण प्रणाली का उपयोग आवश्यक है। यदि इकाई के उपरांत का संस्करण किसी विशेष परीक्षण में विफल रहता है जिसे वह पहले पारित कर चुका था, तो संस्करण-नियंत्रण सॉफ़्टवेयर स्रोत कोड परिवर्तनों की एक सूची प्रदान कर सकता है जो उस समय से इकाई पर लागू किए गए हैं।

यह सुनिश्चित करने के लिए एक स्थायी प्रक्रिया को लागू करना भी आवश्यक है कि परीक्षण न्यूनतम विफलताओं की नियमित रूप से समीक्षा की जाय और तुरंत संबोधित किया जाता है। यदि इस तरह की प्रक्रिया को प्रारंभ नहीं किया जाता है और टीम के वर्कफ़्लो में सम्मिलित हो जाता है, तो एप्लिकेशन इकाई टेस्ट सूट के सापेक्ष सिंक से बाहर हो जाएगा, झूठी सकारात्मकता बढ़ जाएगी और टेस्ट सूट की प्रभावशीलता न्यूनतम हो जाएगी।

इकाई परीक्षण एम्बेडेड प्रणाली सॉफ़्टवेयर एक अनूठी चुनौती प्रस्तुत करता है: क्योंकि सॉफ़्टवेयर को एक पृथक प्लेटफ़ॉर्म पर विकसित किया जा रहा है, जिस पर वह अंततः चलेगा, और आप वास्तविक परिनियोजन वातावरण में एक परीक्षण प्रोग्राम को आसानी से नहीं चला सकते हैं, जैसा कि डेस्कटॉप प्रोग्राम के सापेक्ष संभव है।

इकाई परीक्षण सबसे आसान होते हैं जब किसी विधि में कुछ इनपुट और आउटपुट पैरामीटर होते हैं। इकाई परीक्षण बनाना उतना आसान नहीं है जितना विधि का एक प्रमुख कार्य अनुप्रयोग के लिए किसी बाहरी चीज़ के सापेक्ष सहभागिता करना है। उदाहरण के लिए, एक विधि जो डेटाबेस के सापेक्ष कार्य करेगी, उसे बनाने के लिए डेटाबेस इंटरैक्शन के मॉकअप की आवश्यकता हो सकती है, जो संभवतः वास्तविक डेटाबेस इंटरैक्शन के रूप में व्यापक नहीं होगा।

उदाहरण
यहाँ जावा में परीक्षण स्थिति का एक सेट है जो कार्यान्वयन के कई तत्वों को निर्दिष्ट करता है। सबसे पहले, एडर नामक एक इंटरफ़ेस होना चाहिए, और एक शून्य-तर्क निर्माता के सापेक्ष एक कार्यान्वयन क्लास जिसे AdderImpl कहा जाता है। यह अभिकथन (कंप्यूटिंग) पर जाता है कि योजक इंटरफ़ेस में दो पूर्णांक मापदंडों के सापेक्ष ऐड नामक एक विधि होनी चाहिए, जो एक और पूर्णांक लौटाती है। यह कई परीक्षण विधियों पर मूल्यों की एक छोटी श्रृंखला के लिए इस पद्धति के व्यवहार को भी निर्दिष्ट करता है।

इस स्थिति में इकाई परीक्षण, पहले लिखे जाने के उपरांत, एक वांछित समाधान के रूप और व्यवहार को निर्दिष्ट करने वाला एक प्रारूप दस्तावेज़ के रूप में कार्य करता है, परंतु कार्यान्वयन विवरण नहीं, जो प्रोग्रामर के लिए छोड़ दिया जाता है।सबसे आसान काम करें जो संभवतः काम कर सकता है, अभ्यास के उपरांत,सबसे आसान समाधान जो टेस्ट पास करेगा। नीचे दर्शाया गया है :-

निष्पादन योग्य विनिर्देशों के रूप में
प्रारूप विनिर्देश के रूप में इकाई-टेस्ट का उपयोग करने से अन्य प्रारूप विधियों पर एक महत्वपूर्ण लाभ होता है: प्रारूप दस्तावेज़ का उपयोग कार्यान्वयन को सत्यापित करने के लिए किया जा सकता है। जब तक डेवलपर प्रारूप के अनुसार समाधान लागू नहीं करता तब तक परीक्षण कभी पास नहीं हो सकते हैं।

इकाई परीक्षण में एकीकृत मॉडलिंग भाषा(UML) आरेख जैसे डायग्रामेटिक विनिर्देश की कुछ पहुंच की न्यूनता होती है, परंतु स्वचालित उपकरणों का उपयोग करके इकाई परीक्षण को उत्पन्न कर सकते हैं। अधिकांश आधुनिक भाषाओं में नि: शुल्क उपकरण होते हैं। नि: शुल्क उपकरण, जैसे कि xUnit फ्रेमवर्क, मानव उपभोग के लिए एक दृश्य के ग्राफिकल रेंडरिंग के लिए किसी अन्य प्रणाली के आउटसोर्स का उपयोग करते हैं।

एक्सट्रीम प्रोग्रामिंग
इकाई परीक्षण एक्सट्रीम प्रोग्रामिंग की आधारशिला है इकाई परीक्षण फ्रेमवर्क एक स्वचालित सूची पर निर्भर करता है। यह स्वचालित इकाई परीक्षण फ्रेमवर्क तृतीय पक्ष हो सकता है, उदाहरण के लिए, xUnit, या विकास समूह के अंतर्गत बनाया गया हो।

एक्सट्रीम प्रोग्रामिंग परीक्षण-संचालित विकास के लिए इकाई परीक्षणों के निर्माण का उपयोग करती है। डेवलपर एक इकाई परीक्षण लिखता है जो सॉफ़्टवेयर के आवश्यकता या दोष को उजागर करता है। यह परीक्षण विफल हो सकता है क्योंकि अभी तक आवश्यकताओ कों प्रारंभ नहीं किया गया है, या यह अभिप्रायपूर्वक मौजूदा कोड में एक त्रुटी को उजागर करता है। पुनः, डेवलपर परीक्षण करने के लिए सबसे सरल कोड लिखता है, अन्य परीक्षणों के सापेक्ष,पास करता है।

प्रणाली में अधिकांश कोड इकाई टेस्टेड होते हैं, परंतु कोड के माध्यम से सभी पथ आवश्यक नहीं हैं। एक्सट्रीम प्रोग्रामिंग के लिए हर उस चीज का परीक्षण अनिवार्य है जो संभवतः, पारंपरिक परीक्षण पर प्रत्येक निष्पादन पथ विधि की रणनीति को तोड़ सकती है। यह डेवलपर्स को शास्त्रीय विधि की तुलना में न्यूनतम परीक्षण विकसित करने की ओर ले जाता है, परंतु यह वास्तव में एक समस्या नहीं है, तथ्य की अधिक पुनरावृत्ति है, क्योंकि सभी निष्पादन पथों को पूरी तरह से परीक्षण करने के लिए पारंपरिक विधि का कदाचित ही कभी पर्याप्त रूप से पालन किया गया है। एक्सट्रीम प्रोग्रामिंग केवल यह पहचानती है कि परीक्षण कदाचित ही कभी संपूर्ण होता है (क्योंकि यह आर्थिक रूप से व्यवहार्य होने के लिए प्रायः बहुत महंगा और समय लेने वाला होता है) और सीमित संसाधनों को प्रभावी ढंग से केंद्रित करने के विधि पर मार्गदर्शन प्रदान करता है।

महत्वपूर्ण रूप से, परीक्षण कोड को प्रथम श्रेणी का प्रोजेक्ट आर्टिफैक्ट माना जाता है जिसमें इसे कार्यान्वयन कोड के समान गुणवत्ता पर बनाए रखा जाता है, जिसमें सभी दोहराव हटा दिए जाते हैं। डेवलपर्स इकाई परीक्षण कोड को कोड रिपॉजिटरी में उस कोड के सापेक्ष जारी करते हैं जो वह परीक्षण करता है। एक्सट्रीम प्रोग्रामिंग का पूर्ण इकाई परीक्षण उपरोक्त लाभों की अनुमति देता है, जैसे कि सरल और अधिक विश्वसनीय कोड विकास और रीफैक्टरिंग, सरलीकृत कोड एकीकरण, सटीक प्रलेखन और अधिक मॉड्यूलर प्रारूप इत्यादि। ये इकाई परीक्षण भी प्रतिगमन परीक्षण के रूप में निरंतर चलाए जाते हैं।

इमर्जेंट प्रारूप की अवधारणा के लिए इकाई परीक्षण भी महत्वपूर्ण है। जैसा कि आकस्मिक प्रारूप रिफैक्टरिंग पर अत्यधिक निर्भर है, इकाई परीक्षण एक अभिन्न अंग हैं।

इकाई परीक्षण फ्रेमवर्क
इकाई परीक्षण फ्रेमवर्क प्रायः तीसरे पक्ष के उत्पाद होते हैं जिन्हें कंपाइलर सूट के हिस्से के रूप में वितरित नहीं किया जाता है। वे इकाई परीक्षण फ्रेमवर्क की सूची के लिए विकसित किए जाने के उपरांत इकाई परीक्षण की प्रक्रिया को आसान बनाने में सहायता करते हैं।

क्लाइंट कोड लिखकर एक विशिष्ट ढांचे के समर्थन के बिना इकाई परीक्षण करना सामान्यतया संभव है जो परीक्षण के तहत इकाइयों का प्रयोग करता है और विफलता संकेत करने के लिए अभिकथन (सॉफ्टवेयर विकास), एक्सेप्शन हैंडलिंग, या अन्य नियंत्रण प्रवाह तंत्र का उपयोग करता है। एक ढांचे के बिना इकाई परीक्षण इस मायने में मूल्यवान है, और यही इकाई परीक्षण को अपनाने के लिए प्रवेश में बाधा है; अल्प इकाई परीक्षण होना कदाचित ही कोई नहीं होने से श्रेष्ठतर है, जबकि एक बार एक ढांचा होने के उपरांत, इकाई परीक्षण जोड़ना अपेक्षाकृत आसान हो जाता है। कुछ रूपरेखाओं में कई उन्नत इकाई परीक्षण सुविधाएँ लुप्त हैं या उन्हें हाथ से कोडित किया जाना चाहिए।

भाषा-स्तरीय इकाई परीक्षण समर्थन
कुछ प्रोग्रामिंग लैंग्वेज सीधे इकाई परीक्षण को सपोर्ट करती हैं। उनका व्याकरण पुस्तकालय आयात किए बिना इकाई परीक्षणों की प्रत्यक्ष घोषणा की अनुमति देता है । इसके अतिरिक्त, इकाई परीक्षणों की बूलियन स्थितियों को उसी सिंटैक्स में व्यक्त किया जा सकता है जैसे गैर-इकाई टेस्ट कोड में उपयोग किए जाने वाले बूलियन एक्सप्रेशन, जैसे कि if और while कथनों के लिए क्या उपयोग किया जाता है।

अंतर्निहित इकाई परीक्षण समर्थन करने वाली भाषाओं में सम्मिलित हैं:


 * कोबरा
 * D
 * रस्ट

मानक इकाई परीक्षण ढांचे को समर्थन करने वाली भाषाओं में सम्मिलित हैं:

रेफरी>
 * एपेक्स
 * क्रिस्टल
 * एरलांग
 * गो
 * जूलिया
 * लैब व्यू
 * मतलब
 * पायथन
 * रैकेट
 * रूबी

कुछ भाषाओं में बिल्ट-इन इकाई-परीक्षण सपोर्ट नहीं करता है, परंतु इकाई परीक्षण लाइब्रेरी या फ्रेमवर्क स्थापित हैं। इन भाषाओं में सम्मिलित हैं:


 * एबीएपी
 * सी ++
 * C# (सी शार्प)
 * क्लोजर
 * एलिक्सिर
 * जावा
 * जावास्क्रिप्ट
 * ऑब्जेक्टिव सी
 * पर्ल
 * पीएचपी
 * विंडोज पॉवरशेल


 * R परीक्षण के साथ
 * स्काला
 * टीसीएल
 * विजुअल बेसिक .NET
 * Xojo के साथ XojoUnit

यह भी देखें

 * स्वीकृति परीक्षण
 * लक्षण वर्णन परीक्षण
 * घटक-आधारित उपयोगिता परीक्षण
 * प्रारूप प्रेडीकेटस
 * अनुबंध द्वारा प्रारूप
 * एक्सट्रीम प्रोग्रामिंग
 * क्रियात्मक परीक्षण
 * एकीकरण परीक्षण
 * यूनिट टेस्टिंग फ्रेमवर्क की सूची
 * प्रतिगमन परीक्षण
 * सॉफ्टवेयर पुरातत्व
 * सॉफ़्टवेयर परीक्षण
 * परीक्षण परिस्थिति
 * परीक्षण संचालित विकास
 * xUnit - यूनिट टेस्टिंग फ्रेमवर्क का परिवार।

बाहरी संबंध

 * Test Driven Development (Ward Cunningham's Wiki)