UnitTest Çerçevesi - API

Bu bölüm, unittest modülünde tanımlanan sınıfları ve yöntemleri tartışır. Bu modülde beş ana sınıf vardır.

TestCase Sınıfı

Bu sınıfın amacı, test edilebilir en küçük birimi temsil eder. Test rutinlerini tutar ve her rutini hazırlamak ve daha sonra temizlemek için kancalar sağlar.

Aşağıdaki yöntemler TestCase sınıfında tanımlanmıştır -

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

setUp()

Test fikstürünü hazırlamak için yöntem çağrıldı. Bu, test yöntemini çağırmadan hemen önce çağrılır

2

tearDown()

Yöntem, test yöntemi çağrıldıktan ve sonuç kaydedildikten hemen sonra çağrılır. Test yöntemi bir istisna oluştursa bile bu çağrılır,

3

setUpClass()

Tek bir sınıf çalıştırmasında testlerden önce çağrılan bir sınıf yöntemi.

4

tearDownClass()

Tek bir sınıftaki testler çalıştırıldıktan sonra çağrılan bir sınıf yöntemi.

5

run(result = None)

Olarak geçirilen test sonucu nesnesine sonucu toplayarak, testi uygulama sonucu .

6

skipTest(reason)

Bunun bir test yöntemi veya setUp () sırasında çağrılması mevcut testi atlar.

7

debug()

Sonucu toplamadan testi çalıştırın.

8

shortDescription()

Testin tek satırlık bir açıklamasını döndürür.

Fikstür

Bir TestCase sınıfı içinde yazılmış çok sayıda test olabilir. Bu test yöntemlerinin başlatılması için veritabanı bağlantısı, geçici dosyalar veya diğer kaynaklar gerekebilir. Bunlara demirbaş denir. TestCase, testlerinizin ihtiyaç duyduğu tüm armatürleri yapılandırmak ve temizlemek için özel bir kanca içerir. Fikstürleri yapılandırmak için setUp () öğesini geçersiz kılın. Temizlemek için tearDown () öğesini geçersiz kılın.

Aşağıdaki örnekte, TestCase sınıfının içine iki test yazılmıştır. İki değerin toplanması ve çıkarılmasının sonucunu test ederler. Setup () yöntemi, argümanları her testin shortDescription () yöntemine göre başlatır. teardown () yöntemi her testin sonunda çalıştırılacaktır.

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

Yukarıdaki kodu komut satırından çalıştırın. Aşağıdaki çıktıyı verir -

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)

Sınıf Fikstürü

TestCase sınıfı, bir TestCase sınıfı içinde tek tek testlerin yürütülmesinden önce yürütülmek üzere geçersiz kılınabilen bir setUpClass () yöntemine sahiptir. Benzer şekilde, sınıftaki tüm testlerden sonra tearDownClass () yöntemi çalıştırılacaktır. Her iki yöntem de sınıf yöntemleridir. Bu nedenle, @classmethod yönergesi ile dekore edilmeleri gerekir.

Aşağıdaki örnek, bu sınıf yöntemlerinin kullanımını gösterir -

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 Sınıfı

Python'un test çerçevesi, test senaryosu örneklerinin test ettikleri özelliklere göre birlikte gruplanabilmesini sağlayan kullanışlı bir mekanizma sağlar. Bu mekanizma, unittest modülünde TestSuite sınıfı tarafından kullanıma sunulmuştur.

Aşağıdaki adımlar, bir test paketinin oluşturulması ve çalıştırılmasıyla ilgilidir.

Step 1 - TestSuite sınıfının bir örneğini oluşturun.

suite = unittest.TestSuite()

Step 2 - Paketteki bir TestCase sınıfının içine testler ekleyin.

suite.addTest(testcase class)

Step 3 - Bir sınıftan testler eklemek için makeSuite () yöntemini de kullanabilirsiniz

suite = unittest.makeSuite(test case class)

Step 4 - Süite bireysel testler de eklenebilir.

