Paketinizi test etme

Python Paketleri Geliştirme

James Fulton

Climate informatics researcher

Test etme sanatı ve disiplini

Bu fonksiyon üzerinde çalıştığınızı düşünün

def get_ends(x):
    """Listede ilk ve son öğeyi döndür"""
    return x[0], x[-1]

Çalıştığından emin olmak için test edebilirsiniz

# Fonksiyonu kontrol et
get_ends([1,1,5,39,0])
(1, 0)
Python Paketleri Geliştirme

Test etme sanatı ve disiplini

İyi paketler kaç testi olduğunu gururla söyler

  • pandas paketinin kodunun %91’i testlidir Pandas kapsam rozeti, fonksiyonların %91’inin test edildiğini söylüyor
Python Paketleri Geliştirme

Test yazma

def get_ends(x):
    """Listede ilk ve son öğeyi döndür"""
    return x[0], x[-1]
def test_get_ends():
    assert get_ends([1,5,39,0]) == (1,0)
test_get_ends()


Python Paketleri Geliştirme

Test yazma

def get_ends(x):
    """Listede ilk ve son öğeyi döndür"""
    return x[0], x[1]
def test_get_ends():
    assert get_ends([1,5,39,0]) == (1,0)
test_get_ends()
AssertionError: 
...
Python Paketleri Geliştirme

Test yazma

def get_ends(x):
    """Listede ilk ve son öğeyi döndür"""
    return x[0], x[-1]
def test_get_ends():
    assert get_ends([1,5,39,0]) == (1,0)
    assert get_ends(['n','e','r','d']) == ('n','d')
Python Paketleri Geliştirme

Paket içinde testleri düzenleme

mysklearn/
|-- mysklearn   <-- paket
|-- tests       <-- test dizini
|-- setup.py
|-- LICENSE
|-- MANIFEST.in
Python Paketleri Geliştirme

Paket içinde testleri düzenleme

Test dizini düzeni

mysklearn/tests/
|-- __init__.py
|-- preprocessing

| |-- __init__.py | |-- test_normalize.py
| |-- test_standardize.py |-- regression | |-- __init__.py | |-- test_regression.py |-- test_utils.py

Kod dizini düzeni

mysklearn/mysklearn/
|-- __init__.py
|-- preprocessing

| |-- __init__.py | |-- normalize.py
| |-- standardize.py |-- regression | |-- __init__.py | |-- regression.py |-- utils.py
Python Paketleri Geliştirme

Bir test modülünü düzenleme

test_normalize.py içinde

from mysklearn.preprocessing.normalize import (
    find_max, find_min, normalize_data
)

def test_find_max(x):
    assert find_max([1,4,7,1])==7

def test_find_min(x):
    assert ...

def test_normalize_data(x):
    assert ...

DataCamp: Unit testing for data science

normalize.py içinde

def find_max(x):
    ...
    return x_max

def find_min(x):
    ...
    return x_min

def normalize_data(x):
    ...
    return x_norm
Python Paketleri Geliştirme

Pytest ile testleri çalıştırma

pytest
  • pytest test dizininde arar
  • test_modulename.py gibi modülleri bulur
  • test_functionname() gibi fonksiyonları bulur
  • Bu fonksiyonları çalıştırır ve çıktıyı gösterir
mysklearn/ <-- buraya gidin
|-- mysklearn
|-- tests
|-- setup.py
|-- LICENSE
|-- MANIFEST.in
Python Paketleri Geliştirme

Pytest ile testleri çalıştırma

pytest
======================== test session starts ========================
platform linux -- Python 3.7.9, pytest-6.1.2, py-1.9.0, pluggy-0.13.1
rootdir: /home/workspace/mypackages/mysklearn
collected 6 items

tests/preprocessing/test_normalize.py ...                     [ 50%]
tests/preprocessing/test_standardize.py ...                   [100%]

========================= 6 passed in 0.23s =========================
Python Paketleri Geliştirme

Pytest ile testleri çalıştırma

pytest
======================== test session starts ========================
platform linux -- Python 3.7.9, pytest-6.1.2, py-1.9.0, pluggy-0.13.1
rootdir: /home/workspace/mypackages/mysklearn     <--    bu dizinde çalıştı
collected 6 items                                 <--    6 test fonksiyonu bulundu

tests/preprocessing/test_normalize.py ...                     [ 50%]
tests/preprocessing/test_standardize.py ...                   [100%]

========================= 6 passed in 0.23s =========================
Python Paketleri Geliştirme

Pytest ile testleri çalıştırma

pytest
======================== test session starts ========================
platform linux -- Python 3.7.9, pytest-6.1.2, py-1.9.0, pluggy-0.13.1
rootdir: /home/workspace/mypackages/mysklearn
collected 6 items

tests/preprocessing/test_normalize.py ...                     [ 50%]  <-- 
tests/preprocessing/test_standardize.py ...                   [100%]  <-- 

========================= 6 passed in 0.23s =========================
Python Paketleri Geliştirme

Pytest ile testleri çalıştırma

pytest
======================== test session starts ========================
platform linux -- Python 3.7.9, pytest-6.1.2, py-1.9.0, pluggy-0.13.1
rootdir: /home/workspace/mypackages/mysklearn
collected 6 items

tests/preprocessing/test_normalize.py ...                     [ 50%]
tests/preprocessing/test_standardize.py ...                   [100%]

========================= 6 passed in 0.23s =========================
Python Paketleri Geliştirme

Pytest ile testleri çalıştırma

pytest
==================================== test session starts ====================================
...
tests/preprocessing/test_normalize.py .F.                                              [ 50%]
tests/preprocessing/test_standardize.py ...                                            [100%]

========================================= FAILURES ==========================================
________________________________________ test_mymax _________________________________________
...

tests/preprocessing/test_normalize.py:10: AssertionError
================================== short test summary info ==================================
FAILED tests/preprocessing/test_normalize.py::test_mymax - assert -100 == 100       <-- test_mymax
================================ 1 failed, 5 passed in 0.17s ================================
Python Paketleri Geliştirme

Hadi pratik yapalım!

Python Paketleri Geliştirme

Preparing Video For Download...