यूनिटटेस्ट फ्रेमवर्क - क्विक गाइड

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

इकाई परीक्षण निम्नलिखित दो तरीकों से किया जा सकता है -

मैनुअल परीक्षण स्वचालित परीक्षण

बिना किसी उपकरण समर्थन के मैन्युअल रूप से परीक्षण मामलों को निष्पादित करना मैन्युअल परीक्षण के रूप में जाना जाता है।

  • चूंकि मानव संसाधन द्वारा परीक्षण मामलों को निष्पादित किया जाता है इसलिए यह बहुत है time consuming and tedious

  • चूंकि परीक्षण मामलों को मैन्युअल रूप से निष्पादित करने की आवश्यकता होती है, इसलिए मैन्युअल परीक्षण में अधिक परीक्षकों की आवश्यकता होती है।

  • यह कम विश्वसनीय है क्योंकि मानव त्रुटियों के कारण हर बार परीक्षण सटीकता के साथ नहीं किए जा सकते हैं।

  • परिष्कृत परीक्षणों को लिखने के लिए कोई प्रोग्रामिंग नहीं की जा सकती है जो छिपी हुई जानकारी प्राप्त करते हैं।

टूल सपोर्ट लेना और स्वचालन टूल का उपयोग करके परीक्षण मामलों को निष्पादित करना स्वचालन परीक्षण के रूप में जाना जाता है।

  • फास्ट ऑटोमेशन मानव संसाधन की तुलना में काफी तेजी से परीक्षण मामलों को चलाता है।

  • investment over human resources is less जैसा कि परीक्षण मामलों को स्वचालन उपकरण का उपयोग करके निष्पादित किया जाता है।

  • स्वचालन परीक्षण हर बार चलने के बाद ठीक उसी ऑपरेशन को करते हैं और are more reliable

  • परीक्षक can program sophisticated tests छिपी जानकारी बाहर लाने के लिए।

JUnit जावा प्रोग्रामिंग लैंग्वेज के लिए एक यूनिट टेस्टिंग फ्रेमवर्क है। JUnit परीक्षण-संचालित विकास के विकास में महत्वपूर्ण रहा है, और इकाई परीक्षण के ढांचे के एक परिवार को सामूहिक रूप से xUnit के रूप में जाना जाता है जो JUnit के साथ उत्पन्न हुआ था। आप यहाँ JUnit ट्यूटोरियल का पता लगा सकते हैं ।

पाइथन यूनिट टेस्टिंग फ्रेमवर्क, जिसे कभी-कभी "PyUnit" कहा जाता है, केंट बेक और एरिच गामा द्वारा विकसित JUnit का पायथन लैंग्वेज संस्करण है। PyUnit Python के मानक पुस्तकालय का हिस्सा है, जो Python संस्करण 2.1 के रूप में है।

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

यह ट्यूटोरियल शुरुआती लोगों के लिए तैयार किया गया है ताकि वे पायथन परीक्षण ढांचे की बुनियादी कार्यक्षमता को समझने में मदद कर सकें। इस ट्यूटोरियल को पूरा करने के बाद आप पायथन परीक्षण ढांचे का उपयोग करने में अपने आप को एक मध्यम स्तर के विशेषज्ञ के रूप में पाएंगे जहां से आप अपने आप को अगले स्तरों पर ले जा सकते हैं।

आपको पायथन भाषा का उपयोग करके सॉफ्टवेयर विकास में उचित विशेषज्ञता होनी चाहिए। पायथन सीखने की शुरुआत करने के लिए हमारा पायथन ट्यूटोरियल एक अच्छी जगह है। सॉफ्टवेयर परीक्षण की मूल बातें का ज्ञान भी वांछनीय है।

पर्यावरण सेटअप

परीक्षण लिखने के लिए आवश्यक कक्षाएं 'यूनीटेस्ट ’मॉड्यूल में पाई जानी हैं। यदि आप पायथन के पुराने संस्करणों (पायथन 2.1 से पहले) का उपयोग कर रहे हैं, तो मॉड्यूल को डाउनलोड किया जा सकता हैhttp://pyunit.sourceforge.net/। हालांकि, unittest मॉड्यूल अब मानक पायथन वितरण का एक हिस्सा है; इसलिए इसे अलग स्थापना की आवश्यकता नहीं है।

'यूनिस्टेस्ट' परीक्षण स्वचालन, परीक्षणों के लिए सेटअप और शटडाउन कोड साझा करने, संग्रह में परीक्षणों के एकत्रीकरण और रिपोर्टिंग ढांचे से परीक्षणों की स्वतंत्रता का समर्थन करता है।

यूनीटेस्ट मॉड्यूल उन कक्षाओं को प्रदान करता है जो परीक्षणों के एक सेट के लिए इन गुणों का समर्थन करना आसान बनाते हैं।

इसे प्राप्त करने के लिए, यूनिटेस्ट निम्नलिखित महत्वपूर्ण अवधारणाओं का समर्थन करता है -

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

  • test case- यह परीक्षण की सबसे छोटी इकाई है। यह इनपुट के एक विशेष सेट के लिए एक विशिष्ट प्रतिक्रिया के लिए जाँच करता है। यूनिस्टेस्ट एक बेस क्लास प्रदान करता है,TestCase, जिसका उपयोग नए परीक्षण मामलों को बनाने के लिए किया जा सकता है।

  • test suite- यह परीक्षण मामलों, परीक्षण सूट, या दोनों का एक संग्रह है। इसका उपयोग कुल परीक्षणों के लिए किया जाता है जिन्हें एक साथ निष्पादित किया जाना चाहिए। टेस्ट सूट को टेस्टसुइट क्लास द्वारा लागू किया जाता है।

  • test runner- यह एक घटक है जो परीक्षणों के निष्पादन को ऑर्केस्ट्रा करता है और उपयोगकर्ता को परिणाम प्रदान करता है। धावक एक ग्राफिकल इंटरफ़ेस, एक टेक्स्ट इंटरफेस का उपयोग कर सकता है, या परीक्षणों को निष्पादित करने के परिणामों को इंगित करने के लिए एक विशेष मान लौटा सकता है।

एक यूनिट टेस्ट बनाना

निम्नलिखित चरण एक सरल इकाई परीक्षण लिखने में शामिल हैं -

Step 1 - अपने कार्यक्रम में सबसे बेकार मॉड्यूल आयात करें।

Step 2- परीक्षण किए जाने वाले फ़ंक्शन को परिभाषित करें। निम्नलिखित उदाहरण में, जोड़ें () फ़ंक्शन को परीक्षण के अधीन किया जाना है।

Step 3 - unittest.TestCase को उपविभाजित करके एक टेस्टकेस बनाएं।

Step 4- परीक्षा को कक्षा के अंदर एक विधि के रूप में परिभाषित करें। विधि का नाम 'परीक्षण' से शुरू होना चाहिए।

Step 5- प्रत्येक परीक्षण TestCase वर्ग के मुखर कार्य को बुलाता है। कई प्रकार के दावे हैं। निम्न उदाहरण कॉल assertEquals () फ़ंक्शन।

Step 6 - assertEquals () फ़ंक्शन arg2 तर्क के साथ ऐड () फ़ंक्शन के परिणाम की तुलना करता है और तुलना के अनुसार जोर देता है।

Step 7 - अंत में, यूनिटेस्ट मॉड्यूल से कॉल मेन () विधि।

import unittest
def add(x,y):
   return x + y
   
class SimpleTest(unittest.TestCase):
   def testadd1(self):
      self.assertEquals(add(4,5),9)
      
if __name__ == '__main__':
   unittest.main()

Step 8 - कमांड लाइन से उपरोक्त स्क्रिप्ट चलाएँ।

C:\Python27>python SimpleTest.py
.
----------------------------------------------------------------------
Ran 1 test in 0.000s
OK

