Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

pythoncom has no attribute 'CoUnitialize' #41

Open
drewr95 opened this issue Oct 10, 2022 · 2 comments
Open

pythoncom has no attribute 'CoUnitialize' #41

drewr95 opened this issue Oct 10, 2022 · 2 comments

Comments

@drewr95
Copy link
Contributor

drewr95 commented Oct 10, 2022

I'm developing a C++ application and using Pybind11 to reference the j1939 library. When calling the stop method of the ecu, I'm getting the following:

Exception in thread j1939.ecu job_thread:
Traceback (most recent call last):
File "C:\Users\darife\AppData\Local\Programs\Python\Python310\Lib\threading.py", line 1016, in _bootstrap_inner
self.run()
File "C:\Users\darife\AppData\Local\Programs\Python\Python310\Lib\threading.py", line 953, in run
self._target(*self._args, **self._kwargs)
File "C:\Users\darife\AppData\Local\Programs\Python\Python310\Lib\site-packages\j1939\electronic_control_unit.py", line 313, in _async_job_thread
pythoncom.CoUnitialize()
AttributeError: module 'pythoncom' has no attribute 'CoUnitialize'. Did you mean: 'CoInitialize'?

I saw @GraysonNocera mentioned about calling the 'CoUnitialize' method in his ticket #39 . Any ideas why this worked but I'm getting an error on my end?

Pip says I'm using can-j1939==2.0.12

@PBreier-Simi
Copy link

Hi,
I'm using can-j1939==2.0.12 and had the same error message. The problem is a typo in electronic_control_unit.py line 313, where it says pythoncom.CoUnitialize().
Pythoncom only has CoUninitialize(), so by changing this line to pythoncom.CoUninitialize() the bug is fixed.

@grant-allan-ctct
Copy link
Collaborator

grant-allan-ctct commented Dec 2, 2023

I wonder if there is any kind of unit test we can write to verify things are, and stay, working. Perhaps this can be achieved by introducing a unit test into test_ecu.py which calls feeder.stop() method (which in turn will call stop() of its wrapped ecu instance, seems like - I don't see any unit test currently that exercises the stop() method of class ElectronicControlUnit.)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants