Templates for testing with strings
Project description
Templates for testing with strings
Designed with pytest.mark.parametrize in mind
Work with subclasses inheriting from the templatest.BaseTemplate abstract base class
To use the inherited class decorate it with templatest.templates.register and ensure the module it is in is imported at runtime
As there will be no need to import anything from this module related to this package, this can be ensured by placing it in tests/__init__.py
>>> # tests/__init__.py
>>>
>>> import templatest
>>>
>>> @templatest.templates.register
... class _ExampleTemplate(templatest.BaseTemplate):
... @property
... def template(self) -> str:
... return "Hello, world"
...
... @property
... def expected(self) -> str:
... return "Expected result"
The class’s properties will then be available in the templatest.templates.registered object as an instance of templatest.Template named tuple
>>> templatest.templates.registered
<Registered [Template(name='example-template', template='Hello, world', expected='Expected result')]>
Organise tests by prefixing subclasses for common tests
>>> # tests/__init__.py
>>>
>>> @templatest.templates.register
... class _ErrExampleTemplate(templatest.BaseTemplate):
...
... @property
... def template(self) -> str:
... return "Goodbye, world..."
...
... @property
... def expected(self) -> str:
... return "Goodbye, world..."
>>>
>>> templatest.templates.registered.getids()
('example-template', 'err-example-template')
>>>
>>> templatest.templates.registered.filtergroup('err').getids()
('example-template',)
>>>
>>> templatest.templates.registered.getgroup('err').getids()
('err-example-template',)
Registered.filtergroup can be chained, but this won’t work for Registered.getgroup
More succinctly, multiple prefixes can be used
>>> # tests/__init__.py
>>>
>>> @templatest.templates.register
... class _MultiExampleTemplate(templatest.BaseTemplate):
...
... @property
... def template(self) -> str:
... return "Hello world, and goodbye world..."
...
... @property
... def expected(self) -> str:
... return "Hello world, and goodbye world..."
>>>
>>> templatest.templates.registered.filtergroup('err').filtergroup('multi').getids()
('example-template',)
>>>
>>> templatest.templates.registered.getgroup('err').getgroup('multi').getids()
()
>>>
>>> templatest.templates.registered.filtergroup('err', 'multi').getids()
('example-template',)
>>>
>>> templatest.templates.registered.getgroup('err', 'multi').getids()
('err-example-template', 'multi-example-template')
Additionally, templates can be referenced by index
>>> templatest.templates.registered.getindex('example-template')
0
>>> templatest.templates.registered.getindex('err-example-template')
1
>>> registered = templatest.templates.registered[0]
>>> registered.name
'example-template'
>>> registered.template
'Hello, world'
>>> registered.expected
'Expected result'
>>> name, template, expected = templatest.templates.registered[1]
>>> name
'err-example-template'
>>> template
'Goodbye, world...'
>>> expected
'Goodbye, world...'
And a template can be returned by name
>>> templatest.templates.registered.getbyname('example-template')
Template(name='example-template', template='Hello, world', expected='Expected result')
>>> templatest.templates.registered.getbyname('err-example-template')
Template(name='err-example-template', template='Goodbye, world...', expected='Goodbye, world...')
Example usage with a parametrized test
>>> # tests/_test.py
>>>
>>> import pytest
>>>
>>> from templatest.templates import registered as r
>>>
>>> @pytest.mark.parametrize("n,t,e", r, ids=r.getids())
... def test_example_all(n: str, t: str, e: str) -> None: ...
>>>
>>> @pytest.mark.parametrize("n,t,e", r.filtergroup('err'), ids=r.filtergroup('err').getids())
... def test_example_no_errs(n: str, t: str, e: str) -> None: ...
>>>
>>> @pytest.mark.parametrize("n,t,e", r.getgroup('err'), ids=r.getgroup('err').getids())
... def test_example_errs(n: str, t: str, e: str) -> None:
... with pytest.raises(Exception) as err:
... raise Exception(e)
...
... assert str(err.value) == e
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
File details
Details for the file templatest-0.3.0.tar.gz
.
File metadata
- Download URL: templatest-0.3.0.tar.gz
- Upload date:
- Size: 8.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.13 CPython/3.8.11+ Linux/5.16.18-200.fc35.x86_64
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f1596907a1b68df21052d24a1d42d4af2c1764eb62ecdad766123c58ea8b39e8 |
|
MD5 | 59be5eeb0aeffd4552527eafd00fe096 |
|
BLAKE2b-256 | be1c924f0e62a95083e3f174968294a8025c59efa1fc5b5c0a02a23cff90e22a |
File details
Details for the file templatest-0.3.0-py3-none-any.whl
.
File metadata
- Download URL: templatest-0.3.0-py3-none-any.whl
- Upload date:
- Size: 7.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.13 CPython/3.8.11+ Linux/5.16.18-200.fc35.x86_64
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b99ed6ca6ba6c58d36fcafa605020e98c6e10ab9865f6bd52254d88e46e1fb97 |
|
MD5 | 95eba7d362aedb2bdf9a4260372d6978 |
|
BLAKE2b-256 | 4defc22f907ab8c3dbf8bfb6da68e8a51c646d941aa7922c13c094b44f7914b3 |