mirror of
https://github.com/OMGeeky/flucto-heisskleber.git
synced 2026-01-04 02:25:24 +01:00
* #129 AsyncTcpSource enhancements - retry connection on startup (behavior is configurable) - reconnect if data receiving fails (EOF received) - add Python logging - add unit tests * remove syncronous implementations. * WIP: Refactor packer/unpacker * Refactor type hints and topic handling in console sink. * Remove comma from tcp config enum definitions * Remove references to deleted synchronous classes. * Hopefully stable interface for Packer and Unpacker. * WIP: Working with protocols and generics * Finalized Sink, Source definition. * Rename mqtt source and sink files * Rename mqtt publisher and subscriber. * Fix start function to async. * Update documentation. * Remove recursion from udp source. * rename unpack to unpacker, stay consistent. * Renaming in tests. * Make MqttSource generic. * Configure pyproject.toml to move to uv * Add nox support. * Update documentation with myst-parser and sphinx. * Mess with autogeneration of __call__ signatures. * Add dynamic versioning to hatch * Asyncio wrapper for pyserial. * Add docstrings for serial sink and source. * Refactor config handling (#171) * Removes deprecated "verbose" and "print_std" parameters * Adds class methods for config generation from dictionary or file (yaml or json at this point) * Run-time type checking via __post_init__() function * Add serial dependency. * WIP * Move broker to bin/ * Update docs. * WIP: Need to update docstrings to make ruff happy. * Move source files to src/ * Fix tests for TcpSource. * WIP: Remove old tests. * Fix docstrings in mqtt classes. * Make default tcp unpacker json_unpacker. * No failed tests if there are no tests * Update test pipeline * Update ruff pre-commit * Updated ruff formatting * Format bin/ * Fix type hints * No type checking * Make stop() async * Only test on ubuntu for now * Don't be so strict about sphinx warnings. * Rename TestConf for pytest naming compability. * Install package in editable mode for ci tests. * Update dependencies for docs generation. * Add keepalive and will to mqtt, fixes #112. * Update readme to reflect changes in usage. * Requested fixes for console adapters. * Raise correct errors in unpacker and packer. * Correct logger name for mqtt sink. * Add config options for stopbits and parity to Serial. * Remove exception logging call from yaml parser. * Add comments to clear up very implicit test. * Rename Sink -> Sender, Source -> Receiver. * Rename sink and source in tests. * Fix tests. --------- Co-authored-by: Adrian Weiler <a.weiler@aldea.de>
56 lines
1.5 KiB
Python
56 lines
1.5 KiB
Python
from dataclasses import dataclass
|
|
from typing import Any
|
|
|
|
from heisskleber.core import Unpacker, json_unpacker
|
|
|
|
|
|
@dataclass
|
|
class HotGlue:
|
|
name: str
|
|
weight: float
|
|
|
|
|
|
class DataclassUnpacker(Unpacker[HotGlue]):
|
|
"""Take a csv of 'name,weight' and construct a HotGlue dataclass.
|
|
|
|
Raises:
|
|
TypeError: The csv was not formatted properly or a dataclass could not be constructed.
|
|
|
|
"""
|
|
|
|
def __call__(self, payload: bytes) -> tuple[HotGlue, dict[str, Any]]:
|
|
extra = {"type": "custom"}
|
|
try:
|
|
name, weight = payload.decode().split(",")
|
|
return HotGlue(name, float(weight)), extra
|
|
except UnicodeDecodeError as e:
|
|
raise TypeError from e
|
|
|
|
|
|
def test_custom_unpacker() -> None:
|
|
unpacker = DataclassUnpacker()
|
|
|
|
data, extra = unpacker(b"hotglue,10.0")
|
|
assert isinstance(data, HotGlue)
|
|
assert data == HotGlue("hotglue", 10.0)
|
|
|
|
assert extra == {"type": "custom"}
|
|
|
|
|
|
def test_simple_bytestring() -> None:
|
|
"""Test packing a simple dictionary"""
|
|
|
|
test_data = b'{"key": "value"}'
|
|
data, extra = json_unpacker(test_data)
|
|
assert data == {"key": "value"}
|
|
assert extra == {}
|
|
|
|
|
|
def test_nested_dict() -> None:
|
|
"""Test packing a nested dictionary"""
|
|
test_data = b'{"string": "value", "number": 42, "nested": {"bool": true, "list": [1, 2, 3]}}'
|
|
data, extra = json_unpacker(test_data)
|
|
|
|
assert data == {"string": "value", "number": 42, "nested": {"bool": True, "list": [1, 2, 3]}}
|
|
assert extra == {}
|