यूनिटटेस्ट फ्रेमवर्क - डक्टेस्ट एपीआई
सिद्धांत एपीआई निम्नलिखित दो कंटेनर कक्षाओं के आसपास घूमता है, जिनका उपयोग डॉकस्ट्रिंग्स से इंटरैक्टिव उदाहरणों को संग्रहीत करने के लिए किया जाता है -
Example - एक एकल पायथन स्टेटमेंट, इसके अपेक्षित आउटपुट के साथ जोड़ा गया।
DocTest - उदाहरणों का एक संग्रह, आमतौर पर एक एकल डॉकस्ट्रिंग या एक पाठ फ़ाइल से निकाला जाता है।
निम्नलिखित अतिरिक्त प्रसंस्करण वर्गों को परिभाषित, पार्स और रन करने के लिए परिभाषित किया गया है, और doctest उदाहरणों की जांच करें -
DocTestFinder - दिए गए मॉड्यूल में सभी डॉकस्ट्रिंग्स को ढूँढता है, और प्रत्येक डॉकस्ट्रिंग से एक डॉकटेस्ट बनाने के लिए DocTestParser का उपयोग करता है जिसमें इंटरैक्टिव उदाहरण होते हैं।
DocTestParser - एक स्ट्रिंग से एक doctest ऑब्जेक्ट बनाता है (जैसे कि ऑब्जेक्ट का डॉकस्ट्रिंग)।
DocTestRunner - एक सिद्धान्त में उदाहरणों को निष्पादित करता है, और उनके आउटपुट को सत्यापित करने के लिए एक OutputChecker का उपयोग करता है।
OutputChecker - अपेक्षित आउटपुट के साथ एक वास्तविक उदाहरण से वास्तविक आउटपुट की तुलना करता है, और यह तय करता है कि क्या वे मेल खाते हैं।
DocTestFinder वर्ग
यह एक प्रोसेसिंग क्लास है जिसका उपयोग उन सिद्धांतों को निकालने के लिए किया जाता है जो किसी दिए गए ऑब्जेक्ट से संबंधित हैं, इसके डॉकस्ट्रिंग और इसके निहित ऑब्जेक्ट्स के डॉकस्ट्रिंग्स से। वर्तमान में सिद्धांत निम्नलिखित वस्तु प्रकारों से निकाले जा सकते हैं - मॉड्यूल, फ़ंक्शंस, क्लासेस, विधियाँ, staticmethods, classmethods, और गुण।
यह वर्ग खोज () विधि को परिभाषित करता है। यह DocTests की एक सूची देता है जो कि ऑब्जेक्ट के डॉकस्ट्रिंग द्वारा परिभाषित किया गया है , या इसके किसी भी निहित ऑब्जेक्ट के डॉकस्ट्रिंग्स द्वारा।
DocTestParser वर्ग
यह एक प्रसंस्करण वर्ग है जो एक स्ट्रिंग से इंटरैक्टिव उदाहरण निकालने के लिए उपयोग किया जाता है, और उनका उपयोग डॉकटेस्ट ऑब्जेक्ट बनाने के लिए किया जाता है। यह वर्ग निम्नलिखित विधियों को परिभाषित करता है -
get_doctest() - दिए गए तार से सभी सिद्धांत उदाहरण निकालें, और उन्हें एक में इकट्ठा करें DocTest वस्तु।
get_examples(string[, name]) - दिए गए तार से सभी सिद्धांत उदाहरण निकालें, और उन्हें सूची के रूप में वापस करें Exampleवस्तुओं। लाइन नंबर 0-आधारित हैं। वैकल्पिक तर्क नाम इस स्ट्रिंग की पहचान करने वाला नाम है, और इसका उपयोग केवल त्रुटि संदेशों के लिए किया जाता है।
parse(string[, name]) - दिए गए स्ट्रिंग को उदाहरणों और हस्तक्षेप करने वाले पाठ में विभाजित करें, और उन्हें वैकल्पिक की सूची के रूप में वापस करें Examplesऔर तार। के लिए लाइन नंबरExamples0-आधारित हैं। वैकल्पिक तर्क नाम इस स्ट्रिंग की पहचान करने वाला नाम है, और इसका उपयोग केवल त्रुटि संदेशों के लिए किया जाता है।
DocTestRunner क्लास
यह एक प्रोसेसिंग क्लास है जिसका उपयोग डॉकटेस्ट में इंटरेक्टिव उदाहरणों को निष्पादित और सत्यापित करने के लिए किया जाता है। इसमें निम्नलिखित विधियों को परिभाषित किया गया है -
report_start ()
रिपोर्ट करें कि परीक्षण धावक दिए गए उदाहरण को संसाधित करने वाला है। उपवर्गों को अनुमति देने के लिए यह विधि प्रदान की जाती हैDocTestRunnerउनके उत्पादन को अनुकूलित करने के लिए; इसे सीधे नहीं कहा जाना चाहिए
report_success ()
रिपोर्ट करें कि दिया गया उदाहरण सफलतापूर्वक चला। यह विधि DocTestRunner के उपवर्गों को उनके आउटपुट को अनुकूलित करने की अनुमति देने के लिए प्रदान की जाती है; इसे सीधे नहीं कहा जाना चाहिए।
report_failure ()
रिपोर्ट करें कि दिया गया उदाहरण विफल रहा। उपवर्गों को अनुमति देने के लिए यह विधि प्रदान की जाती हैDocTestRunnerउनके उत्पादन को अनुकूलित करने के लिए; इसे सीधे नहीं कहा जाना चाहिए।
report_unexpected_exception ()
रिपोर्ट करें कि दिए गए उदाहरण ने एक अप्रत्याशित अपवाद उठाया। यह विधि DocTestRunner के उपवर्गों को उनके आउटपुट को अनुकूलित करने की अनुमति देने के लिए प्रदान की जाती है ; इसे सीधे नहीं कहा जाना चाहिए।
चालू परीक्षण)
में उदाहरण चलाने के परीक्षण (एक DocTest वस्तु), और लेखक समारोह का उपयोग कर परिणाम प्रदर्शित बाहर ।
संक्षेप में प्रस्तुत ([वर्बोज़])
इस DocTestRunner द्वारा चलाए गए सभी परीक्षण मामलों का एक सारांश प्रिंट करें, और एक नामित tuple TestResults (विफल, प्रयास) लौटाएं । वैकल्पिक वर्बोज़ तर्क यह नियंत्रित करता है कि सारांश कितना विस्तृत है। यदि वर्बोसिटी निर्दिष्ट नहीं है, तो DocTestRunner की वर्बोसिटी का उपयोग किया जाता है।
आउटपुटचैकर क्लास
इस वर्ग का उपयोग यह जांचने के लिए किया जाता है कि क्या एक वास्तविक उदाहरण से वास्तविक आउटपुट अपेक्षित आउटपुट से मेल खाता है।
इस वर्ग में निम्नलिखित विधियां परिभाषित की गई हैं -
check_output ()
वापसी Trueअगर एक उदाहरण से वास्तविक उत्पादन ( मिल उम्मीद निर्गम (के साथ मैच) करना चाहते हैं )। इन तारों को हमेशा मिलान करने के लिए माना जाता है यदि वे समान हैं; लेकिन परीक्षण धावक किस विकल्प के झंडे का उपयोग कर रहा है, इसके आधार पर, कई गैर-सटीक मिलान प्रकार भी संभव हैं। विकल्प झंडे के बारे में अधिक जानकारी के लिए अनुभाग विकल्प झंडे और निर्देश देखें ।
output_difference ()
दिए गए उदाहरण ( उदाहरण ) और वास्तविक आउटपुट ( प्राप्त ) के लिए अपेक्षित आउटपुट के बीच के अंतर का वर्णन करते हुए एक स्ट्रिंग लौटें ।
DocTest एकता के साथ एकीकरण
Doctest मॉड्यूल दो फ़ंक्शन प्रदान करता है जिसका उपयोग मॉड्यूल से पाठ और फ़ाइलों से रहित परीक्षण सुइट्स बनाने के लिए किया जा सकता है। बिना जांच परख के एकीकृत करने के लिए, अपने परीक्षण मॉड्यूल में लोड_टैस्ट () फ़ंक्शन शामिल करें -
import unittest
import doctest
import doctestexample
def load_tests(loader, tests, ignore):
tests.addTests(doctest.DocTestSuite(doctestexample))
return tests
यूनिस्टेस्ट के साथ-साथ सिद्धांत से संयुक्त टेस्टसुइट का गठन किया जाएगा और अब इसे यूनिस्टेस्ट मॉड्यूल के मुख्य () विधि या रन () विधि द्वारा निष्पादित किया जा सकता है।
बनाने के लिए निम्नलिखित दो मुख्य कार्य हैं unittest.TestSuite सिद्धांतों के साथ पाठ फ़ाइलों और मॉड्यूल से उदाहरण -
doctest.DocFileSuite ()
यह एक या एक से अधिक पाठ फ़ाइलों से doctest परीक्षणों को परिवर्तित करने के लिए उपयोग किया जाता है unittest.TestSuite। लौटाया गया unittest.TestSuite को unittest फ्रेमवर्क द्वारा चलाया जाना है और प्रत्येक फ़ाइल में इंटरेक्टिव उदाहरण चलाता है। यदि किसी फ़ाइल में कोई उदाहरण विफल रहता है, तो संश्लेषित इकाई परीक्षण विफल हो जाता है, और एfailureException अपवाद को फ़ाइल का नाम दिखाया गया है जिसमें परीक्षण और (कभी-कभी अनुमानित) पंक्ति संख्या होती है।
doctest.DocTestSuite ()
इसका उपयोग मॉड्यूल के लिए doctest परीक्षणों को a में बदलने के लिए किया जाता है unittest.TestSuite।
लौटाया गया unittest.TestSuite को unittest ढांचे द्वारा चलाया जाना है और मॉड्यूल में प्रत्येक सिद्धांत को चलाता है। यदि कोई सिद्धांत विफल हो जाता है, तो संश्लेषित इकाई परीक्षण विफल हो जाता है, और एfailureException अपवाद को फ़ाइल का नाम दिखाया गया है जिसमें परीक्षण और (कभी-कभी अनुमानित) पंक्ति संख्या होती है
कवर के तहत, DocTestSuite () एक बनाता है unittest.TestSuite doctest.DocTestCase उदाहरणों में से, और DocTestCase unittest.TestCase का एक उपवर्ग है।
इसी तरह, DocFileSuite () एक unittest.TestSuite को doctest.DocFileCase उदाहरणों से बाहर बनाता है, और DocFileCase DocTestCase का एक उपवर्ग है।
तो दोनों के एक unittest.TestSuite रन बनाने के तरीके DocTestCase के उदाहरण। जब आप स्वयं doctest फ़ंक्शंस चलाते हैं, तो आप सीधे doctest फ़ंक्शंस को फ़ोकस करके doctest फ़ंक्शंस को नियंत्रित कर सकते हैं।
हालाँकि, यदि आप एक unitest फ्रेमवर्क लिख रहे हैं, तो unitest अंततः नियंत्रित करता है कि परीक्षण कब और कैसे चलते हैं। फ्रेमवर्क लेखक आम तौर पर doctest रिपोर्टिंग विकल्पों को नियंत्रित करना चाहता है (शायद, उदाहरण के लिए, कमांड लाइन विकल्पों द्वारा निर्दिष्ट), लेकिन एकतरफा परीक्षण करने वालों के लिए unittest के माध्यम से विकल्पों को पारित करने का कोई तरीका नहीं है।