यूनिटटेस्ट फ्रेमवर्क - Doctest

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

निम्नलिखित परिदृश्यों में Doctest बहुत उपयोगी हो सकता है -

  • यह जाँचने के लिए कि मॉड्यूल के डॉकस्ट्रिंग्स यह सत्यापित करके अद्यतित हैं कि सभी इंटरैक्टिव उदाहरण अभी भी दस्तावेज के रूप में काम करते हैं।

  • प्रतीकात्मक परीक्षण करने के लिए परीक्षण फ़ाइल या परीक्षण ऑब्जेक्ट से इंटरएक्टिव उदाहरणों की अपेक्षा के अनुसार काम करें।

  • पैकेज के लिए ट्यूटोरियल प्रलेखन लिखने के लिए, इनपुट-आउटपुट उदाहरणों के साथ उदारतापूर्वक सचित्र

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

डॉकस्ट्रिंग के अंदर पायथन कोड के विभिन्न हिस्सों का उदाहरण उपयोग करना एक सामान्य अभ्यास है। सिद्धांत मॉड्यूल यह सत्यापित करने की अनुमति देता है कि ये डॉकस्ट्रिंग्स कोड में आंतरायिक संशोधनों के साथ अद्यतित हैं।

निम्नलिखित कोड में, एक फैक्टरियल फ़ंक्शन को उदाहरण उपयोग के साथ प्रतिच्छेदित परिभाषित किया गया है। उदाहरण का उपयोग सही होने पर सत्यापित करने के लिए, टेस्टमॉड () फ़ंक्शन को डॉक्टेस्ट मॉड्यूल में कॉल करें।

"""
This is the "example" module.

The example module supplies one function, factorial(). For example,

>>> factorial(5)
120
"""

def factorial(x):
   """Return the factorial of n, an exact integer >= 0.
   >>> factorial(-1)
   Traceback (most recent call last):
      ...
   ValueError: x must be >= 0
   """
   
   if not x >= 0:
      raise ValueError("x must be >= 0")
   f = 1
   for i in range(1,x+1):
      f = f*i
   return f
   
if __name__ == "__main__":
   import doctest
   doctest.testmod()

उपरोक्त स्क्रिप्ट को FactDocTest.py के रूप में दर्ज करें और सहेजें और कमांड लाइन से इस स्क्रिप्ट को निष्पादित करने का प्रयास करें।

Python FactDocTest.py

जब तक उदाहरण विफल नहीं होता कोई आउटपुट नहीं दिखाया जाएगा। अब, कमांड लाइन को निम्न में बदलें -

Python FactDocTest.py –v

कंसोल अब निम्न आउटपुट दिखाएगा -

C:\Python27>python FactDocTest.py -v
Trying:
   factorial(5)
Expecting:
   120
ok
Trying:
   factorial(-1)
Expecting:
   Traceback (most recent call last):
      ...
   ValueError: x must be >= 0
ok
2 items passed all tests:
   1 tests in __main__
   1 tests in __main__.factorial
2 tests in 2 items.
2 passed and 0 failed.
Test passed.

यदि दूसरी ओर, फैक्टरियल कोड () फ़ंक्शन डॉकस्ट्रिंग में अपेक्षित परिणाम नहीं देता है, तो विफलता परिणाम प्रदर्शित किया जाएगा। उदाहरण के लिए, उपरोक्त स्क्रिप्ट में f = 1 के स्थान पर f = 2 बदलें और फिर से doctest चलाएं। परिणाम इस प्रकार होगा -

Trying:
   factorial(5)
Expecting:
   120
**********************************************************************
File "docfacttest.py", line 6, in __main__
Failed example:
factorial(5)
Expected:
   120
Got:
   240
Trying:
   factorial(-1)
Expecting:
   Traceback (most recent call last):
      ...
   ValueError: x must be >= 0
ok
1 items passed all tests:
   1 tests in __main__.factorial
**********************************************************************
1 items had failures:
   1 of 1 in __main__
2 tests in 2 items.
1 passed and 1 failed.
***Test Failed*** 1 failures.

सिद्धांत: पाठ फ़ाइल में उदाहरणों की जाँच करना

सिद्धांत का एक और सरल अनुप्रयोग एक पाठ फ़ाइल में इंटरैक्टिव उदाहरणों का परीक्षण कर रहा है। यह टेस्टफाइल () फ़ंक्शन के साथ किया जा सकता है।

निम्न पाठ को 'example.txt' नामक पाठ फ़ाइल में संग्रहीत किया जाता है।

Using ''factorial''
-------------------
This is an example text file in reStructuredText format. First import
''factorial'' from the ''example'' module:
   >>> from example import factorial
Now use it:
   >>> factorial(5)
   120

फ़ाइल सामग्री को डॉकस्ट्रिंग के रूप में माना जाता है। पाठ फ़ाइल में उदाहरणों को सत्यापित करने के लिए, doctest मॉड्यूल के टेस्टफाइल () फ़ंक्शन का उपयोग करें।

def factorial(x):
   if not x >= 0:
      raise ValueError("x must be >= 0")
   f = 1
   for i in range(1,x+1):
      f = f*i
   return f
   
if __name__ == "__main__":
   import doctest
   doctest.testfile("example.txt")
  • जब तक एक उदाहरण विफल नहीं होता है तब तक टेस्टमॉड (), टेस्टफाइल () कुछ भी प्रदर्शित नहीं करेगा। यदि कोई उदाहरण विफल होता है, तो विफलता का उदाहरण (ओं) और विफलता के कारण (ओं) को सांत्वना के लिए मुद्रित किया जाता है, टेस्टमॉड () के समान प्रारूप का उपयोग करते हुए।

  • ज्यादातर मामलों में एक इंटरैक्टिव कंसोल सत्र की प्रतिलिपि-और-पेस्ट ठीक काम करता है, लेकिन सिद्धांत किसी भी विशिष्ट पायथन शेल का सटीक अनुकरण करने की कोशिश नहीं कर रहा है।

  • किसी भी अपेक्षित आउटपुट को तुरंत अंतिम '>>>' या '...' लाइन का पालन करना चाहिए जिसमें कोड शामिल है, और अपेक्षित आउटपुट (यदि कोई हो) अगले '>>>' या सभी व्हाट्सएप लाइन तक फैला हुआ है।

  • अपेक्षित आउटपुट में ऑल-व्हाट्सएप लाइन नहीं हो सकती है, क्योंकि अपेक्षित आउटपुट के अंत को संकेत देने के लिए ऐसी लाइन ली जाती है। यदि अपेक्षित आउटपुट में एक रिक्त रेखा होती है, तो अपने स्थान पर <BLANKLINE> को अपने उदाहरण में रखें, प्रत्येक स्थान पर एक रिक्त पंक्ति अपेक्षित है।