यूनिटटेस्ट फ्रेमवर्क - एपीआई
इस अध्याय में यूनिस्टेस्ट मॉड्यूल में परिभाषित वर्गों और विधियों पर चर्चा की गई है। इस मॉड्यूल में पाँच प्रमुख वर्ग हैं।
टेस्टकेस क्लास
इस वर्ग की वस्तु सबसे छोटी परीक्षण योग्य इकाई का प्रतिनिधित्व करती है। यह परीक्षण दिनचर्या रखता है और प्रत्येक दिनचर्या तैयार करने और उसके बाद सफाई के लिए हुक प्रदान करता है।
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