A utility for managing mosaik's entity identifiers.
Project description
Mosaik EID
Mosaik EID supports creating Mosaik scenarios by managing the identifiers of the entities.
Status
Motivation
Traditionally, mosaik entities are created with hard coded names. Mosaik EID intends to be easier to use and less error-prone than to hard coding values. The clean and pythonic API encourages creating scenarios in a DRY fashion.
Design
The package contains a parser, generator, data model and exceptions around creating such names.
The data model is based upon an
Enum
.
Building upon that is a manager which issues entity identifiers
based on the entity type and a serial number.
The entity manager implements the borg pattern and
can thus be instantiated at will without losing state.
There are some basic entity types predefined,
but they can be extended by registering additional types.
Compatibility
It is allowed to register entity names with arbitrary capitalization,
for example CHP
, BioGas
or wind
or lv_bat_liion_3_5_10
.
All components are tested with 100 % test coverage and hopefully many corner cases
caught.
There are extensive unit, integration and functional tests.
Tests are integrated into tox to ensure compatibility across some python
implementations.
These are: CPython 2.7, Python 3.6, CPython 3.7, PyPy2v6 and PyPy3v6
Limitations
-
Thread safety is not yet implemented because it seems to have little value.
-
Entity types need to be valid Python identifiers.
-
PyPy3 does not currently work under Windows 10 because of an unresolved a bug in pypy.
Tests
This package uses
unittest
for writing tests,
nose
for test discovery and
tox
for running them on multiple python versions.
Cloning the Source
git clone https://eprojects.offis.de/mosaik-eid/git/mosaik-eid.git
Creating the Virtual Environment
Under Linux:
virtualenv -p python3.7 venv
Under Windows:
virtualenv -p "C:\Program Files\Python37\python.exe" venv
Installing the Requirements
python -m pip install --upgrade -r requirements.d/venv.txt
Running the Tests
tox --parallel all
Testing the Coverage
python -m coverage html mosaik_eid/*.py
Under Linux
xdg-open htmlcov/index.html
Under Windows
start htmlcov/index.html
Using the Library
>>> from mosaik_eid.eid_registry import EidRegistry
>>> e_type = EntityTypeRegistry.register(e_type='biogas')
>>> for _ in range(3):
... next(EidManager(e_type=e_type))
...
'biogas-0'
'biogas-1'
'biogas-2'
See tests/functional
for more practical examples of intended use.
Developing the Library
For development purposes, use one of the virtual environment under .tox your choice.
Freezing the Virtual Environment Requirements
Under Linux
venv/bin/python -m pip freeze --all --exclude-editable > requirements.d/venv.txt
# And remove line beginning with package name
Under Windows
venv\Scripts\python.exe -m pip freeze --all --exclude-editable > requirements.d/venv.txt
# And remove line beginning with package name
Freezing the Tox Requirements
Under Linux
.tox/py37/bin/python -m pip freeze --all --exclude-editable > requirements.d/base.txt
# And remove line beginning with package name
Under Windows
.tox\py37\Scripts\python -m pip freeze --all --exclude-editable > requirements.d/base.txt
# And remove line beginning with package name
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 Distributions
Built Distribution
Hashes for mosaik.EId-0.1.0rc20200131090841-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 79a3f2b821e46a3b20b4a54b65b64e1829cdf1a1a4139c3f7ad31162ba7f1e30 |
|
MD5 | 5cd2008f9492edaf284dadd9b16c5f88 |
|
BLAKE2b-256 | ab17a1eaeb57acba9eac40b780b6ae25d19b8651e34f61669aef6bd8883334bc |