-
Notifications
You must be signed in to change notification settings - Fork 285
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
PythonRepl over AsyncSSH mixes inputs, corrupts connection #561
Comments
Thanks for reporting! I don't have a solution right now, but I can reproduce this. It's definitely a bug. |
I should also add that even if we manage to make it work again (I think this used to work), the SSH/telnet functionality of ptpython has its limitations. The main problem being that there's only one |
I think mostly just
I can log to this interpreter from different ssh / telnet sessions and it just works without hijacking inputs. Frankly, when i noticed that ssh embed demo, i thought it'd be drop-in replacement, with better REPL experience on top (twisted manhole has some support for deferred / future calls out of the box + basic coloring, but that's it). I've spent some time trying to debug that input mixup expecting some easy to spot place, but came empty-handed. |
I'm encountering strange issue with PythonRepl over ssh. Example ptpython/examples/asyncio-ssh-python-embed.py using ptpython.contrib.asyncssh_repl.py bundled in sources is obsolete (at least from 3.0.28), but it looks like prompt_toolkit.contrib.ssh.server is now the proper way to go (it even looks it was developed from the example).
Using all these as a base for my example (see below for gist), i was able to login over ssh to
PythonRepl
and everything looks fine, however only until there is another connection. Second connection then hijacks input from first. Writing to first client shows nothing, but is visible in second. As soon as any input is entered, second session fails.first client:
second client just after connect:
Now enter anything to first client, nothing will happen there, but will appear in the second. Pressing
enter
ends up with corrupted connection, disconnecting second client and leaving first client in unusable state.Server output:
Raising logging level to DEBUG doesn't show anything interesting either.
Stepping through the code with debugger prevents this corruption, so there is probably even some timing issue, but input is still mixed. When experimenting with writing to each client i've noticed other weird behavior - writing to second client and stepping through execution makes
ptpython
bottom menu disappear in the first client for a brief moment (mostly when a corouting is being scheduled). Possibly not only inputs, but even outputs are somehow connected.I've prepared minimal example as a gist: asyncio-ssh-python-embed.py. This expects server key in
ssh-keys/ssh_host_rsa_key
. It is stripped down to bare minimum, not even passing customglobals
(each command then runs in empty dict as globals and locals, triggering error on exit, but it is unrelated to this case). Most probably i'm just omitting some important setting, or not passing correct values somewhere, but examples are scarce for this usecase.The text was updated successfully, but these errors were encountered: