UnitTest Çerçevesi - Onaylama

Python test çerçevesi, belirli bir koşulu test eden Python'un yerleşik assert () işlevini kullanır. İddia başarısız olursa, bir AssertionError ortaya çıkar. Test çerçevesi daha sonra testi Başarısız olarak tanımlayacaktır. Diğer istisnalar Hata olarak değerlendirilir.

Unittest modülünde aşağıdaki üç grup onaylama işlevi tanımlanmıştır -

  • Temel Boolean İddiaları
  • Karşılaştırmalı İddialar
  • Koleksiyonlar için Onaylar

Temel onay işlevleri, bir işlemin sonucunun Doğru mu Yanlış mı olduğunu değerlendirir. Tüm iddia yöntemleri kabul edermsg belirtilirse, başarısızlık durumunda hata mesajı olarak kullanılan argüman.

Sr.No. Yöntem ve Açıklama
1

assertEqual(arg1, arg2, msg = None)

Arg1 ve arg2'nin eşit olduğunu test edin . Değerler eşit değilse, test başarısız olacaktır.

2

assertNotEqual(arg1, arg2, msg = None)

Arg1 ve arg2'nin eşit olmadığını test edin . Değerler eşitse, test başarısız olur.

3

assertTrue(expr, msg = None)

İfadenin doğru olduğunu test edin . Yanlışsa, test başarısız olur

4

assertFalse(expr, msg = None)

İfadenin yanlış olduğunu test edin . Doğruysa, test başarısız olur

5

assertIs(arg1, arg2, msg = None)

Arg1 ve arg2'nin aynı nesneyi değerlendirip değerlendirmediğini test edin .

6

assertIsNot(arg1, arg2, msg = None)

Arg1 ve arg2'nin aynı nesneyi değerlendirmediğini test edin .

7

assertIsNone(expr, msg = None)

İfadenin Yok olduğunu test edin . Yok değilse, test başarısız olur

8

assertIsNotNone(expr, msg = None)

İfadenin Yok olmadığını test edin . Yok ise, test başarısız olur

9

assertIn(arg1, arg2, msg = None)

Testi o arg1 içindedir ARG2 .

10

assertNotIn(arg1, arg2, msg = None)

Bu test arg1 değil ARG2 .

11

assertIsInstance(obj, cls, msg = None)

Testi bu obj bir örneğidir cls'ye

12

assertNotIsInstance(obj, cls, msg = None)

O Testi obj bir örneği değil cls'ye

Yukarıdaki iddia işlevlerinden bazıları aşağıdaki kodda uygulanmaktadır -

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()

Yukarıdaki komut dosyası çalıştırıldığında, test2, test4 ve test6 başarısızlık gösterecek ve diğerleri başarıyla çalışacaktır.

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)

İkinci onaylama işlevi kümesi: comparative asserts −

  • assertAlmostEqual (birinci, ikinci, yerler = 7, msg = Yok, delta = Yok)

    Deney bu birinci ve ikinci yaklaşık (ya da yaklaşık olarak) olan ondalık verili bir yuvarlama farkı hesaplayarak eşit basamağa (varsayılan 7),

  • assertNotAlmostEqual (birinci, ikinci, yerler, mesaj, delta)

    Farkı hesaplayarak, verilen ondalık basamak sayısına (varsayılan 7) yuvarlayarak ve sıfırla karşılaştırarak birinci ve ikinci saniyenin yaklaşık olarak eşit olmadığını test edin.

    Yukarıdaki işlevlerin her ikisinde de, yerler yerine delta sağlanırsa, birinci ve ikinci arasındaki fark delta'ya eşit veya ondan küçük (veya daha büyük) olmalıdır.

    Hem delta hem de yerleri sağlamak bir TypeError hatası oluşturur.

  • assertGreater (birinci, ikinci, msg = Yok)

    Yöntem adına bağlı olarak ilkinin saniyeden büyük olduğunu test edin . Aksi takdirde test başarısız olur.

  • assertGreaterEqual (birinci, ikinci, msg = Yok)

    Yöntem adına bağlı olarak ilkinin saniyeden büyük veya saniyeye eşit olduğunu test edin . Değilse, test başarısız olur

  • assertLess (birinci, ikinci, msg = Yok)

    Yöntem adına bağlı olarak ilkinin saniyeden küçük olduğunu test edin . Değilse, test başarısız olur

  • assertLessEqual (birinci, ikinci, msg = Yok)

    Yöntem adına bağlı olarak ilkinin saniyeden küçük veya saniyeye eşit olduğunu test edin . Aksi takdirde test başarısız olur.

  • assertRegexpMatches (metin, regexp, msg = Yok)

    Bir regexp aramasının metinle eşleşip eşleşmediğini test edin. Başarısızlık durumunda, hata mesajı modeli ve metni içerecektir. regexp, normal bir ifade nesnesi veya kullanım için uygun bir normal ifade içeren bir dize olabilir.re.search().

  • assertNotRegexpMatches (metin, regexp, msg = Yok)

    Bir regexp aramasının metinle eşleşmediğini doğrular . Model ve eşleşen metin bölümünü içeren bir hata mesajıyla başarısız olur . regexp , normal bir ifade nesnesi veya re.search () tarafından kullanılmaya uygun bir normal ifade içeren bir dize olabilir .

Onaylama işlevleri aşağıdaki örnekte uygulanmaktadır -

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()

Yukarıdaki komut dosyası test1 ve test4'ü Hata olarak bildirir. Test1'de 22/7 bölümü, 3.14'ün 7 ondalık basamağı içinde değildir. Benzer şekilde, ikinci bağımsız değişken ilk bağımsız değişkendeki metinle eşleştiğinden, test4 AssertionError ile sonuçlanır.

=====================================================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)

Koleksiyonlar için Hak Talebi

Bu onaylama işlevleri kümesi, Python'daki Liste, Tuple, Sözlük ve Küme gibi veri toplama türleriyle kullanılmak üzere tasarlanmıştır.

Sr.No. Yöntem ve Açıklama
1

assertListEqual (list1, list2, msg = None)

İki listenin eşit olduğunu test eder. Değilse, yalnızca ikisi arasındaki farkları gösteren bir hata mesajı oluşturulur.

2

assertTupleEqual (tuple1, tuple2, msg = None)

İki demetin eşit olduğunu test eder. Değilse, yalnızca ikisi arasındaki farkları gösteren bir hata mesajı oluşturulur.

3

assertSetEqual (set1, set2, msg = None)

İki setin eşit olduğunu test eder. Değilse, setler arasındaki farkları listeleyen bir hata mesajı oluşturulur.

4

assertDictEqual (expected, actual, msg = None)

İki sözlüğün eşit olduğunu test edin. Değilse, sözlüklerdeki farklılıkları gösteren bir hata mesajı oluşturulur.

Aşağıdaki örnek, yukarıdaki yöntemleri uygular -

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()

Yukarıdaki örnekte, test1 ve test3 AssertionError'ı gösterir. Hata mesajı Liste ve Sözlük nesnelerindeki farklılıkları görüntüler.

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)