XML Biçiminde Test Yürütme Sonuçları

Test yürütmenin ayrıntılarını bir xml dosyasında oluşturabiliriz. Bu xml dosyası esas olarak test sonuçlarını yansıtan bir panomuzun olduğu durumlarda kullanışlıdır. Bu tür durumlarda, xml, yürütmenin ayrıntılarını almak için ayrıştırılabilir.

Şimdi test_multiplcation.py'deki testleri yürüteceğiz ve xml'yi çalıştırarak

pytest test_multiplication.py -v --junitxml="result.xml"

Şimdi sonuc.xml'nin aşağıdaki verilerle oluşturulduğunu görebiliriz -

<?xml version = "1.0" encoding = "utf-8"?>
<testsuite errors = "0" failures = "1"
name = "pytest" skips = "0" tests = "4" time = "0.061">
   <testcase classname = "test_multiplication"          
      file = "test_multiplication.py"
      line = "2" name = "test_multiplication_11[1-11]"
      time = "0.00117516517639>
   </testcase>
   
   <testcase classname = "test_multiplication"    
      file = "test_multiplication.py"
      line = "2" name = "test_multiplication_11[2-22]"
      time = "0.00155973434448">
   </testcase>

   <testcase classname = "test_multiplication" 
      file = "test_multiplication.py"
      line = "2" name = "test_multiplication_11[3-35]" time = "0.00144290924072">
      failure message = "assert (11 * 3) == 35">num = 3, output = 35

         @pytest.mark.parametrize("num,
         output",[(1,11),(2,22),(3,35),(4,44)])
            
         def test_multiplication_11(num, output):> 
         assert 11*num == output
         E assert (11 * 3) == 35

         test_multiplication.py:5: AssertionErro
      </failure>
   </testcase>
   <testcase classname = "test_multiplication" 
      file = "test_multiplication.py"
      line = "2" name = "test_multiplication_11[4-44]"
      time = "0.000945091247559">
   </testcase>
</testsuite>

İşte etiket <testsuit> 4 test olduğunu ve başarısızlıkların 1 olduğunu özetler.

  • Etiket <testcase> yürütülen her testin ayrıntılarını verir.

  • <failure> etiketi, başarısız olan test kodunun ayrıntılarını verir.