Menguji paket Anda

Mengembangkan Paket Python

James Fulton

Climate informatics researcher

Seni dan disiplin pengujian

Bayangkan Anda mengerjakan fungsi ini

def get_ends(x):
    """Get the first and last element in a list"""
    return x[0], x[-1]

Anda bisa mengujinya untuk memastikan berfungsi

# Periksa fungsinya
get_ends([1,1,5,39,0])
(1, 0)
Mengembangkan Paket Python

Seni dan disiplin pengujian

Paket yang baik bangga atas banyaknya test yang dimiliki

  • 91% kode paket pandas memiliki test Lencana cakupan Pandas menyatakan 91% fungsi diuji
Mengembangkan Paket Python

Menulis test

def get_ends(x):
    """Get the first and last element in a list"""
    return x[0], x[-1]
def test_get_ends():
    assert get_ends([1,5,39,0]) == (1,0)
test_get_ends()


Mengembangkan Paket Python

Menulis test

def get_ends(x):
    """Get the first and last element in a list"""
    return x[0], x[1]
def test_get_ends():
    assert get_ends([1,5,39,0]) == (1,0)
test_get_ends()
AssertionError: 
...
Mengembangkan Paket Python

Menulis test

def get_ends(x):
    """Get the first and last element in a list"""
    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')
Mengembangkan Paket Python

Mengatur test di dalam paket Anda

mysklearn/
|-- mysklearn   <-- paket
|-- tests       <-- direktori test
|-- setup.py
|-- LICENSE
|-- MANIFEST.in
Mengembangkan Paket Python

Mengatur test di dalam paket Anda

Struktur direktori test

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

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

Struktur direktori kode

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

| |-- __init__.py | |-- normalize.py
| |-- standardize.py |-- regression | |-- __init__.py | |-- regression.py |-- utils.py
Mengembangkan Paket Python

Mengatur sebuah modul test

Di dalam test_normalize.py

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

Di dalam normalize.py

def find_max(x):
    ...
    return x_max

def find_min(x):
    ...
    return x_min

def normalize_data(x):
    ...
    return x_norm
Mengembangkan Paket Python

Menjalankan test dengan pytest

pytest
  • pytest mencari di direktori test
  • Mencari modul seperti test_namamodul.py
  • Mencari fungsi seperti test_namafungsi()
  • Menjalankan fungsi tersebut dan menampilkan output
mysklearn/ <-- navigasikan ke sini
|-- mysklearn
|-- tests
|-- setup.py
|-- LICENSE
|-- MANIFEST.in
Mengembangkan Paket Python

Menjalankan test dengan pytest

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 =========================
Mengembangkan Paket Python

Menjalankan test dengan pytest

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     <--    dijalankan di direktori ini
collected 6 items                                 <--    menemukan 6 fungsi test

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

========================= 6 passed in 0.23s =========================
Mengembangkan Paket Python

Menjalankan test dengan pytest

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 =========================
Mengembangkan Paket Python

Menjalankan test dengan pytest

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 =========================
Mengembangkan Paket Python

Menjalankan test dengan pytest

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 ================================
Mengembangkan Paket Python

Ayo berlatih!

Mengembangkan Paket Python

Preparing Video For Download...