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

python 3.5 support #50

Closed
pohmelie opened this issue Oct 15, 2015 · 17 comments
Closed

python 3.5 support #50

pohmelie opened this issue Oct 15, 2015 · 17 comments

Comments

@pohmelie
Copy link

Thanks for awesome project 👍
When will quamash start working with python 3.5 on windows? Is it stopped by missed binary packages PyQt 5.5.1 (will support 3.5), which stopped by Qt 5.5.1?
My app works fine on ubuntu with python 3.4.3 and PyQt 5.5, and have some known troubles with https on windows (cause event loop, as far as I remember). Right now I have windows python 3.5 + PyQt 5.5.1-snapshot builded from source and get such traceback (it is not about https part):

Traceback (most recent call last):
  File "C:\Python35\lib\asyncio\coroutines.py", line 270, in _format_coroutine
    coro_code = coro.gi_code
AttributeError: '_DetachedRequestContextManager' object has no attribute 'gi_code'

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "C:\pro\py\bazar-watcher\bazar_parser.py", line 98, in bazar_theme_retriever
    yield from job(task)
  File "C:\pro\py\bazar-watcher\bazar_parser.py", line 32, in job
    10,
  File "C:\Python35\lib\asyncio\tasks.py", line 365, in wait_for
    fut = ensure_future(fut, loop=loop)
  File "C:\Python35\lib\asyncio\tasks.py", line 526, in ensure_future
    task = loop.create_task(coro_or_future)
  File "C:\Python35\lib\asyncio\base_events.py", line 216, in create_task
    task = tasks.Task(coro, loop=self)
  File "C:\Python35\lib\asyncio\tasks.py", line 77, in __init__
    self._loop.call_soon(self._step)
  File "C:\Python35\lib\site-packages\quamash\__init__.py", line 370, in call_soon
    return self.call_later(0, callback, *args)
  File "C:\Python35\lib\site-packages\quamash\__init__.py", line 345, in call_later
    .format(callback, args, delay))
  File "C:\Python35\lib\asyncio\futures.py", line 194, in __repr__
    info = self._repr_info()
  File "C:\Python35\lib\asyncio\tasks.py", line 102, in _repr_info
    coro = coroutines._format_coroutine(self._coro)
  File "C:\Python35\lib\asyncio\coroutines.py", line 272, in _format_coroutine
    coro_code = coro.cr_code
AttributeError: '_DetachedRequestContextManager' object has no attribute 'cr_code'
@aknuds1
Copy link
Collaborator

aknuds1 commented Oct 16, 2015

The initial exception doesn't quite look like it has anything to do with Quamash. Where does _DetachedRequestContextManager stem from?

@pohmelie
Copy link
Author

Hm, google said, that it is from aiohttp. Line 32 in job is:

response = yield from asyncio.wait_for(
    aiohttp.get(task.url),
    10,
)

This code works fine on 3.4.3 with quamash. You think it is aiohttp issue?

@aknuds1
Copy link
Collaborator

aknuds1 commented Oct 16, 2015

It does look as if _DetachedRequestContextManager is passed to _format_coroutine as a coroutine for some reason, and _format_coroutine expects it to have a different interface.

@aknuds1
Copy link
Collaborator

aknuds1 commented Oct 16, 2015

What you can do to debug in the meantime is to see if self._coro is a _DetachedRequestContextManager line 102 of file "C:\Python35\lib\asyncio\tasks.py" (in _repr_info), with Python 3.4.

@aknuds1
Copy link
Collaborator

aknuds1 commented Oct 16, 2015

Forgot to specify at first, that I'd like you to compare to what happens in Python 3.4, since that works. If the coro is a _DetachedRequestContextManager then too, the problem should be that _DetachedRequestContextManager is incompatible.

@pohmelie
Copy link
Author

I made test. The _coro is _DetachedRequestContextManager only with 3.5. Anyway, there is some PY35-only code in aiohttp, and I have installed alpha version.

@aknuds1
Copy link
Collaborator

aknuds1 commented Oct 16, 2015

I think I would try to debug why _DetachedRequestContextManager is passed as the coro with 3.5, sounds as if it shouldn't be.

@pohmelie
Copy link
Author

There is duality for python versions: https://github.com/KeepSafe/aiohttp/blob/master/aiohttp/client.py#L413-L417
which may cause some problems. But aiohttp master have commits almost every day, so I think it's better to wait until stable release. aiohttp issues search have not _DetachedRequestContextManager.

@aknuds1
Copy link
Collaborator

aknuds1 commented Oct 16, 2015

