It makes combinations covering pairs for pairwise testing.
Project description
Requirements
- Python: 3.3 or later.
- Tested with 3.7
Installation
$ pip install covertable
Usage
Just import covertable and call make function.
>>> from covertable import make, sorters, criteria >>> machine_list = ['iphone', 'pixel'] >>> os_list = ['ios', 'android'] >>> browser_list = ['FireFox', 'Chrome', 'Safari'] >>> # list input and output >>> make( ... [machine_list, os_list, browser_list], # list factors ... length=2, # default: 2 ... sorter=sorters.random, # default: sorters.hash ... criterion=criteria.simple, # default: criteria.greedy ... seed=100, # default: '' ... pre_filter=lambda row: not(row[1] == 'android' and row[0] != 'pixel') and not(row[1] == 'ios' and row[0] != 'iphone'), # default: None ... ) [ ['pixel', 'android', 'Safari'], ['iphone', 'ios', 'Chrome'], ['iphone', 'ios', 'Safari'], ['pixel', 'android', 'Chrome'], ['pixel', 'android', 'FireFox'], ['iphone', 'ios', 'FireFox'] ] >>> # dict input and output >>> make( ... {'machine': machine_list, 'os': os_list, 'browser': browser_list}, # dict factors ... length=2, # default: 2 ... tolerance=3, # default: 0 ... post_filter=lambda row: not(row['os'] == 'android' and row['machine'] != 'pixel') and not(row['os'] == 'ios' and row['machine'] != 'iphone'), # default: None ... ) [ {'machine': 'pixel', 'browser': 'Chrome', 'os': 'android'}, {'machine': 'pixel', 'browser': 'FireFox', 'os': 'android'}, {'machine': 'iphone', 'os': 'ios', 'browser': 'Chrome'}, {'os': 'ios', 'browser': 'FireFox', 'machine': 'iphone'} ]
Options
covertable.make function has options as keyword argument.
All options are omittable.
length
It means length of pair to meet. (default: 2)
The more it increases, the more number of combinations increases.
sorter
Combinations depend on the order of spreading all over the rows.
You can choice a sorter from the following:
sorters.random: | This makes different combinations everytime. (fastest) |
---|---|
sorters.hash: | This makes combinations depending on hash of the pair and seed. (default)
|
criterion
criteria.simple: | |
---|---|
This extracts any pairs that can be stored into the processing row. |
|
criteria.greedy: | |
This attempts to make most efficient combinations. (default)
|
Note
Not relevant options will be ignored.
pre_filter
This means a function to filter beforehand.
It receives an argument row as object type.
When the function returns false, the row combination will not registered.
- If factors type is Array, you should an index at the subscript like row => row[1] < 6.
- IF factors type is Object, you should a key at the subscript like row => row.month < 6 or row => row[‘month’] < 6
post_filter
This means a function to filter later.
Usage is the same as preFilter, only the difference is the timing that it is called. It will delete rows not matched this function at the last.
Development
# preparation $ python3 -m venv venv $ source venv/bin/activate (venv) $ pip install -r dev_requirements.txt # testing (venv) $ tox # -e py37 -e cov -e black
Publish
(venv) $ python setup.py sdist bdist_wheel (venv) $ twine upload --repository pypi dist/*
More info
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Filename, size | File type | Python version | Upload date | Hashes |
---|---|---|---|---|
Filename, size covertable-2.0.0-py3-none-any.whl (7.1 kB) | File type Wheel | Python version py3 | Upload date | Hashes View |
Filename, size covertable-2.0.0.tar.gz (5.7 kB) | File type Source | Python version None | Upload date | Hashes View |
Hashes for covertable-2.0.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | da887e54450327dac00f561657bf07e9f293930150a70759d03f867bfc58351e |
|
MD5 | be02513bb848379c7a28f866270f547e |
|
BLAKE2-256 | 3c45b11afe163e99bbb5ee258dd8b2b4aaf46a9e58d1158374d782c2504cbb10 |