lockable resource plugin for pytest
Project description
pytest-lockable
pytest plugin for lockable resources.
Replacement for Jenkins lockable -plugin.
Locking is implemented using <resource.id>.lock
files.
Resources are described in json file as array of objects. Each object has some mandatory fields but can contains any other as well. Required fields are: id
, online
, hostname
-
Example resources.json
[
{
"id": "1234",
"online": true,
"hostname": "localhost"
}
]
id
should be unique for each resources. online
describes if resource are available for allocator. Set this false
if you don't want to allocate resource. hostname
is used to select suitable resource by running host.
installation
Requires: python 3.7<
pip install pytest-lockable
conftest.py
:
pytest_plugins = ("lockable.plugin",)
Usage
Custom options:
--allocation_hostname=<hostname>, default=<os-hostname> Allocation host
--allocation_requirements=<requirements> Resource requirements to be allocate
--allocation_timeout=<timeout>, default=10 Allocation timeout in seconds
--allocation_resource_list_file=<filename>, default=resources.json
Available resorces list
--allocation_lock_folder=<folder>, default=<os-tmp-path> allocation lockfiles folder
<requirements>
can be json-string or key-value pairs. requirements have to match available resources to make allocation possible. Key-value pairs example: key=value&key2=value2
Example:
See example test. Usage:
cd example
pytest --allocation_hostname localhost -s --allocation_lock_folder . .
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for pytest_lockable-0.2.2-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9965f8490a08dd435c83c659be0a7f3990ae9684eb34a2fd5434b2d0ab497c13 |
|
MD5 | 0ccbafdb42caaade3c7142a5fc423c60 |
|
BLAKE2b-256 | ff80373185ab94c51f5e55e70322e1f58d8aaa14e8099844c96a47dd30f47bee |