यूनिटटेस्ट फ्रेमवर्क - एपीआई

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

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

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

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

अनु क्रमांक। विधि और विवरण
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 वर्ग में विधियों की एक सूची दिखाती है -

अनु क्रमांक विधि और विवरण
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.stderrstartTest () और 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