यूनिटटेस्ट फ्रेमवर्क - अभिकथन

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

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

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

मूल मुखर कार्य मूल्यांकन करते हैं कि क्या किसी ऑपरेशन का परिणाम सही है या गलत है। सभी मुखर तरीके स्वीकार करते हैं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)