-
Notifications
You must be signed in to change notification settings - Fork 447
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
fix: attach container stdin on tutor dev start <service> #1152
fix: attach container stdin on tutor dev start <service> #1152
Conversation
Thanks for the PR Danyal! This is a problem I have noticed on Ubuntu as well. I'm able to attach to an individual container's stdout by doing, for example, I'm not super keen to add a new command, but breakpoint debugging is definitely something we all need. I'll test this out and leave a review soon. |
I was hoping I was the only one who observed that issue... EDIT: actually,
|
@regisb, I get the same error as you do which prompted me to make this PR. I also initially thought that |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is working great for me. Can you update those dev docs that I linked in my comment above?
EDIT: In the dev docs, please also mention that the way to detach from the container without shutting it down is to send Ctrl-p Ctrl-q
.
changelog.d/20241105_162158_danyal.faheem_add_dev_attach_command.md
Outdated
Show resolved
Hide resolved
cf149e6
to
e54b670
Compare
Hey @kdmccormick, I've updated the docs as well. Can you take another look and let me know what you think? |
6f2a518
to
5848679
Compare
Based on my experience, it seems that |
@regisb , I really like that idea, especially since I cannot imagine any situation where I run There is only one minor problem:
If we went with your proposal, that would mean that What do you think @regisb , go forward with modifying |
Yes, I think we should do that. I honestly didn't know about escape commands, as I just ctrl+c all the time. In the process I just discovered that we also need to ctrl+p+q on So my vote goes to changing the "start" command. Especially since it's so easy to run |
@Danyal-Faheem could you incorporate Régis's suggestion as well as a help message for detachment? |
Hey @kdmccormick, sorry about that. I've been pretty busy the past few weeks. I'll try to make the requested changes this week. |
5848679
to
caa6e0b
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
A couple small requests, otherwise this looks great and works great.
if build: | ||
command.append("--build") | ||
if detach: | ||
# We have to run the container in detached mode first to attach to it | ||
if detach or attach: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you for the comment 😂
changelog.d/20241205_211837_danyal.faheem_add_dev_attach_command.md
Outdated
Show resolved
Hide resolved
Co-authored-by: Kyle McCormick <[email protected]>
Co-authored-by: Kyle McCormick <[email protected]>
tutor/commands/compose.py
Outdated
@@ -245,14 +245,22 @@ def start( | |||
services: list[str], | |||
) -> None: | |||
command = ["up", "--remove-orphans"] | |||
attach = len(services) == 1 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nit: we can simplify the code slightly by writing:
attach = len(services) == 1 and not detach
Then below:
if detach:
command.append("-d")
...
if attach:
...
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That's a great suggestion, I've made the change.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good and works great. This is an important bugfix, thank you @Danyal-Faheem !
Edx-platform developers regularly utilize debuggers inside their codebase and the
tutor dev start
command does not allow attaching to containers on certain OSes such as MacOS. This command will allow users to attach a single running container using thedocker compose attach
command.Caveats: