Je pakket testen

Python-pakketten ontwikkelen

James Fulton

Climate informatics researcher

De kunst en discipline van testen

Stel, je werkt aan deze functie

def get_ends(x):
    """Pak het eerste en laatste element van een lijst"""
    return x[0], x[-1]

Je kunt die testen om te zien of hij werkt

# Check de functie
get_ends([1,1,5,39,0])
(1, 0)
Python-pakketten ontwikkelen

De kunst en discipline van testen

Goede pakketten pronken met hoeveel tests ze hebben

  • 91% van de pandas-code is getest Pandas-badge: 91% van de functies getest
Python-pakketten ontwikkelen

Tests schrijven

def get_ends(x):
    """Pak het eerste en laatste element van een lijst"""
    return x[0], x[-1]
def test_get_ends():
    assert get_ends([1,5,39,0]) == (1,0)
test_get_ends()


Python-pakketten ontwikkelen

Tests schrijven

def get_ends(x):
    """Pak het eerste en laatste element van een lijst"""
    return x[0], x[1]
def test_get_ends():
    assert get_ends([1,5,39,0]) == (1,0)
test_get_ends()
AssertionError: 
...
Python-pakketten ontwikkelen

Tests schrijven

def get_ends(x):
    """Pak het eerste en laatste element van een lijst"""
    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-pakketten ontwikkelen

Tests organiseren in je pakket

mysklearn/
|-- mysklearn   <-- pakket
|-- tests       <-- testmap
|-- setup.py
|-- LICENSE
|-- MANIFEST.in
Python-pakketten ontwikkelen

Tests organiseren in je pakket

Structuur testmap

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

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

Structuur codemap

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

| |-- __init__.py | |-- normalize.py
| |-- standardize.py |-- regression | |-- __init__.py | |-- regression.py |-- utils.py
Python-pakketten ontwikkelen

Een testmodule organiseren

In 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

In normalize.py

def find_max(x):
    ...
    return x_max

def find_min(x):
    ...
    return x_min

def normalize_data(x):
    ...
    return x_norm
Python-pakketten ontwikkelen

Tests draaien met pytest

pytest
  • pytest kijkt in de map test
  • Zoekt modules als test_modulename.py
  • Zoekt functies als test_functionname()
  • Voert ze uit en toont de output
mysklearn/ <-- ga hierheen
|-- mysklearn
|-- tests
|-- setup.py
|-- LICENSE
|-- MANIFEST.in
Python-pakketten ontwikkelen

Tests draaien met 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 =========================
Python-pakketten ontwikkelen

Tests draaien met 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     <--    gedraaid in deze map
collected 6 items                                 <--    6 testfuncties gevonden

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

========================= 6 passed in 0.23s =========================
Python-pakketten ontwikkelen

Tests draaien met 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 =========================
Python-pakketten ontwikkelen

Tests draaien met 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 =========================
Python-pakketten ontwikkelen

Tests draaien met 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 ================================
Python-pakketten ontwikkelen

Laten we oefenen!

Python-pakketten ontwikkelen

Preparing Video For Download...