Step 9 - निम्नलिखित तीन एक परीक्षण के संभावित परिणाम हो सकते हैं -

अनु क्रमांक संदेश और विवरण
1

OK

परीक्षा पास हो जाती है। 'ए' कंसोल पर प्रदर्शित होता है।

2

FAIL

परीक्षण पास नहीं करता है, और एक जोर का अपवाद उठाता है। 'एफ' कंसोल पर प्रदर्शित होता है।

3

ERROR

परीक्षण AssertionError के अलावा एक अपवाद को जन्म देता है। 'E' कंसोल पर प्रदर्शित होता है।

ये परिणाम क्रमशः कंसोल पर '।', 'एफ' और 'ई' द्वारा प्रदर्शित किए जाते हैं।

कमांड लाइन इंटरफेस

एकल या एकाधिक परीक्षण चलाने के लिए कमांड लाइन से यूनीटेस्ट मॉड्यूल का उपयोग किया जा सकता है।

python -m unittest test1
python -m unittest test_module.TestClass
python -m unittest test_module.TestClass.test_method

unittest निम्न कमांड लाइन विकल्पों का समर्थन करता है। सभी कमांड लाइन विकल्पों की सूची के लिए, निम्नलिखित कमांड का उपयोग करें -

Python –m unittest -h

अनु क्रमांक विकल्प और विवरण
1

-h, --help

यह संदेश दिखाएं

2

v, --verbose

वाचाल उत्पादन

3

-q, --quiet

न्यूनतम उत्पादन

4

-f, --failfast

पहली असफलता पर रोक

5

-c, --catch

नियंत्रण-सी और प्रदर्शन परिणाम पकड़ो

6

-b, --buffer

टेस्ट रन के दौरान बफर स्टडआउट और स्टेडर

इस अध्याय में यूनिस्टेस्ट मॉड्यूल में परिभाषित वर्गों और विधियों पर चर्चा की गई है। इस मॉड्यूल में पाँच प्रमुख वर्ग हैं।

टेस्टकेस क्लास

इस वर्ग की वस्तु सबसे छोटी परीक्षण योग्य इकाई का प्रतिनिधित्व करती है। यह परीक्षण दिनचर्या रखता है और प्रत्येक दिनचर्या तैयार करने और उसके बाद सफाई के लिए हुक प्रदान करता है।

टेस्टास क्लास में निम्नलिखित विधियां परिभाषित की गई हैं -

अनु क्रमांक विधि और विवरण
1

setUp()

पद्धति परीक्षण स्थिरता तैयार करने के लिए कहती है। परीक्षण विधि को कॉल करने से तुरंत पहले इसे कहा जाता है

2

tearDown()

परीक्षण विधि के तुरंत बाद बुलाया गया तरीका और दर्ज किया गया परिणाम है। इसे तब भी कहा जाता है जब परीक्षण विधि ने एक अपवाद उठाया,

3

setUpClass()

एक वर्ग विधि जिसे व्यक्तिगत कक्षा चलाने में परीक्षण से पहले बुलाया जाता है।

4

tearDownClass()

एक वर्ग विधि जिसे एक व्यक्तिगत कक्षा में परीक्षण के बाद बुलाया जाता है।

5

run(result = None)

परीक्षण चलाएँ, परीक्षा परिणाम वस्तु के रूप में पारित कर दिया में परिणाम एकत्रित परिणाम

6

skipTest(reason)

एक परीक्षण विधि या सेटअप () के दौरान यह कॉल करना वर्तमान परीक्षण को छोड़ देता है।

7

debug()

परिणाम इकट्ठा किए बिना परीक्षण चलाएं।

8

shortDescription()

परीक्षण का एक-पंक्ति विवरण देता है।

फिक्स्चर

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

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

import unittest

class simpleTest2(unittest.TestCase):
   def setUp(self):
      self.a = 10
      self.b = 20
      name = self.shortDescription()
      if name == "Add":
         self.a = 10
         self.b = 20
         print name, self.a, self.b
      if name == "sub":
         self.a = 50
         self.b = 60
         print name, self.a, self.b
   def tearDown(self):
      print '\nend of test',self.shortDescription()

   def testadd(self):
      """Add"""
      result = self.a+self.b
      self.assertTrue(result == 100)
   def testsub(self):
      """sub"""
      result = self.a-self.b
      self.assertTrue(result == -10)
      
if __name__ == '__main__':
   unittest.main()

कमांड कोड से उपरोक्त कोड चलाएँ। यह निम्नलिखित उत्पादन देता है -

C:\Python27>python test2.py
Add 10 20
F
end of test Add
sub 50 60
end of test sub
.
================================================================
FAIL: testadd (__main__.simpleTest2)
Add
----------------------------------------------------------------------
Traceback (most recent call last):
   File "test2.py", line 21, in testadd
      self.assertTrue(result == 100)
AssertionError: False is not true
----------------------------------------------------------------------
Ran 2 tests in 0.015s

FAILED (failures = 1)

कक्षा का निर्धारण

TestCase क्लास में एक setUpClass () विधि है जिसे TestCase क्लास के अंदर व्यक्तिगत परीक्षणों के निष्पादन से पहले निष्पादित करने की अनुमति दी जा सकती है। इसी तरह, क्लास में सभी परीक्षण के बाद आंसू डांडक्लास () पद्धति को निष्पादित किया जाएगा। दोनों विधियां वर्ग विधियां हैं। इसलिए, उन्हें @classmethod निर्देश के साथ सजाया जाना चाहिए।

निम्न उदाहरण इन वर्ग विधियों के उपयोग को दर्शाता है -

import unittest

class TestFixtures(unittest.TestCase):

   @classmethod
   def setUpClass(cls):
      print 'called once before any tests in class'

   @classmethod
   def tearDownClass(cls):
      print '\ncalled once after all tests in class'

   def setUp(self):
      self.a = 10
      self.b = 20
      name = self.shortDescription()
      print '\n',name
   def tearDown(self):
      print '\nend of test',self.shortDescription()

   def test1(self):
      """One"""
      result = self.a+self.b
      self.assertTrue(True)
   def test2(self):
      """Two"""
      result = self.a-self.b
      self.assertTrue(False)
      
if __name__ == '__main__':
unittest.main()

टेस्टसुइट क्लास

पायथन का परीक्षण ढांचा एक उपयोगी तंत्र प्रदान करता है जिसके द्वारा परीक्षण मामले के उदाहरणों को उनके द्वारा परीक्षण की जाने वाली सुविधाओं के अनुसार एक साथ समूहीकृत किया जा सकता है। यह तंत्र TestSuite वर्ग द्वारा सबसे अच्छे मॉड्यूल में उपलब्ध कराया गया है।

एक परीक्षण सूट बनाने और चलाने में निम्नलिखित चरण शामिल हैं।

Step 1 - TestSuite वर्ग का एक उदाहरण बनाएँ।

suite = unittest.TestSuite()

Step 2 - सूट में एक TestCase वर्ग के अंदर परीक्षण जोड़ें।

suite.addTest(testcase class)

Step 3 - आप क्लास से टेस्ट जोड़ने के लिए मेकसाइट () विधि का भी उपयोग कर सकते हैं

suite = unittest.makeSuite(test case class)

Step 4 - सुइट में व्यक्तिगत परीक्षण भी जोड़े जा सकते हैं।

