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