mirror of
https://github.com/kuhyx/testsAndMisc.git
synced 2026-07-04 12:43:12 +02:00
Split diet_guard/_gatelock.py, wake_alarm/_alarm.py, and the usage_report.py/_usage_report_parsing.py pair into focused sub-modules so every Python file is <= 500 lines, satisfying test_file_length.py. Install python-kasa into .venv (declared in requirements but missing after the 3.13->3.14 venv upgrade), fixing 8 failing smart_plug tests and restoring 100% coverage. Also includes prior in-progress work from the working tree: the wake_alarm Progress/View/Hardware field-grouping refactor, brother_printer query module + tests, diet_guard foodbank/state/cli updates, new shared coerce/logging_setup helpers, morning_routine orchestrator tweaks, dwm window-manager config, gaming scripts, and misc maintenance/digital-wellbeing script updates. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
212 lines
7.2 KiB
Python
212 lines
7.2 KiB
Python
"""Tests for brother_printer.check_brother_printer module."""
|
|
|
|
from __future__ import annotations
|
|
|
|
from io import StringIO
|
|
import subprocess
|
|
from unittest.mock import MagicMock, patch
|
|
|
|
import pytest
|
|
|
|
from python_pkg.brother_printer.check_brother_printer import (
|
|
_discover_network_printer,
|
|
_no_printer_found,
|
|
_run_network_mode,
|
|
_run_usb_mode,
|
|
main,
|
|
)
|
|
from python_pkg.brother_printer.data_classes import USBResult
|
|
|
|
MOD = "python_pkg.brother_printer.check_brother_printer"
|
|
|
|
|
|
class TestDiscoverNetworkPrinter:
|
|
@patch(f"{MOD}.shutil.which", return_value=None)
|
|
def test_no_lpstat(self, m: MagicMock) -> None:
|
|
assert _discover_network_printer() == ""
|
|
|
|
@patch("python_pkg.brother_printer._query.subprocess.run")
|
|
@patch(f"{MOD}.shutil.which", return_value="/usr/bin/lpstat")
|
|
def test_found_ip(self, w: MagicMock, mock_run: MagicMock) -> None:
|
|
mock_run.return_value = MagicMock(
|
|
stdout="device for BrotherHL1110: ipp://192.168.1.100/ipp\n",
|
|
)
|
|
assert _discover_network_printer() == "192.168.1.100"
|
|
|
|
@patch("python_pkg.brother_printer._query.subprocess.run")
|
|
@patch(f"{MOD}.shutil.which", return_value="/usr/bin/lpstat")
|
|
def test_socket(self, w: MagicMock, mock_run: MagicMock) -> None:
|
|
mock_run.return_value = MagicMock(
|
|
stdout="device for BrotherHL1110: socket://10.0.0.5:9100\n",
|
|
)
|
|
assert _discover_network_printer() == "10.0.0.5"
|
|
|
|
@patch("python_pkg.brother_printer._query.subprocess.run")
|
|
@patch(f"{MOD}.shutil.which", return_value="/usr/bin/lpstat")
|
|
def test_no_match(self, w: MagicMock, mock_run: MagicMock) -> None:
|
|
mock_run.return_value = MagicMock(
|
|
stdout="device for BrotherHL1110: usb://Brother/HL-1110\n",
|
|
)
|
|
assert _discover_network_printer() == ""
|
|
|
|
@patch("python_pkg.brother_printer._query.subprocess.run")
|
|
@patch(f"{MOD}.shutil.which", return_value="/usr/bin/lpstat")
|
|
def test_timeout(self, w: MagicMock, mock_run: MagicMock) -> None:
|
|
mock_run.side_effect = subprocess.TimeoutExpired("lpstat", 5)
|
|
assert _discover_network_printer() == ""
|
|
|
|
@patch("python_pkg.brother_printer._query.subprocess.run")
|
|
@patch(f"{MOD}.shutil.which", return_value="/usr/bin/lpstat")
|
|
def test_oserror(self, w: MagicMock, mock_run: MagicMock) -> None:
|
|
mock_run.side_effect = OSError("fail")
|
|
assert _discover_network_printer() == ""
|
|
|
|
|
|
class TestRunNetworkMode:
|
|
@patch(f"{MOD}.shutil.which", return_value=None)
|
|
def test_no_snmpwalk(self, m: MagicMock) -> None:
|
|
with (
|
|
patch("sys.stdout", new_callable=StringIO),
|
|
pytest.raises(SystemExit),
|
|
):
|
|
_run_network_mode("1.2.3.4")
|
|
|
|
@patch(f"{MOD}.display_network_results")
|
|
@patch(f"{MOD}.query_network_snmp")
|
|
@patch(f"{MOD}.shutil.which", return_value="/usr/bin/snmpwalk")
|
|
def test_success(
|
|
self,
|
|
w: MagicMock,
|
|
mock_query: MagicMock,
|
|
mock_display: MagicMock,
|
|
) -> None:
|
|
from python_pkg.brother_printer.data_classes import NetworkResult
|
|
|
|
mock_query.return_value = NetworkResult(ip="1.2.3.4")
|
|
with patch("sys.stdout", new_callable=StringIO):
|
|
_run_network_mode("1.2.3.4")
|
|
mock_display.assert_called_once()
|
|
|
|
|
|
class TestRunUsbMode:
|
|
@patch(f"{MOD}.display_usb_results")
|
|
@patch(f"{MOD}.query_usb_pjl")
|
|
def test_success(
|
|
self,
|
|
mock_query: MagicMock,
|
|
mock_display: MagicMock,
|
|
) -> None:
|
|
mock_query.return_value = USBResult()
|
|
with patch("sys.stdout", new_callable=StringIO):
|
|
_run_usb_mode("Brother USB line")
|
|
mock_display.assert_called_once()
|
|
|
|
|
|
class TestNoPrinterFound:
|
|
def test_exits(self) -> None:
|
|
with (
|
|
patch("sys.stdout", new_callable=StringIO),
|
|
pytest.raises(SystemExit),
|
|
):
|
|
_no_printer_found()
|
|
|
|
|
|
class TestMain:
|
|
@patch(f"{MOD}.reset_consumable")
|
|
def test_reset_toner(self, mock_reset: MagicMock) -> None:
|
|
main(["--reset-toner"])
|
|
mock_reset.assert_called_once_with("toner")
|
|
|
|
@patch(f"{MOD}.reset_consumable")
|
|
def test_reset_drum(self, mock_reset: MagicMock) -> None:
|
|
main(["--reset-drum"])
|
|
mock_reset.assert_called_once_with("drum")
|
|
|
|
@patch(f"{MOD}.os.geteuid", return_value=1000)
|
|
def test_not_root(self, m: MagicMock) -> None:
|
|
with (
|
|
patch("sys.stdout", new_callable=StringIO),
|
|
pytest.raises(SystemExit),
|
|
):
|
|
main([])
|
|
|
|
@patch(f"{MOD}._run_network_mode")
|
|
@patch(f"{MOD}.os.geteuid", return_value=0)
|
|
def test_with_ip(self, g: MagicMock, mock_net: MagicMock) -> None:
|
|
main(["1.2.3.4"])
|
|
mock_net.assert_called_once_with("1.2.3.4")
|
|
|
|
@patch(f"{MOD}._run_usb_mode")
|
|
@patch(f"{MOD}.find_brother_usb", return_value="Brother USB")
|
|
@patch(f"{MOD}.os.geteuid", return_value=0)
|
|
def test_usb_found(
|
|
self,
|
|
g: MagicMock,
|
|
f: MagicMock,
|
|
mock_usb: MagicMock,
|
|
) -> None:
|
|
main([])
|
|
mock_usb.assert_called_once()
|
|
|
|
def test_network_discovered(self) -> None:
|
|
from python_pkg.brother_printer.data_classes import NetworkResult
|
|
|
|
with (
|
|
patch(f"{MOD}.os.geteuid", return_value=0),
|
|
patch(f"{MOD}.find_brother_usb", return_value=""),
|
|
patch(f"{MOD}._discover_network_printer", return_value="192.168.1.100"),
|
|
patch(f"{MOD}.shutil.which", return_value="/usr/bin/snmpwalk"),
|
|
patch(f"{MOD}.query_network_snmp") as mock_query,
|
|
patch(f"{MOD}.display_network_results") as mock_display,
|
|
patch("sys.stdout", new_callable=StringIO),
|
|
):
|
|
mock_query.return_value = NetworkResult(ip="192.168.1.100")
|
|
main([])
|
|
mock_display.assert_called_once()
|
|
|
|
@patch(f"{MOD}._no_printer_found")
|
|
@patch(f"{MOD}._discover_network_printer", return_value="")
|
|
@patch(f"{MOD}.find_brother_usb", return_value="")
|
|
@patch(f"{MOD}.os.geteuid", return_value=0)
|
|
def test_nothing_found(
|
|
self,
|
|
g: MagicMock,
|
|
f: MagicMock,
|
|
d: MagicMock,
|
|
mock_no: MagicMock,
|
|
) -> None:
|
|
main([])
|
|
mock_no.assert_called_once()
|
|
|
|
@patch(f"{MOD}._no_printer_found")
|
|
@patch(f"{MOD}.shutil.which", return_value=None)
|
|
@patch(f"{MOD}._discover_network_printer", return_value="192.168.1.100")
|
|
@patch(f"{MOD}.find_brother_usb", return_value="")
|
|
@patch(f"{MOD}.os.geteuid", return_value=0)
|
|
def test_network_discovered_no_snmpwalk(
|
|
self,
|
|
g: MagicMock,
|
|
f: MagicMock,
|
|
d: MagicMock,
|
|
w: MagicMock,
|
|
mock_no: MagicMock,
|
|
) -> None:
|
|
main([])
|
|
mock_no.assert_called_once()
|
|
|
|
def test_default_argv(self) -> None:
|
|
with (
|
|
patch(f"{MOD}.sys.argv", ["prog", "--reset-toner"]),
|
|
patch(f"{MOD}.reset_consumable") as mock_reset,
|
|
):
|
|
main()
|
|
mock_reset.assert_called_once_with("toner")
|
|
|
|
@patch(f"{MOD}.os.geteuid", return_value=1000)
|
|
def test_not_root_with_args(self, g: MagicMock) -> None:
|
|
with (
|
|
patch("sys.stdout", new_callable=StringIO),
|
|
pytest.raises(SystemExit),
|
|
):
|
|
main(["1.2.3.4"])
|