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