Files
pynamics/diagnostics/os_diagnostics.py

29 lines
1.6 KiB
Python
Raw Normal View History

2026-03-06 16:34:42 +00:00
from pybricks.parameters import Port
from uerrno import EAGAIN, EBUSY, ECANCELED, EINVAL, EIO, ENODEV, EOPNOTSUPP, EPERM, ETIMEDOUT
2026-03-06 18:35:52 +00:00
class OSDiagnostics:
def __init__(self, hub, motorclass):
self.motorclass = motorclass
self.successfultests = 0
self.failedtests = {}
2026-03-11 01:03:44 +00:00
def testenodev(self):
2026-03-06 18:35:52 +00:00
try:
# Try to initialize a motor on an empty port (Port.A)
print("Starting Test 6/9: ENODEV - Device Not Found Error")
input("Make sure Port A doesn't have anything plugged in, then press Enter.")
my_motor = self.motorclass(Port.A)
print("OS detected a motor when there was nothing. You may have allowed missing motors. This is useful for debugging, but not recommended for production as it can cause issues with device control.")
except OSError as ex:
# If an OSError was raised, check the specific error code
if ex.errno == ENODEV:
print("There is no motor on this port. ENODEV can be thrown and caught.\nCompleted Test 6/9: ENODEV - SUCCESSFUL")
self.successfultests += 1
elif ex.errno == EIO:
print("An unspecified error occurred (EIO).\nCompleted Test 6/9: ENODEV - FAILED")
self.failedtests["ENODEV"] = "EIO - Unspecified Error"
else:
print(f"Another error occurred with code: {ex.errno}.\nCompleted Test 6/9: ENODEV - FAILED")
self.failedtests["ENODEV"] = ex.errno
2026-03-11 01:03:44 +00:00
def print_results(self):
2026-03-06 18:35:52 +00:00
for key, value in self.failedtests():
print(f"{key}: {value}")