UnitTest Çerçevesi - Doctest

Python 'standart dağıtımı' Doctest 'modülünü içerir. Bu modülün işlevselliği, etkileşimli Python oturumları gibi görünen metin parçalarını aramayı mümkün kılar ve tam olarak gösterildiği gibi çalışıp çalışmadıklarını görmek için bu oturumları yürütür.

Doctest, aşağıdaki senaryolarda çok faydalı olabilir -

  • Tüm etkileşimli örneklerin hala belgelendiği gibi çalıştığını doğrulayarak bir modülün belge dizilerinin güncel olup olmadığını kontrol etmek için.

  • Bir test dosyasından veya bir test nesnesinden etkileşimli örneklerin beklendiği gibi çalıştığını doğrulayarak regresyon testi gerçekleştirmek için.

  • Girdi-çıktı örnekleriyle serbestçe gösterilen bir paket için öğretici belgeler yazmak için

Python'da bir 'docstring', bir sınıf, işlev veya modülde ilk ifade olarak görünen bir dize değişmezidir. Paket yürütüldüğünde yok sayılır, ancak derleyici tarafından tanınır ve__doc__çevreleyen sınıf, işlev veya modülün niteliği. İç gözlem yoluyla kullanılabildiğinden, nesnenin dokümantasyonu için kanonik yerdir.

Docstring'in içine Python kodunun farklı bölümlerinin örnek kullanımını koymak olağan bir uygulamadır. Doctest modülü, bu belge dizilerinin koddaki aralıklı revizyonlarla güncel olduğunu doğrulamaya izin verir.

Aşağıdaki kodda, faktöriyel bir fonksiyon örnek kullanımla serpiştirilmiş olarak tanımlanmıştır. Örnek kullanımın doğru olup olmadığını doğrulamak için doctest modülündeki testmod () işlevini çağırın.

"""
This is the "example" module.

The example module supplies one function, factorial(). For example,

>>> factorial(5)
120
"""

def factorial(x):
   """Return the factorial of n, an exact integer >= 0.
   >>> factorial(-1)
   Traceback (most recent call last):
      ...
   ValueError: x must be >= 0
   """
   
   if not x >= 0:
      raise ValueError("x must be >= 0")
   f = 1
   for i in range(1,x+1):
      f = f*i
   return f
   
if __name__ == "__main__":
   import doctest
   doctest.testmod()

Yukarıdaki komut dosyasını FactDocTest.py olarak girin ve kaydedin ve bu komut dosyasını komut satırından çalıştırmayı deneyin.

Python FactDocTest.py

Örnek başarısız olmadıkça hiçbir çıktı gösterilmeyecektir. Şimdi, komut satırını şu şekilde değiştirin -

Python FactDocTest.py –v

Konsol şimdi aşağıdaki çıktıyı gösterecek -

C:\Python27>python FactDocTest.py -v
Trying:
   factorial(5)
Expecting:
   120
ok
Trying:
   factorial(-1)
Expecting:
   Traceback (most recent call last):
      ...
   ValueError: x must be >= 0
ok
2 items passed all tests:
   1 tests in __main__
   1 tests in __main__.factorial
2 tests in 2 items.
2 passed and 0 failed.
Test passed.

Öte yandan, factorial () işlevinin kodu docstring'de beklenen sonucu vermezse, başarısızlık sonucu görüntülenecektir. Örneğin, yukarıdaki komut dosyasında f = 1 yerine f = 2'yi değiştirin ve doctest'i yeniden çalıştırın. Sonuç aşağıdaki gibi olacaktır -

Trying:
   factorial(5)
Expecting:
   120
**********************************************************************
File "docfacttest.py", line 6, in __main__
Failed example:
factorial(5)
Expected:
   120
Got:
   240
Trying:
   factorial(-1)
Expecting:
   Traceback (most recent call last):
      ...
   ValueError: x must be >= 0
ok
1 items passed all tests:
   1 tests in __main__.factorial
**********************************************************************
1 items had failures:
   1 of 1 in __main__
2 tests in 2 items.
1 passed and 1 failed.
***Test Failed*** 1 failures.

Doctest: Bir Metin Dosyasındaki Örnekleri Kontrol Etme

Doctest'in diğer bir basit uygulaması, bir metin dosyasında etkileşimli örnekleri test etmektir. Bu, testfile () işlevi ile yapılabilir.

Aşağıdaki metin, 'example.txt' adlı bir metin dosyasında saklanır.

Using ''factorial''
-------------------
This is an example text file in reStructuredText format. First import
''factorial'' from the ''example'' module:
   >>> from example import factorial
Now use it:
   >>> factorial(5)
   120

Dosya içeriği docstring olarak değerlendirilir. Metin dosyasındaki örnekleri doğrulamak için doctest modülünün testfile () işlevini kullanın.

def factorial(x):
   if not x >= 0:
      raise ValueError("x must be >= 0")
   f = 1
   for i in range(1,x+1):
      f = f*i
   return f
   
if __name__ == "__main__":
   import doctest
   doctest.testfile("example.txt")
  • Testmod () ile olduğu gibi, testfile () bir örnek başarısız olmadıkça hiçbir şey göstermez. Bir örnek başarısız olursa, başarısız olan örnekler ve hataların nedenleri, testmod () ile aynı format kullanılarak konsola yazdırılır.

  • Çoğu durumda etkileşimli bir konsol oturumunun kopyalayıp yapıştırması iyi çalışır, ancak doctest herhangi bir belirli Python kabuğunun tam bir öykünmesini yapmaya çalışmaz.

  • Beklenen herhangi bir çıktı, kodu içeren son '>>>' veya '...' satırını hemen takip etmelidir ve beklenen çıktı (varsa) sonraki '>>>' veya tamamen beyaz boşluk satırına uzanır.

  • Beklenen çıktı tamamen boşluklu bir satır içeremez, çünkü böyle bir satır beklenen çıktının sonunu işaret etmek için alınır. Beklenen çıktı boş bir satır içeriyorsa, doctest örneğinizde boş bir satır olması beklenen her yere <BLANKLINE> yazın.