У меня есть простой рабочий пример использования Python / NXT / libusb следующим образом (примечание: использование Lego NXT с интерфейсом USB):
import nxt.locator
from nxt.motor import *
def flip_cube(b):
m_arm = Motor(b, PORT_B)
m_arm.turn(75, 85)
m_arm.turn(-50, 85)
b = nxt.locator.find_one_brick()
flip_cube(b)
Выше работает отлично.
В качестве учебного упражнения я пытаюсь «объективировать» код python, чтобы я мог начать размещать библиотеки вокруг кода, но теперь библиотека LibUSB жалуется, что не может найти USB-устройство. А? Что я делаю неправильно. Вот моя попытка кода с использованием структуры класса:
import nxt.locator
from nxt.motor import *
class BasicRobotTestCase():
__test__ = True
def __init__(self):
b = nxt.locator.find_one_brick()
def flip_cube(self):
m_arm = Motor(b, PORT_B)
m_arm.turn(75, 85)
m_arm.turn(-50, 85)
def test_flip_cube(self):
flip_cube()
Когда я выполняю вышеизложенное, я получаю следующую ошибку (даже если я повторно выполню первый пример, он снова будет работать нормально):
E
======================================================================
ERROR: Failure: USBError (No such device (it may have been disconnected))
----------------------------------------------------------------------
Traceback (most recent call last):
File "/Library/Python/2.6/site-packages/nose-0.11.4-py2.6.egg/nose/loader.py", line 485, in makeTest
return self._makeTest(obj, parent)
File "/Library/Python/2.6/site-packages/nose-0.11.4-py2.6.egg/nose/loader.py", line 539, in _makeTest
return MethodTestCase(obj)
File "/Library/Python/2.6/site-packages/nose-0.11.4-py2.6.egg/nose/case.py", line 331, in __init__
self.inst = self.cls()
File "/Users/gnunez/git-projects/pdca_automation/rubics/tests/basic_robot_test_case.py", line 8, in __init__
b = nxt.locator.find_one_brick()
File "/Users/gnunez/git-projects/pdca_automation/nxt/locator.py", line 112, in find_one_brick
for s in find_bricks(host, name, silent, method):
File "/Users/gnunez/git-projects/pdca_automation/nxt/locator.py", line 43, in find_bricks
for s in socks:
File "/Users/gnunez/git-projects/pdca_automation/nxt/usbsock.py", line 83, in find_bricks
for bus in usb.busses():
File "build/bdist.macosx-10.6-universal/egg/usb/legacy.py", line 330, in busses
return (Bus(),)
File "build/bdist.macosx-10.6-universal/egg/usb/legacy.py", line 326, in __init__
self.devices = [Device(d) for d in core.find(find_all=True)]
File "build/bdist.macosx-10.6-universal/egg/usb/legacy.py", line 311, in __init__
self.configurations = [Configuration(c) for c in dev]
File "build/bdist.macosx-10.6-universal/egg/usb/core.py", line 706, in __iter__
yield Configuration(self, i)
File "build/bdist.macosx-10.6-universal/egg/usb/core.py", line 407, in __init__
configuration
File "build/bdist.macosx-10.6-universal/egg/usb/_debug.py", line 52, in do_trace
return f(*args, **named_args)
File "build/bdist.macosx-10.6-universal/egg/usb/backend/libusb10.py", line 423, in get_configuration_descriptor
config, byref(cfg)))
File "build/bdist.macosx-10.6-universal/egg/usb/backend/libusb10.py", line 357, in _check
raise USBError(_str_error[retval.value])
USBError: No such device (it may have been disconnected)