suite.addTest(testcaseclass(""testmethod")

Step 5 - TestTestRunner वर्ग की एक वस्तु बनाएँ।

runner = unittest.TextTestRunner()

Step 6 - सूट में सभी परीक्षणों को चलाने के लिए रन () विधि को कॉल करें

runner.run (suite)

निम्नलिखित तरीके TestSuite वर्ग में परिभाषित किए गए हैं -

अनु क्रमांक विधि और विवरण
1

addTest()

परीक्षण सूट में एक परीक्षण विधि जोड़ता है।

2

addTests()

कई TestCase कक्षाओं से परीक्षण जोड़ता है।

3

run()

इस सूट के साथ जुड़े परीक्षणों को चलाता है, परिणाम को परीक्षा परिणाम वस्तु में एकत्रित करता है

4

debug()

परिणाम एकत्र किए बिना इस सूट के साथ जुड़े परीक्षणों को चलाता है।

5

countTestCases()

इस परीक्षण ऑब्जेक्ट द्वारा दर्शाए गए परीक्षणों की संख्या लौटाता है

निम्न उदाहरण दिखाता है कि टेस्टसुइट क्लास का उपयोग कैसे करें -

import unittest
class suiteTest(unittest.TestCase):
   def setUp(self):
      self.a = 10
      self.b = 20
      
   def testadd(self):
      """Add"""
      result = self.a+self.b
      self.assertTrue(result == 100)
   def testsub(self):
      """sub"""
      result = self.a-self.b
      self.assertTrue(result == -10)
      
def suite():
   suite = unittest.TestSuite()
##   suite.addTest (simpleTest3("testadd"))
##   suite.addTest (simpleTest3("testsub"))
   suite.addTest(unittest.makeSuite(simpleTest3))
   return suite
   
if __name__ == '__main__':
   runner = unittest.TextTestRunner()
   test_suite = suite()
   runner.run (test_suite)

आप लाइनों को अनइंस्टॉल करके और मेक स्युइट () विधि से टिप्पणी करके ऐडटेस्ट () विधि के साथ प्रयोग कर सकते हैं।

TestLoader वर्ग

सबसे अच्छे पैकेज में TestLoader वर्ग होता है जिसका उपयोग कक्षाओं और मॉड्यूल से टेस्ट सूट बनाने के लिए किया जाता है। डिफ़ॉल्ट रूप से, unittest.defaultTestLoader उदाहरण स्वचालित रूप से तब बनाया जाता है जब unittest.main (0 पद्धति) को कहा जाता है। एक स्पष्ट उदाहरण, हालांकि कुछ गुणों के अनुकूलन को सक्षम करता है।

निम्नलिखित कोड में, TestLoader ऑब्जेक्ट का उपयोग करके एक सूची में दो वर्गों से परीक्षण एकत्र किए जाते हैं।

import unittest
testList = [Test1, Test2]
testLoad = unittest.TestLoader()

TestList = []
for testCase in testList:
   testSuite = testLoad.loadTestsFromTestCase(testCase)
   TestList.append(testSuite)
   
newSuite = unittest.TestSuite(TestList)
runner = unittest.TextTestRunner()
runner.run(newSuite)

निम्न तालिका TestLoader वर्ग में विधियों की एक सूची दिखाती है -

S.No विधि और विवरण
1

loadTestsFromTestCase()

TestCase क्लास में निहित सभी परीक्षण मामलों का एक सूट लौटाएँ

2

loadTestsFromModule()

दिए गए मॉड्यूल में निहित सभी परीक्षण मामलों का एक सूट लौटाएं।

3

loadTestsFromName()

एक स्ट्रिंग स्पेसियर दिए गए सभी परीक्षणों के मामलों का एक सूट लौटाएं।

4

discover()

निर्दिष्ट प्रारंभ निर्देशिका से उपनिर्देशिकाओं में आवर्ती करके सभी परीक्षण मॉड्यूल का पता लगाएं, और एक TestSuite ऑब्जेक्ट वापस करें

TestResult Class

इस वर्ग का उपयोग उन परीक्षणों के बारे में जानकारी संकलित करने के लिए किया जाता है जो सफल रहे हैं और परीक्षण जो असफलता से मिले हैं। TestResult ऑब्जेक्ट परीक्षण के एक सेट के परिणामों को संग्रहीत करता है। TestRunner.run () विधि द्वारा TestResult इंस्टेंस लौटाया जाता है।

TestResult उदाहरण में निम्नलिखित विशेषताएं हैं -

अनु क्रमांक विशेषता और विवरण
1

Errors

टेस्टकेस उदाहरणों के 2-टुप्लस और स्ट्रैटेड ट्रेसबैक पकड़े तार। प्रत्येक टपल एक परीक्षण का प्रतिनिधित्व करता है जिसने एक अप्रत्याशित अपवाद उठाया।

2

Failures

टेस्टकेस उदाहरणों के 2-टुप्लस और स्ट्रैटेड ट्रेसबैक पकड़े तार। प्रत्येक टपल एक परीक्षण का प्रतिनिधित्व करता है, जहां TestCase.assert * () विधियों का उपयोग करके विफलता को स्पष्ट रूप से संकेत दिया गया था।

3

Skipped

टेस्टकेस उदाहरणों के 2-टुप्लस और परीक्षण को लंघन का कारण बताते हुए एक सूची।

4

wasSuccessful()

यदि अभी तक चलाए गए सभी परीक्षण समाप्त हो गए हैं, तो वापस लौटें, अन्यथा गलत रिटर्न देता है।

5

stop()

इस पद्धति को यह संकेत देने के लिए कहा जा सकता है कि चलाए जा रहे परीक्षणों के सेट को निरस्त किया जाना चाहिए।

6

startTestRun()

किसी भी परीक्षण को निष्पादित करने से पहले एक बार कॉल किया जाता है।

7

stopTestRun()

सभी परीक्षणों को निष्पादित करने के बाद एक बार कॉल किया जाता है।

8

testsRun

परीक्षणों की कुल संख्या अब तक चलती है।

9

Buffer

अगर यह सच है, sys.stdout तथा sys.stderr startTest () और stopTest () के बीच बफ़र किया जाएगा।

निम्नलिखित कोड एक परीक्षण सूट निष्पादित करता है -

if __name__ == '__main__':
   runner = unittest.TextTestRunner()
   test_suite = suite()
   result = runner.run (test_suite)
   
   print "---- START OF TEST RESULTS"
   print result

   print "result::errors"
   print result.errors

   print "result::failures"
   print result.failures

   print "result::skipped"
   print result.skipped

   print "result::successful"
   print result.wasSuccessful()
   
   print "result::test-run"
   print result.testsRun
   print "---- END OF TEST RESULTS"

निष्पादित होने पर कोड निम्न आउटपुट प्रदर्शित करता है -

---- START OF TEST RESULTS
<unittest.runner.TextTestResult run = 2 errors = 0 failures = 1>
result::errors
[]
result::failures
[(<__main__.suiteTest testMethod = testadd>, 'Traceback (most recent call last):\n
   File "test3.py", line 10, in testadd\n 
   self.assertTrue(result == 100)\nAssert
   ionError: False is not true\n')]
result::skipped
[]
result::successful
False
result::test-run
2
---- END OF TEST RESULTS

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

अभिकथन कार्यों के निम्नलिखित तीन सेट एकात्मक मॉड्यूल में परिभाषित किए गए हैं -

  • मूल बूलियन जोर देता है
  • तुलनात्मक जोर देता है
  • संग्रह के लिए जोर देता है

बुनियादी अभिकारक कार्य मूल्यांकन करते हैं कि किसी ऑपरेशन का परिणाम सही है या गलत। सभी मुखर तरीके एक स्वीकार करते हैंmsg तर्क, यदि निर्दिष्ट किया जाता है, तो विफलता पर त्रुटि संदेश के रूप में उपयोग किया जाता है।

अनु क्रमांक विधि और विवरण
1

assertEqual(arg1, arg2, msg = None)

टेस्ट कि arg1 और arg2 बराबर हैं। यदि मान बराबर की तुलना नहीं करते हैं, तो परीक्षण विफल हो जाएगा।

2

assertNotEqual(arg1, arg2, msg = None)

परीक्षण करें कि arg1 और arg2 समान नहीं हैं। यदि मान बराबर की तुलना करते हैं, तो परीक्षण विफल हो जाएगा।

3

assertTrue(expr, msg = None)

परीक्षण है कि expr सच है। यदि गलत है, तो परीक्षण विफल हो जाता है

4

assertFalse(expr, msg = None)

परीक्षण है कि expr गलत है। यदि सही है, तो परीक्षण विफल रहता है

5

assertIs(arg1, arg2, msg = None)

परीक्षण कि arg1 और arg2 एक ही वस्तु का मूल्यांकन करते हैं।

6

assertIsNot(arg1, arg2, msg = None)

परीक्षण करें कि arg1 और arg2 एक ही वस्तु का मूल्यांकन नहीं करते हैं।

7

assertIsNone(expr, msg = None)

परीक्षण है कि expr कोई नहीं है। यदि कोई नहीं, तो परीक्षण विफल रहता है

8

assertIsNotNone(expr, msg = None)

टेस्ट कि expr कोई नहीं है। यदि कोई नहीं, तो परीक्षण विफल हो जाता है

9

assertIn(arg1, arg2, msg = None)

टेस्ट कि ARG1 में है ARG2

10

assertNotIn(arg1, arg2, msg = None)

परीक्षण करें कि arg1 arg2 में नहीं है ।

1 1

assertIsInstance(obj, cls, msg = None)

टेस्ट कि obj का एक उदाहरण है cls

12

assertNotIsInstance(obj, cls, msg = None)

टेस्ट कि obj का एक उदाहरण नहीं है cls

उपरोक्त अभिकथन कार्यों में से कुछ निम्नलिखित कोड में कार्यान्वित किए गए हैं -

import unittest

class SimpleTest(unittest.TestCase):
   def test1(self):
      self.assertEqual(4 + 5,9)
   def test2(self):
      self.assertNotEqual(5 * 2,10)
   def test3(self):
      self.assertTrue(4 + 5 == 9,"The result is False")
   def test4(self):
      self.assertTrue(4 + 5 == 10,"assertion fails")
   def test5(self):
      self.assertIn(3,[1,2,3])
   def test6(self):
      self.assertNotIn(3, range(5))

if __name__ == '__main__':
   unittest.main()

जब उपरोक्त स्क्रिप्ट चलती है, तो test2, test4 और test6 विफलता दिखाएगा और अन्य सफलतापूर्वक चलते हैं।

FAIL: test2 (__main__.SimpleTest)
----------------------------------------------------------------------
Traceback (most recent call last):
   File "C:\Python27\SimpleTest.py", line 9, in test2
      self.assertNotEqual(5*2,10)
AssertionError: 10 == 10

FAIL: test4 (__main__.SimpleTest)
----------------------------------------------------------------------
Traceback (most recent call last):
   File "C:\Python27\SimpleTest.py", line 13, in test4
      self.assertTrue(4+5==10,"assertion fails")
AssertionError: assertion fails

FAIL: test6 (__main__.SimpleTest)
----------------------------------------------------------------------
Traceback (most recent call last):
   File "C:\Python27\SimpleTest.py", line 17, in test6
      self.assertNotIn(3, range(5))
AssertionError: 3 unexpectedly found in [0, 1, 2, 3, 4]

----------------------------------------------------------------------            
Ran 6 tests in 0.001s                                                             
                                                                                  
FAILED (failures = 3)

दावे के कार्यों का दूसरा सेट है comparative asserts −

  • assertAlmostEqual (पहला, दूसरा, स्थान = 7, संदेश = कोई नहीं, डेल्टा = कोई नहीं)

    परीक्षण करें कि अंतर की गणना करके पहले और दूसरे लगभग (या लगभग नहीं) बराबर हैं, दिए गए स्थानों की संख्या को गोल करके (डिफ़ॉल्ट 7, डिफ़ॉल्ट)

  • assertNotAlmostEqual (पहला, दूसरा, स्थान, संदेश, डेल्टा)

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

    उपरोक्त दोनों कार्यों में, यदि डेल्टा को स्थानों के बजाय आपूर्ति की जाती है, तो पहले और दूसरे के बीच का अंतर डेल्टा के मुकाबले (या उससे अधिक) कम या बराबर होना चाहिए।

    दोनों डेल्टा और स्थानों की आपूर्ति एक TypeError उठाती है।

  • assertGreater (पहला, दूसरा, संदेश = कोई नहीं)

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

  • assertGreaterEqual (पहला, दूसरा, संदेश = कोई नहीं)

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

  • assertLess (पहला, दूसरा, संदेश = कोई नहीं)

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

  • assertLessEqual (पहला, दूसरा, संदेश = कोई नहीं)

    परीक्षण करें कि विधि के नाम के आधार पर पहला , दूसरे से कम या बराबर है । यदि नहीं, तो परीक्षण विफल हो जाएगा।

  • assertRegexpMatches (पाठ, regexp, संदेश = कोई नहीं)

    परीक्षण करें कि regexp खोज पाठ से मेल खाती है। विफलता के मामले में, त्रुटि संदेश में पैटर्न और पाठ शामिल होंगे। regexp एक नियमित अभिव्यक्ति ऑब्जेक्ट या एक स्ट्रिंग हो सकती है जिसमें एक नियमित अभिव्यक्ति उपयुक्त होती हैre.search()

  • assertNotRegexpMatches (पाठ, regexp, संदेश = कोई नहीं)

    सत्यापित करता है कि एक regexp खोज पाठ से मेल नहीं खाती है । एक त्रुटि संदेश के पैटर्न और पाठ के भाग से मेल खाता है जो मेल खाता है। regexp एक नियमित अभिव्यक्ति ऑब्जेक्ट या एक स्ट्रिंग हो सकती है जिसमें एक नियमित अभिव्यक्ति उपयुक्त होती हैre.search()

अभिकथन कार्य निम्नलिखित उदाहरण में कार्यान्वित किए गए हैं -

import unittest
import math
import re

class SimpleTest(unittest.TestCase):
   def test1(self):
      self.assertAlmostEqual(22.0/7,3.14)
   def test2(self):
      self.assertNotAlmostEqual(10.0/3,3)
   def test3(self):
      self.assertGreater(math.pi,3)
   def test4(self):
      self.assertNotRegexpMatches("Tutorials Point (I) Private Limited","Point")

if __name__ == '__main__':
   unittest.main()

उपरोक्त स्क्रिप्ट परीक्षण 1 और परीक्षण 4 को विफलता के रूप में रिपोर्ट करती है। Test1 में, 22/7 का विभाजन 3.14 के 7 दशमलव स्थानों में नहीं है। इसी तरह, चूंकि दूसरा तर्क पहले तर्क में पाठ के साथ मेल खाता है, इसलिए परीक्षण 4 में परिणाम जोर से मिलता है।

=====================================================FAIL: test1 (__main__.SimpleTest)
----------------------------------------------------------------------
Traceback (most recent call last):
   File "asserttest.py", line 7, in test1
      self.assertAlmostEqual(22.0/7,3.14)
AssertionError: 3.142857142857143 != 3.14 within 7 places
================================================================
FAIL: test4 (__main__.SimpleTest)
----------------------------------------------------------------------
Traceback (most recent call last):
   File "asserttest.py", line 13, in test4
      self.assertNotRegexpMatches("Tutorials Point (I) Private Limited","Point")
AssertionError: Regexp matched: 'Point' matches 'Point' in 'Tutorials Point (I)
Private Limited'
----------------------------------------------------------------------

Ran 4 tests in 0.001s                                                             
                                                                                  
FAILED (failures = 2)

संग्रह के लिए मुखर

मुखर कार्यों के इस सेट का उपयोग पाइथन, जैसे सूची, टपल, शब्दकोश और सेट में संग्रह डेटा प्रकारों के साथ किया जाना है।

अनु क्रमांक विधि और विवरण
1

assertListEqual (list1, list2, msg = None)

टेस्ट जो दो सूचियों के बराबर हैं। यदि नहीं, तो एक त्रुटि संदेश का निर्माण किया जाता है जो दोनों के बीच के अंतर को दर्शाता है।

2

assertTupleEqual (tuple1, tuple2, msg = None)

टेस्ट जो दो ट्यूपल बराबर हैं। यदि नहीं, तो एक त्रुटि संदेश का निर्माण किया जाता है जो दोनों के बीच के अंतर को दर्शाता है।

3

assertSetEqual (set1, set2, msg = None)

टेस्ट कि दो सेट बराबर हैं। यदि नहीं, तो एक त्रुटि संदेश का निर्माण किया जाता है जो सेट के बीच के अंतरों को सूचीबद्ध करता है।

4

assertDictEqual (expected, actual, msg = None)

परीक्षण करें कि दो शब्दकोश समान हैं। यदि नहीं, तो एक त्रुटि संदेश का निर्माण किया जाता है जो शब्दकोशों में अंतर दिखाता है।

निम्नलिखित उदाहरण उपरोक्त विधियों को लागू करता है -

import unittest

class SimpleTest(unittest.TestCase):
   def test1(self):
      self.assertListEqual([2,3,4], [1,2,3,4,5])
   def test2(self):
      self.assertTupleEqual((1*2,2*2,3*2), (2,4,6))
   def test3(self):
      self.assertDictEqual({1:11,2:22},{3:33,2:22,1:11})

if __name__ == '__main__':
   unittest.main()

ऊपर दिए गए उदाहरण में, test1 और test3 AssertionError दिखाते हैं। त्रुटि संदेश सूची और शब्दकोश वस्तुओं में अंतर प्रदर्शित करता है।

FAIL: test1 (__main__.SimpleTest)
----------------------------------------------------------------------
Traceback (most recent call last):
   File "asserttest.py", line 5, in test1
      self.assertListEqual([2,3,4], [1,2,3,4,5])
AssertionError: Lists differ: [2, 3, 4] != [1, 2, 3, 4, 5]

First differing element 0:
2
1

Second list contains 2 additional elements.
First extra element 3:
4

- [2, 3, 4]
+ [1, 2, 3, 4, 5]
? +++       +++

FAIL: test3 (__main__.SimpleTest)
----------------------------------------------------------------------
Traceback (most recent call last):
   File "asserttest.py", line 9, in test3
      self.assertDictEqual({1:11,2:22},{3:33,2:22,1:11})
AssertionError: {1: 11, 2: 22} != {1: 11, 2: 22, 3: 33}
- {1: 11, 2: 22}
+ {1: 11, 2: 22, 3: 33}
?              +++++++
                                                                                  
----------------------------------------------------------------------            
Ran 3 tests in 0.001s                                                             
                                                                                  
FAILED (failures = 2)

TestLoader वर्ग में एक खोज () फ़ंक्शन है। अजगर परीक्षण रूपरेखा सरल परीक्षण खोज के लिए इसका उपयोग करता है। संगत होने के लिए, शीर्ष स्तर निर्देशिका से परीक्षण वाले मॉड्यूल और पैकेज को आयात किया जाना चाहिए।

परीक्षण खोज का मूल कमांड लाइन उपयोग निम्नलिखित है -

Python –m unittest discover

दुभाषिया वर्तमान निर्देशिका और आंतरिक निर्देशिका से परीक्षण वाले सभी मॉड्यूल को पुन: लोड करने की कोशिश करता है। अन्य कमांड लाइन विकल्प हैं -

अनु क्रमांक विकल्प और विवरण
1

-v, --verbose

वाचाल उत्पादन

2

-s, --start-directory

निर्देशिका निर्देशिका खोज शुरू करने के लिए (डिफ़ॉल्ट)

3

-p, --pattern

पैटर्न पैटर्न टेस्ट फ़ाइलों से मेल खाने के लिए (परीक्षण *। डिफ़ॉल्ट डिफ़ॉल्ट)

4

-t, --top-level-directory

निर्देशिका परियोजना की शीर्ष स्तर निर्देशिका (निर्देशिका शुरू करने के लिए चूक)

उदाहरण के लिए, मॉड्यूल में परीक्षणों की खोज करने के लिए जिनके नाम 'परीक्षण' निर्देशिका में 'मुखर' से शुरू होते हैं, निम्नलिखित कमांड का उपयोग किया जाता है -

C:\python27>python –m unittest –v –s "c:\test" –p "assert*.py"

परीक्षण खोज परीक्षण को आयात करके लोड करती है। एक बार परीक्षण खोज ने आपके द्वारा निर्दिष्ट प्रारंभ निर्देशिका से सभी परीक्षण फ़ाइलों को पाया है, यह आयात करने के लिए पैकेज नामों में पथ बदल देता है।

यदि आप एक निर्देशिका के लिए एक पथ के बजाय एक पैकेज नाम के रूप में प्रारंभ निर्देशिका की आपूर्ति करते हैं, तो मान लें कि जो भी स्थान से आयात करता है वह वह स्थान है जो आप का इरादा है, इसलिए आपको चेतावनी नहीं मिलेगी।

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

किसी विधि को बिना शर्त छोड़ने के लिए, निम्नलिखित unittest.skip () वर्ग विधि का उपयोग किया जा सकता है -

import unittest

   def add(x,y):
      return x+y

class SimpleTest(unittest.TestCase):
   @unittest.skip("demonstrating skipping")
   def testadd1(self):
      self.assertEquals(add(4,5),9)

if __name__ == '__main__':
   unittest.main()

चूंकि स्किप () एक वर्ग विधि है, यह @ टोकन द्वारा पूर्वनिर्मित है। विधि एक तर्क लेती है: स्किप करने का कारण बताने वाला लॉग संदेश।

जब उपरोक्त स्क्रिप्ट निष्पादित की जाती है, तो निम्न परिणाम कंसोल पर प्रदर्शित होता है -

C:\Python27>python skiptest.py
s
----------------------------------------------------------------------
Ran 1 test in 0.000s

OK (skipped = 1)

चरित्र 's' इंगित करता है कि एक परीक्षण छोड़ दिया गया है।

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

def testadd2(self):
   self.skipTest("another method for skipping")
   self.assertTrue(add(4 + 5) == 10)

निम्नलिखित सज्जाकार परीक्षण लंघन और अपेक्षित विफलताओं को लागू करते हैं -

अनु क्रमांक विधि और विवरण
1

unittest.skip(reason)

बिना सोचे-समझे टेस्ट को छोड़ दें। कारण का वर्णन करना चाहिए कि परीक्षण क्यों छोड़ा जा रहा है।

2

unittest.skipIf(condition, reason)

अगर हालत सही है तो सजाए गए टेस्ट को छोड़ दें।

3

unittest.skipUnless(condition, reason)

जब तक स्थिति सही न हो, सजा हुआ परीक्षण छोड़ दें।

4

unittest.expectedFailure()

परीक्षण को एक अपेक्षित विफलता के रूप में चिह्नित करें। यदि परीक्षण चलने पर विफल हो जाता है, तो परीक्षण को विफलता के रूप में नहीं गिना जाता है।

निम्नलिखित उदाहरण सशर्त लंघन और अपेक्षित विफलता का उपयोग दर्शाता है।

import unittest

class suiteTest(unittest.TestCase):
   a = 50
   b = 40
   
   def testadd(self):
      """Add"""
      result = self.a+self.b
      self.assertEqual(result,100)

   @unittest.skipIf(a>b, "Skip over this routine")
   def testsub(self):
      """sub"""
      result = self.a-self.b
      self.assertTrue(result == -10)
   
   @unittest.skipUnless(b == 0, "Skip over this routine")
   def testdiv(self):
      """div"""
      result = self.a/self.b
      self.assertTrue(result == 1)

   @unittest.expectedFailure
   def testmul(self):
      """mul"""
      result = self.a*self.b
      self.assertEqual(result == 0)

if __name__ == '__main__':
   unittest.main()

उपरोक्त उदाहरण में, टेस्टबस () और टेस्टडिव () को छोड़ दिया जाएगा। पहले मामले में a> b सत्य है, जबकि दूसरे मामले में b == 0 सत्य नहीं है। दूसरी ओर, टेस्टमुल () को अपेक्षित विफलता के रूप में चिह्नित किया गया है।

जब उपरोक्त स्क्रिप्ट को चलाया जाता है, तो दो स्किप किए गए परीक्षण 's' दिखाते हैं और अपेक्षित विफलता को 'x' के रूप में दिखाया जाता है।

C:\Python27>python skiptest.py
Fsxs
================================================================
FAIL: testadd (__main__.suiteTest)
Add
----------------------------------------------------------------------
Traceback (most recent call last):
   File "skiptest.py", line 9, in testadd
      self.assertEqual(result,100)
AssertionError: 90 != 100

----------------------------------------------------------------------
Ran 4 tests in 0.000s

FAILED (failures = 1, skipped = 2, expected failures = 1)

पायथन परीक्षण ढांचा यह सुनिश्चित करने के लिए निम्नलिखित दावे के तरीके प्रदान करता है कि अपवाद उठाए गए हैं।

assertRaises (अपवाद, कॉल करने योग्य, * आर्ग्स, ** kwds)

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

नीचे दिए गए उदाहरण में, एक परीक्षण फ़ंक्शन यह जांचने के लिए परिभाषित किया गया है कि क्या ZeroDivisionError उठाया गया है।

import unittest

def div(a,b):
   return a/b
class raiseTest(unittest.TestCase):
   def testraise(self):
      self.assertRaises(ZeroDivisionError, div, 1,0)

if __name__ == '__main__':
   unittest.main()

Testraise () फ़ंक्शन assertRaises () फ़ंक्शन का उपयोग करता है यह देखने के लिए कि क्या विभाजन तब होता है जब div () फ़ंक्शन कहा जाता है। उपरोक्त कोड एक अपवाद बढ़ाएगा। लेकिन तर्कों को div () फ़ंक्शन में निम्नानुसार बदला गया है -

self.assertRaises(ZeroDivisionError, div, 1,1)

जब कोई कोड इन परिवर्तनों के साथ चलाया जाता है, तो परीक्षण विफल हो जाता है क्योंकि ZeroDivisionError नहीं होता है।

F
================================================================
FAIL: testraise (__main__.raiseTest)
----------------------------------------------------------------------
Traceback (most recent call last):
   File "raisetest.py", line 7, in testraise
      self.assertRaises(ZeroDivisionError, div, 1,1)
AssertionError: ZeroDivisionError not raised

----------------------------------------------------------------------
Ran 1 test in 0.000s

FAILED (failures = 1)

assertRaisesRegexp (अपवाद, regexp, callable, * args, ** kwds)

उभरे हुए अपवाद के स्ट्रिंग प्रतिनिधित्व पर रेगेक्सप से मेल खाने वाले टेस्ट । regexp एक रेग्युलर एक्सप्रेशन ऑब्जेक्ट या स्ट्रिंग हो सकता है जिसमें रेग्युलर एक्सप्रेशन का उपयोग re.search () द्वारा किया जाता है।

निम्न उदाहरण से पता चलता है कि कैसे asRRisesRegexp () का उपयोग किया जाता है -

import unittest
import re

class raiseTest(unittest.TestCase):
   def testraiseRegex(self):
      self.assertRaisesRegexp(TypeError, "invalid", reg,"Point","TutorialsPoint")
      
if __name__ == '__main__':
   unittest.main()

यहाँ, testraseRegex () परीक्षण पहले तर्क के रूप में विफल नहीं होता है। "प्वाइंट" दूसरे तर्क स्ट्रिंग में पाया जाता है।

================================================================
FAIL: testraiseRegex (__main__.raiseTest)
----------------------------------------------------------------------
Traceback (most recent call last):
   File "C:/Python27/raiseTest.py", line 11, in testraiseRegex
      self.assertRaisesRegexp(TypeError, "invalid", reg,"Point","TutorialsPoint")
AssertionError: TypeError not raised
----------------------------------------------------------------------

हालाँकि, परिवर्तन नीचे दिखाया गया है -

self.assertRaisesRegexp(TypeError, "invalid", reg,123,"TutorialsPoint")

टाइपराइटर अपवाद को फेंक दिया जाएगा। इसलिए, निम्न परिणाम प्रदर्शित किया जाएगा -

================================================================
FAIL: testraiseRegex (__main__.raiseTest)
----------------------------------------------------------------------
Traceback (most recent call last):
   File "raisetest.py", line 11, in testraiseRegex
      self.assertRaisesRegexp(TypeError, "invalid", reg,123,"TutorialsPoint")
AssertionError: "invalid" does not match 
   "first argument must be string or compiled pattern"
----------------------------------------------------------------------

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

पायथन के परीक्षण ढांचे में टाइम आउट के लिए कोई समर्थन नहीं है। हालांकि, टाइमआउट-डेकोरेटर नामक तीसरा भाग मॉड्यूल काम कर सकता है।

मॉड्यूल डाउनलोड और इंस्टॉल करें -

https://pypi.python.org/packages/source/t/timeout-decorator/timeout-decorator-0.3.2.tar.gz

  • कोड में timeout_decorator आयात करें
  • टेस्ट से पहले टाइमआउट डेकोरेटर लगाएं
  • @timeout_decorator.timeout(10)

यदि इस पंक्ति के नीचे एक परीक्षण विधि यहां बताए गए टाइमआउट (10 मिनट) से अधिक समय लेती है, तो TimeOutError को उठाया जाएगा। उदाहरण के लिए -

import time
import timeout_decorator

class timeoutTest(unittest.TestCase):

   @timeout_decorator.timeout(5)
   def testtimeout(self):
      print "Start"
   for i in range(1,10):
      time.sleep(1)
      print "%d seconds have passed" % i
      
if __name__ == '__main__':
   unittest.main()

unittest2 Python 2.7 और उसके बाद के पायथन टेस्टिंग फ्रेमवर्क में जोड़े गए अतिरिक्त फीचर्स का बैकपोर्ट है। इसे पायथन 2.6, 2.7 और 3. * पर चलाने के लिए परीक्षण किया गया है। नवीनतम संस्करण से डाउनलोड किया जा सकता हैhttps://pypi.python.org/pypi/unittest2

यूनीटेस्ट के बजाय यूनीटेस्ट 2 का उपयोग करने के लिए, बस इंपोर्ट को यूनिस्टेस्ट 2 से आयात करें।

यूनिस्टेस्ट 2 में कक्षाएं यूनिस्टेस्ट में उपयुक्त कक्षाओं से निकलती हैं, इसलिए बिना किसी अतिरिक्त तत्काल उपयोग किए अपने सभी परीक्षणों को स्विच करने के लिए बिना यूनिट 2 टेस्ट रनिंग बुनियादी ढांचे का उपयोग करना संभव होना चाहिए। यदि आप नई सुविधाओं को लागू करने का इरादा रखते हैं, तो अपने टेस्टकेस को उपवर्ग से हटा देंunittest2.TestCase unittest.TestCase के बजाय

निम्नलिखित unittest2 की नई विशेषताएं हैं -

  • addCleanups बेहतर संसाधन प्रबंधन के लिए

  • कई नए मुखर तरीके शामिल हैं

  • assertRaises संदर्भ प्रबंधक के रूप में, बाद में अपवाद तक पहुंच के साथ

  • जैसे मॉड्यूल स्तर जुड़नार है setUpModule तथा tearDownModule

  • शामिल load_tests मॉड्यूल या पैकेज से परीक्षण लोड करने के लिए प्रोटोकॉल

  • startTestRun तथा stopTestRun TestResult पर तरीके

पायथन 2.7 में, आप के साथ सबसे आसान कमांड लाइन सुविधाओं (परीक्षण खोज सहित) को आमंत्रित करते हैं python -m unittest <args>

इसके बजाय, unittest2 एक स्क्रिप्ट यूनिट 2 के साथ आता है।

unit2 discover
unit2 -v test_module

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

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

निम्नलिखित उपयोगिता फ़ंक्शंस परीक्षण चौखटों के भीतर नियंत्रण-सी हैंडलिंग कार्यक्षमता सक्षम करते हैं -

unittest.installHandler ()

नियंत्रण-सी हैंडलर स्थापित करें। जब एकsignal.SIGINT प्राप्त सभी पंजीकृत परिणाम TestResult.stop () कहा जाता है।

unittest.registerResult (परिणाम)

रजिस्टर a TestResultनियंत्रण-सी हैंडलिंग के लिए वस्तु। रिजल्ट रजिस्टर करना एक कमजोर संदर्भ को संग्रहीत करता है, इसलिए यह परिणाम को एकत्रित होने से नहीं रोकता है।

unittest.removeResult (परिणाम)

एक पंजीकृत परिणाम निकालें। एक बार एक परिणाम निकाल दिया गया है तो TestResult.stop () अब नियंत्रण-सी के जवाब में उस परिणाम ऑब्जेक्ट पर नहीं बुलाया जाएगा।

unittest.removeHandler (फ़ंक्शन = कोई नहीं)

जब तर्क के बिना कहा जाता है, तो यह फ़ंक्शन नियंत्रण-सी हैंडलर को हटा देता है यदि इसे स्थापित किया गया है। इस फ़ंक्शन का उपयोग परीक्षण डेकोरेटर के रूप में भी किया जा सकता है ताकि परीक्षण निष्पादित होने के बाद हैंडलर को अस्थायी रूप से हटाया जा सके।

जीयूआई टेस्ट रनर

अंतःक्रियात्मक तरीके से परीक्षणों को खोजने और चलाने के लिए सबसे उपयुक्त मॉड्यूल स्थापित किया गया है। यह उपयोगिता, पायथन स्क्रिप्ट 'inittestgui.py' Tkinter मॉड्यूल का उपयोग करती है जो TK ग्राफिक्स सिस्टम किट के लिए पायथन पोर्ट है। यह खोज और परीक्षण चलाने के लिए GUI का उपयोग करना आसान बनाता है।

Python unittestgui.py

'डिस्कवर टेस्ट ’बटन पर क्लिक करें। एक छोटा संवाद बॉक्स दिखाई देता है जहां आप निर्देशिका और मॉड्यूल का चयन कर सकते हैं जहां से परीक्षण चलाया जाना है।

अंत में, स्टार्ट बटन पर क्लिक करें। परीक्षण चयनित पथ और मॉड्यूल नामों से खोजा जाएगा, और परिणाम फलक परिणाम प्रदर्शित करेगा।

व्यक्तिगत परीक्षा का विवरण देखने के लिए, परिणाम बॉक्स में परीक्षण पर चयन करें और क्लिक करें -

यदि आपको पायथन इंस्टॉलेशन में यह उपयोगिता नहीं मिलती है, तो आप इसे प्रोजेक्ट पेज से प्राप्त कर सकते हैं http://pyunit.sourceforge.net/।

इसी तरह, wxpython टूलकिट पर आधारित उपयोगिता भी वहां उपलब्ध है।

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

निम्नलिखित परिदृश्यों में 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> को अपने उदाहरण में रखें, प्रत्येक स्थान पर एक रिक्त पंक्ति अपेक्षित है।

सिद्धांत एपीआई निम्नलिखित दो कंटेनर कक्षाओं के आसपास घूमता है, जिनका उपयोग डॉकस्ट्रिंग्स से इंटरैक्टिव उदाहरणों को संग्रहीत करने के लिए किया जाता है -

  • 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 के माध्यम से विकल्पों को पारित करने का कोई तरीका नहीं है।

यह 2004 में था कि होल्गर क्रैकेल ने उनका नाम बदल दिया stdपैकेज, जिसका नाम अक्सर मानक लाइब्रेरी के साथ भ्रमित होता था जो कि पायथन के साथ जहाज (केवल थोड़ा कम भ्रमित) नाम 'py।' हालांकि पैकेज में कई उप-पैकेज हैं, यह अब लगभग पूरी तरह से अपने py.test ढांचे के लिए जाना जाता है।

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

py.test Python के स्टैण्डर्ड यूनिस्टेस्ट मॉड्यूल का एक नो-बॉयलरप्लेट है। पूरी तरह से चित्रित और एक्स्टेंसिबल परीक्षण उपकरण होने के बावजूद, यह एक सरल वाक्यविन्यास का दावा करता है। एक परीक्षण सूट बनाना उतना ही आसान है जितना कि कुछ कार्यों के साथ मॉड्यूल लिखना।

py.test पायथन संस्करणों 2.6 और इसके बाद के संस्करण के साथ सभी POSIX ऑपरेटिंग सिस्टम और WINDOWS (XP / 7/8) पर चलता है।

इंस्टालेशन

वर्तमान पायथन वितरण में और साथ ही py.test.exe उपयोगिता में pytest मॉड्यूल को लोड करने के लिए निम्न कोड का उपयोग करें। टेस्ट दोनों का उपयोग करके चलाया जा सकता है।

pip install pytest

प्रयोग

आप बस परीक्षण अपेक्षाओं का दावा करने के लिए मुखर कथन का उपयोग कर सकते हैं। पाइस्टेस्ट के मुखर आत्मनिरीक्षण बुद्धिमानी से मुखर अभिव्यक्ति के मध्यवर्ती मूल्यों की रिपोर्ट करेंगे जो आपको कई नामों को जानने की आवश्यकता से मुक्त करते हैंJUnit legacy methods

# content of test_sample.py
def func(x):
   return x + 1
   
def test_answer():
   assert func(3) == 5

उपरोक्त परीक्षण को चलाने के लिए निम्न कमांड लाइन का उपयोग करें। एक बार परीक्षण चलाने के बाद, निम्नलिखित परिणाम कंसोल पर प्रदर्शित होता है -

C:\Python27>scripts\py.test -v test_sample.py
============================= test session starts =====================
platform win32 -- Python 2.7.9, pytest-2.9.1, py-1.4.31, pluggy-0.3.1 -- C:\Pyth
on27\python.exe
cachedir: .cache
rootdir: C:\Python27, inifile:
collected 1 items
test_sample.py::test_answer FAILED
================================== FAILURES =====================
_________________________________ test_answer _________________________________
   def test_answer():
>  assert func(3) == 5
E     assert 4 == 5
E     + where 4 = func(3)
test_sample.py:7: AssertionError
========================== 1 failed in 0.05 seconds ====================

परीक्षण को कमांड लाइन से pytest मॉड्यूल का उपयोग करके भी चलाया जा सकता है -m स्विच का उपयोग करके।

python -m pytest test_sample.py

एक कक्षा में कई टेस्ट का आयोजन

एक बार जब आपके पास कुछ परीक्षणों से अधिक होना शुरू हो जाता है, तो यह अक्सर समूह परीक्षणों को तार्किक रूप से कक्षाओं और मॉड्यूल में समझ में आता है। आइए एक क्लास लिखें जिसमें दो टेस्ट हों -

class TestClass:
   def test_one(self):
      x = "this"
      assert 'h' in x
   def test_two(self):
      x = "hello"
      assert hasattr(x, 'check')

निम्नलिखित परीक्षा परिणाम प्रदर्शित किया जाएगा -

C:\Python27>scripts\py.test -v test_class.py
============================= test session starts =====================
platform win32 -- Python 2.7.9, pytest-2.9.1, py-1.4.31, pluggy-0.3.1 -- C:\Pyt
on27\python.exe
cachedir: .cache
rootdir: C:\Python27, inifile:
collected 2 items
test_class.py::TestClass::test_one PASSED
test_class.py::TestClass::test_two FAILED
================================== FAILURES =====================
_____________________________ TestClass.test_two ______________________________
self = <test_class.TestClass instance at 0x01309DA0>

   def test_two(self):
      x = "hello"
>  assert hasattr(x, 'check')
E     assert hasattr('hello', 'check')

test_class.py:7: AssertionError
===================== 1 failed, 1 passed in 0.06 seconds ======================

नाक परियोजना को 2005 में जारी किया गया था, इसके एक साल बाद py.testइसकी आधुनिक आड़ मिली। यह जेसन पेलरिन द्वारा उन्हीं टेस्ट मुहावरों का समर्थन करने के लिए लिखा गया था, जिन्हें py.test द्वारा अग्रणी किया गया था, लेकिन एक पैकेज में जिसे स्थापित करना और बनाए रखना आसान है।

nose पाइप उपयोगिता की मदद से मॉड्यूल स्थापित किया जा सकता है

pip install nose

यह वर्तमान पायथन वितरण के साथ-साथ nosetest.exe में नाक मॉड्यूल स्थापित करेगा, जिसका अर्थ है कि इस उपयोगिता का उपयोग करने के साथ-साथ स्विच का उपयोग करके परीक्षण चलाया जा सकता है।

C:\python>nosetests –v test_sample.py
Or
C:\python>python –m nose test_sample.py

nose से परीक्षण एकत्र करता है unittest.TestCaseउपवर्ग, निश्चित रूप से। हम सरल परीक्षण फ़ंक्शन, साथ ही परीक्षण कक्षाएं भी लिख सकते हैं जो कि unittest.TestCase के उपवर्ग नहीं हैं। नाक भी समयबद्ध परीक्षण लिखने, अपवादों के परीक्षण, और अन्य सामान्य उपयोग के मामलों के लिए कई सहायक कार्यों की आपूर्ति करता है।

noseस्वचालित रूप से परीक्षण एकत्र करता है। परीक्षण मामलों को मैन्युअल रूप से परीक्षण सूट में इकट्ठा करने की कोई आवश्यकता नहीं है। चल रहे परीक्षण उत्तरदायी है, क्योंकिnose पहला परीक्षण मॉड्यूल लोड होते ही परीक्षण चलाना शुरू कर देता है।

के रूप में unittest मॉड्यूल, nose पैकेज, मॉड्यूल, क्लास और टेस्ट केस स्तर पर जुड़नार का समर्थन करता है, इसलिए महंगे इनिशियलाइज़ेशन को जितना संभव हो उतना बार किया जा सकता है।

मूल उपयोग

आइए हम पहले उपयोग की गई स्क्रिप्ट के समान nosetest.py पर विचार करें -

# content of nosetest.py
def func(x):
   return x + 1
   
def test_answer():
   assert func(3) == 5

उपरोक्त परीक्षण को चलाने के लिए, निम्नलिखित कमांड लाइन सिंटैक्स का उपयोग करें -

C:\python>nosetests –v nosetest.py

कंसोल पर प्रदर्शित आउटपुट निम्नानुसार होगा -

nosetest.test_answer ... FAIL
================================================================
FAIL: nosetest.test_answer
----------------------------------------------------------------------
Traceback (most recent call last):
   File "C:\Python34\lib\site-packages\nose\case.py", line 198, in runTest
      self.test(*self.arg)
   File "C:\Python34\nosetest.py", line 6, in test_answer
      assert func(3) == 5
AssertionError
----------------------------------------------------------------------
Ran 1 test in 0.000s
FAILED (failures = 1)

nose का उपयोग करके DocTest के साथ एकीकृत किया जा सकता है with-doctest athe bove कमांड लाइन में विकल्प।

\nosetests --with-doctest -v nosetest.py

आप इस्तेमाल कर सकते हैं nose एक परीक्षण स्क्रिप्ट में -

import nose
nose.main()

यदि आप परीक्षण स्क्रिप्ट को सफलता पर 0 और असफलता पर 1 (जैसे unittest.main) से बाहर निकलने की इच्छा नहीं रखते हैं, तो इसके बजाय nose.run () का उपयोग करें -

import nose
result = nose.run()

यदि टेस्ट रन सफल होता है या परिणाम असफल हो जाता है या अनकहा अपवाद नहीं उठाता है तो परिणाम सही होगा।

noseपैकेज, मॉड्यूल, वर्ग, और परीक्षण स्तर पर जुड़नार (सेटअप और फाड़नेवाला तरीकों) का समर्थन करता है। Py.test या unittest जुड़नार के साथ, सेटअप हमेशा किसी भी परीक्षण (या परीक्षण पैकेज और मॉड्यूल के लिए परीक्षणों का संग्रह) से पहले चलता है; अगर टैस्ट रन की स्थिति की परवाह किए बिना सेटअप सफलतापूर्वक पूरा हो गया है, तो अश्रु रन।

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

  • nose.tools.ok_(expr, msg = None) - आशुलिपि के लिए आशुलिपि।

  • nose.tools.eq_(a, b, msg = None) - आशुलिपि 'के लिए ए == बी, "% आर! =% आर"% (ए, बी)

  • nose.tools.make_decorator(func) - एक परीक्षण डेकोरेटर को लपेटता है ताकि सजाया फ़ंक्शन के मेटाडेटा को ठीक से दोहराया जा सके, जिसमें नाक का अतिरिक्त सामान (अर्थात्, सेटअप और फाड़) शामिल है।

  • nose.tools.raises(*exceptions) - टेस्ट पास करने के लिए अपेक्षित अपवादों में से एक को उठाना होगा।

  • nose.tools.timed(limit) - टेस्ट पास करने के लिए निर्दिष्ट समय सीमा के भीतर समाप्त होना चाहिए

  • nose.tools.istest(func) - परीक्षण के रूप में एक फ़ंक्शन या विधि को चिह्नित करने के लिए डेकोरेटर

  • nose.tools.nottest(func) - डेकोरेटर एक फ़ंक्शन या विधि को चिह्नित करने के लिए एक परीक्षण के रूप में नहीं

परिमाणित परीक्षण

पायथन का परीक्षण ढांचा, एकतरफा, पैरामीट्रिज्ड परीक्षण मामलों को चलाने का एक सरल तरीका नहीं है। दूसरे शब्दों में, आप आसानी से तर्क को पास नहीं कर सकतेunittest.TestCase बाहर से।

हालांकि, पाइस्टेस्ट मॉड्यूल पोर्ट कई अच्छी तरह से एकीकृत तरीकों में पैराट्रिजेशन का परीक्षण करते हैं -

  • pytest.fixture() आप जुड़नार कार्यों के स्तर पर पैरामीट्रिज़ेशन को परिभाषित करने की अनुमति देता है।

  • @pytest.mark.parametrizeफ़ंक्शन या वर्ग स्तर पर पैरामीट्रिज़ेशन को परिभाषित करने की अनुमति देता है। यह एक विशेष परीक्षण समारोह या वर्ग के लिए कई तर्क / स्थिरता सेट प्रदान करता है।

  • pytest_generate_tests अपनी खुद की कस्टम डायनेमिक पैरामीरिजेशन स्कीम या एक्सटेंशन को लागू करने में सक्षम बनाता है।

एक तीसरे पक्ष के मॉड्यूल 'नाक-पैरामीटरकृत' किसी भी पायथन परीक्षण ढांचे के साथ परिमित परीक्षण की अनुमति देता है। इसे इस लिंक से डाउनलोड किया जा सकता है -https://github.com/wolever/nose-parameterized