In that case, it looks as if _DetachedRequestContextManager has the wrong coro interface.

@Insoleet
Copy link
Contributor

Hello,

I have the same problem. What are supposed to be contained in gi_code and cr_code ? The ContextManager doesn't look like a coroutine. I think there is a bug when passing the coroutine somewhere in the code...

@harvimt
Copy link
Owner

harvimt commented Oct 23, 2015

I thought it looked like a problem with aiohttp and not quamash?

On Fri, Oct 23, 2015 at 9:16 AM, Insoleet [email protected] wrote:

Hello,

I have the same problem. What are supposed to be contained in gi_code and
cr_code ? The ContextManager doesn't look like a coroutine. I think there
is a bug when passing the coroutine somewhere in the code...


Reply to this email directly or view it on GitHub
#50 (comment).

@pohmelie
Copy link
Author

@harvimt true. But it can't be tested well, since there is no pyqt for 3.5. I've tested it again (cause aiohttp 18.1 releazed), but nothing changes.

@pohmelie
Copy link
Author

Oh, missed that traceback change:

Traceback (most recent call last):
  File "C:\Python35\lib\asyncio\coroutines.py", line 270, in _format_coroutine
    coro_code = coro.gi_code
AttributeError: '_RequestContextManager' object has no attribute 'gi_code'

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "bazar-watcher.py", line 304, in Sender
    20
  File "C:\Python35\lib\asyncio\tasks.py", line 378, in wait_for
    return fut.result()
  File "C:\Python35\lib\asyncio\futures.py", line 274, in result
    raise self._exception
  File "C:\Python35\lib\asyncio\tasks.py", line 239, in _step
    result = coro.send(value)
  File "C:\pro\py\bazar-watcher\vk_sender.py", line 58, in send_message
    links.append((yield from self.upload_photo(file_like)))
  File "C:\pro\py\bazar-watcher\vk_sender.py", line 45, in upload_photo
    response = yield from self.vk.photos.getMessagesUploadServer()
  File "C:\pro\py\bazar-watcher\aiovk\api.py", line 75, in make_request
    response = yield from self.send_api_request(method_request)
  File "C:\pro\py\bazar-watcher\aiovk\api.py", line 127, in send_api_request
    response = yield from self.send_request(url, method_args, timeout)
  File "C:\pro\py\bazar-watcher\aiovk\api.py", line 137, in send_request
    timeout=timeout,
  File "C:\Python35\lib\asyncio\tasks.py", line 365, in wait_for
    fut = ensure_future(fut, loop=loop)
  File "C:\Python35\lib\asyncio\tasks.py", line 526, in ensure_future
    task = loop.create_task(coro_or_future)
  File "C:\Python35\lib\asyncio\base_events.py", line 216, in create_task
    task = tasks.Task(coro, loop=self)
  File "C:\Python35\lib\asyncio\tasks.py", line 77, in __init__
    self._loop.call_soon(self._step)
  File "C:\pro\py\bazar-watcher\quamash\__init__.py", line 373, in call_soon
    return self.call_later(0, callback, *args)
  File "C:\pro\py\bazar-watcher\quamash\__init__.py", line 348, in call_later
    .format(callback, args, delay))
  File "C:\Python35\lib\asyncio\futures.py", line 194, in __repr__
    info = self._repr_info()
  File "C:\Python35\lib\asyncio\tasks.py", line 102, in _repr_info
    coro = coroutines._format_coroutine(self._coro)
  File "C:\Python35\lib\asyncio\coroutines.py", line 272, in _format_coroutine
    coro_code = coro.cr_code
AttributeError: '_RequestContextManager' object has no attribute 'cr_code'

@pohmelie
Copy link
Author

Without quamash I got:

aiohttp.errors.ClientOSError: [Errno 1] Cannot connect to host api.vk.com:443 ssl:True [Can not connect to api.vk.com:443 [[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:646)]]

But this is just cause Windows, I think. Same code with Ubuntu 3.4.3 and 3.5.0 works just fine (it have some OAuth2 exceptions, but it does not matter). What I have done is isolate aiohttp part and run it without qt and quamash.
So, probably, this is not just aiohttp, but this need some research.

@Insoleet
Copy link
Contributor

I handled to reproduce the bug with aiohttp without quamash in aio-libs/aiohttp#590 .

@pohmelie
Copy link
Author

@Insoleet brilliant! 👍

@asvetlov
Copy link

Please close the issue, fixed by aiohttp 0.18.3 release.

@aknuds1 aknuds1 closed this as completed Oct 25, 2015
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

No branches or pull requests

5 participants