From 2bbc533fabaa3160c70f9979fe1c0740715b8cb7 Mon Sep 17 00:00:00 2001 From: odudex Date: Thu, 26 Sep 2024 11:59:32 -0300 Subject: [PATCH 1/2] fix camera initialization for cube --- mkdocs.yml | 2 +- pyproject.toml | 2 +- src/krux/camera.py | 13 +++++-------- src/krux/metadata.py | 2 +- 4 files changed, 8 insertions(+), 11 deletions(-) diff --git a/mkdocs.yml b/mkdocs.yml index 2b9706e5..31bc9666 100644 --- a/mkdocs.yml +++ b/mkdocs.yml @@ -51,7 +51,7 @@ edit_uri: edit/main/docs docs_dir: docs site_dir: public extra: - latest_krux: krux-v24.09.0 + latest_krux: krux-v24.09.1 latest_installer: v0.0.20-alpha-2 latest_installer_rpm: krux-installer-0.0.20_alpha-2-1.x86_64.rpm latest_installer_deb: krux-installer_0.0.20-alpha-2_amd64.deb diff --git a/pyproject.toml b/pyproject.toml index 3e68aab4..2e7a8077 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -22,7 +22,7 @@ [tool.poetry] name = "krux" -version = "24.09.0" +version = "24.09.1" description = "Open-source signing device firmware for Bitcoin" authors = ["Jeff S "] diff --git a/src/krux/camera.py b/src/krux/camera.py index fae0743a..174b27de 100644 --- a/src/krux/camera.py +++ b/src/krux/camera.py @@ -51,15 +51,12 @@ def __init__(self): def initialize_sensor(self, grayscale=False): """Initializes the camera""" self.antiglare_enabled = False - if self.cam_id in (OV7740_ID, GC2145_ID): - sensor.reset(freq=18200000) - if board.config["type"] == "cube": - # Rotate camera 180 degrees on Cube - sensor.set_hmirror(1) - sensor.set_vflip(1) - else: - sensor.reset() + sensor.reset(freq=18200000) self.cam_id = sensor.get_id() + if board.config["type"] == "cube": + # Rotate camera 180 degrees on Cube + sensor.set_hmirror(1) + sensor.set_vflip(1) self.mode = COLOR_MODE if grayscale and self.cam_id != GC2145_ID: # GC2145 does not support grayscale diff --git a/src/krux/metadata.py b/src/krux/metadata.py index 314d5565..572663a9 100644 --- a/src/krux/metadata.py +++ b/src/krux/metadata.py @@ -19,5 +19,5 @@ # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN # THE SOFTWARE. -VERSION = "24.09.0" +VERSION = "24.09.1" SIGNER_PUBKEY = "03339e883157e45891e61ca9df4cd3bb895ef32d475b8e793559ea10a36766689b" From 49c107d3fec4e3722c6b0cceda5efa132804ea82 Mon Sep 17 00:00:00 2001 From: odudex Date: Thu, 26 Sep 2024 13:01:20 -0300 Subject: [PATCH 2/2] add check on camera initialization parameters on camera tests --- tests/test_camera.py | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/tests/test_camera.py b/tests/test_camera.py index a8c8fc78..6056109b 100644 --- a/tests/test_camera.py +++ b/tests/test_camera.py @@ -10,7 +10,8 @@ def test_init(mocker, m5stickv): assert isinstance(c, Camera) -def test_initialize_sensors(mocker, m5stickv): +def test_initialize_sensors(mocker, multiple_devices): + import board import krux from krux.camera import Camera, OV7740_ID, OV2640_ID, GC0328_ID, GC2145_ID @@ -30,6 +31,17 @@ def test_initialize_sensors(mocker, m5stickv): if config_method: getattr(c, config_method).assert_called() + if board.config["type"] == "cube" or c.cam_id == OV2640_ID: + krux.camera.sensor.set_vflip.assert_called_with(1) + else: + krux.camera.sensor.set_vflip.assert_not_called() + krux.camera.sensor.set_vflip.reset_mock() + + if board.config["type"] == "cube": + krux.camera.sensor.set_hmirror.assert_called_with(1) + else: + krux.camera.sensor.set_hmirror.assert_not_called() + krux.camera.sensor.reset.assert_called() krux.camera.sensor.set_pixformat.assert_called() assert (