suite.addTest(testcaseclass(""testmethod")

Step 5 - TestTestRunner sınıfının bir nesnesini oluşturun.

runner = unittest.TextTestRunner()

Step 6 - Paketteki tüm testleri çalıştırmak için run () yöntemini çağırın

runner.run (suite)

Aşağıdaki yöntemler TestSuite sınıfında tanımlanmıştır -

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

addTest()

Test paketine bir test yöntemi ekler.

2

addTests()

Birden çok TestCase sınıfından testler ekler.

3

run()

Bu paketle ilişkili testleri çalıştırarak sonucu test sonucu nesnesinde toplar

4

debug()

Sonucu toplamadan bu paketle ilişkili testleri çalıştırır.

5

countTestCases()

Bu test nesnesiyle temsil edilen testlerin sayısını verir

Aşağıdaki örnek, TestSuite sınıfının nasıl kullanılacağını gösterir -

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)

MakeSuite () yöntemini kullanarak satırları ve yorum deyimini kaldırarak addTest () yöntemini deneyebilirsiniz.

TestLoader Sınıfı

Unittest paketi, sınıflardan ve modüllerden test takımları oluşturmak için kullanılan TestLoader sınıfına sahiptir. Varsayılan olarak unittest.defaultTestLoader örneği, unittest.main (0 yöntemi çağrıldığında otomatik olarak oluşturulur. Açık bir örnek, ancak belirli özelliklerin özelleştirilmesini sağlar.

Aşağıdaki kodda, TestLoader nesnesi kullanılarak iki sınıftaki testler bir List'de toplanır.

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)

Aşağıdaki tablo, TestLoader sınıfındaki yöntemlerin bir listesini gösterir -

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

loadTestsFromTestCase()

Bir TestCase sınıfında bulunan tüm test vakalarının bir paketini döndür

2

loadTestsFromModule()

Verilen modülde bulunan tüm test durumlarının bir paketini döndür.

3

loadTestsFromName()

Bir dizge belirticisi verilen tüm test durumlarının bir paketini döndürür.

4

discover()

Belirtilen başlangıç ​​dizininden alt dizinlere yineleyerek tüm test modüllerini bulun ve bir TestSuite nesnesi döndürür

TestResult Sınıfı

Bu sınıf, başarılı olan testler ve başarısızlıkla karşılaşan testler hakkında bilgi toplamak için kullanılır. Bir TestResult nesnesi, bir dizi testin sonuçlarını depolar. TestResult örneği, TestRunner.run () yöntemi tarafından döndürülür.

TestResult örnekleri aşağıdaki özniteliklere sahiptir -

Sr.No. Öznitelik ve Açıklama
1

Errors

TestCase örneklerinin 2 demetini ve biçimlendirilmiş izleme boşluklarını tutan dizeleri içeren bir liste. Her demet, beklenmedik bir istisna oluşturan bir testi temsil eder.

2

Failures

TestCase örneklerinin 2 demetini ve biçimlendirilmiş izleme boşluklarını tutan dizeleri içeren bir liste. Her demet, bir hatanın TestCase.assert * () yöntemleri kullanılarak açıkça bildirildiği bir testi temsil eder.

3

Skipped

TestCase örneklerinin 2 demetini ve testi atlama nedenini içeren dizeleri içeren bir liste.

4

wasSuccessful()

Şimdiye kadar çalıştırılan tüm testler geçtiyse True döndür, aksi takdirde False döndürür.

5

stop()

Bu yöntem, çalıştırılmakta olan testler setinin iptal edilmesi gerektiğini belirtmek için çağrılabilir.

6

startTestRun()

Herhangi bir test yapılmadan önce bir kez çağrılır.

7

stopTestRun()

Tüm testler yapıldıktan sonra bir kez çağrılır.

8

testsRun

Şimdiye kadar yapılan toplam test sayısı.

9

Buffer

True olarak ayarlanmışsa, sys.stdout ve sys.stderrçağrılan startTest () ve stopTest () arasında arabelleğe alınacaktır .

Aşağıdaki kod bir test paketini yürütür -

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"

Çalıştırıldığında kod aşağıdaki çıktıyı görüntüler -

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