-
Notifications
You must be signed in to change notification settings - Fork 399
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
Reimplement the live TUI using textual #274
Conversation
Thanks a lot for the work on this! This is quite a large PR, so I haven't yet made time to review this, but I definitely appreciate the work you've put in here! |
Sorry, @ayshiff - we've owed you a response on this for far too long, and I just haven't had the bandwidth to sit down and give this a proper review. First of all: holy cow, this is really impressive! Being able to use the mouse wheel to scroll the TUI is very, very cool. And it's much, much faster than the existing Rich TUI. So much faster that we probably need to put in some sort of a delay: I notice that right when the Textual TUI first appears, before the grid is populated for the first time, the live memory graph in the top right starts off narrow, and then when we start getting samples it abruptly expands to the appropriate width. That seems like a minor bug. There's a small omission, as well: on the Rich TUI, there's a dotted line in between the "Current heap size:" line and the top of the location grid. That line isn't just a separator, it's also a "progress bar", let's say. It shows what percentage the current heap size is, compared to the maximum heap size we ever saw. I think we want to keep that, though we could pick a different way to draw it that feels more natural for Textual. This handles different terminal sizes pretty well, but not perfectly. I notice that if there's not enough horizontal room for the Memory graph in the top right, it seems to line wrap (you'll notice this if you try making the terminal window too skinny). Also, I notice that if I fullscreen my terminal (63 lines x 239 columns, it seems), there are a few unnecessary blank lines above and below the "Current heap size" line. To address your points:
Let's hold off on worrying about tests for now. Let's get the interface as polished as we can and working just how we want it to, and then we'll figure out what automated testing we can do. We have a lot of flexibility here, and we can always choose to throw the existing tests away and start from scratch if that turns out to be what makes the most sense. I've never worked with Textual before, but the docs have a
That's interesting - sometimes the arrows switch threads, sometimes they scroll the table! We may just need to pick different keys for these things. Perhaps < and > for switching threads instead of left and right arrow, and perhaps even a clickable button for users with mouse support enabled. I noticed something else funny with the scroll bar as well - if I scroll the table all the way to the bottom, then switch threads, and then switch back to the first thread, I see that the scroll bar looks as though I'm at the bottom, when actually the rows being shown are the ones at the top. It looks like we may need to re-sync the scroll bar with the grid position, or re-scroll the grid to whatever position the scroll bar thinks we should be at. Maybe remember the position when we switch away from a thread, and try to scroll back to that same position when we return to that thread... I'm not sure what the limit of what we can do for ourselves there is, and at what point we might need a feature request to the Textual devs.
I wouldn't! If someone makes their terminal too narrow to be able to see all the columns, being able to scroll to see the others is a nice feature.
Can you give any specifics for that? I don't think I managed to reproduce that, but I'm not sure what I should have been looking for.
I'm not too worried about the style matching. If we find a nicer or prettier way to display anything, I don't want to be held back because of backwards compatibility with how the old grid table looked. I'm happy to take this as an opportunity to modernize the look and feel, so I think we should make choices based on what looks and feels right, not just on what the Rich version looked like. I realize that it's been a while since you sent this PR - is this still something that you're interested in pushing forward? If not, we can try to pick this up ourselves and polish it and finish it off sometime in the next month or so, but if you're interested we'd still be very glad to have your help, and I'll try to be more responsive to any future requests for comment. I really can't stress enough: this really looks awesome already, and I'm thrilled with everything you've done so far. This is very, very cool. |
Ping - are you still interested in pushing this forward, @ayshiff? |
Yes definitely! Sorry for the delay, I've been a little busy lately. |
3ba7855
to
e640ef1
Compare
@ayshiff We've decided to take this PR over. Holy cow, this was a lot more work than I expected, so thanks so much for getting the ball rolling for us! I've got one last thing I need to ask you for, though. Would you mind editing the commit message for your commit to add a DCO signoff? If you're using the github CLI, you should be able to do that using something like: gh pr checkout -f 274 to check out the latest commits that I've pushed, then git rebase -i c5672788e1472cb3a6eda4a65c400bd6ca8764a7~1 then change the first line from "pick" to "edit", and save and quit. From there you can: git commit --amend -C HEAD -s to add the signoff to the commit message, and finally git rebase --continue to finish rebasing and
to push the updated commits. |
e640ef1
to
3f75279
Compare
@godlygeek Thanks a lot for taking over my work! And sorry for having been a bit busy lately. |
Codecov ReportAttention:
Additional details and impacted files@@ Coverage Diff @@
## main #274 +/- ##
==========================================
+ Coverage 92.23% 92.24% +0.01%
==========================================
Files 91 91
Lines 10872 11029 +157
Branches 1499 1520 +21
==========================================
+ Hits 10028 10174 +146
- Misses 841 851 +10
- Partials 3 4 +1
Flags with carried forward coverage won't be shown. Click here to find out more.
☔ View full report in Codecov by Sentry. |
Signed-off-by: Remi Doreau <[email protected]>
This test was leaving a profile function installed when it shouldn't. Signed-off-by: Matt Wozniski <[email protected]>
This will allow us to migrate the TUI to Textual while leaving the summary reporter on Rich. Signed-off-by: Matt Wozniski <[email protected]>
4fba1f6
to
33aba70
Compare
src/memray/reporters/tui.py
Outdated
|
||
default_sort_column_id = 1 | ||
sort_column_id = reactive(default_sort_column_id) | ||
max_rows = reactive(None) |
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.
I don't think this is used anywhere
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.
Indeed, will remove
src/memray/reporters/tui.py
Outdated
snapshot = reactive(_EMPTY_SNAPSHOT) | ||
paused = reactive(False) | ||
disconnected = reactive(False) | ||
footer_message = reactive("") |
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 seems is also not used anywhere
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.
Indeed, will remove
src/memray/reporters/tui.py
Outdated
|
||
from memray import AllocationRecord | ||
from memray import SocketReader | ||
from memray._memray import size_fmt | ||
|
||
MAX_MEMORY_RATIO = 0.95 | ||
|
||
DEFAULT_TERMINAL_LINES = 24 |
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.
Is this used? Seems that we copied it to summary.py
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.
Used only for type annotations.
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.
oh, wait, I misread - I thought you were asking about the highlighted line in the diff, not the last line in it. Yep, that's unused now.
src/memray/reporters/tui.py
Outdated
table.sort(table.ordered_columns[sort_column_id].key, reverse=True) | ||
|
||
@staticmethod | ||
def _percent_to_style( |
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.
is this needed for something?
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.
Not anymore! Will remove.
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.
Appart from the small nits to delete some unneeded things: LGTM.
Fantastic work @godlygeek! 🚀 I know how difficult was to do the refactor. You did a fantastic work ✨ Outstanding!
And thanks a lot for all the work and design in the initial version @ayshiff! This was certainly NOT a small issue, so this was super useful and you helped the project a lot ❤️
84d3073
to
5196081
Compare
Signed-off-by: Matt Wozniski <[email protected]>
Everything this test exercises is also exercised by the `test_live_tracking_server_exits_properly_on_sigint` test that still remains in the `TestLiveRemoteSubcommand` class (same test name, different test class). That test uses `_wait_until_process_blocks` to ensure that the SIGINT is sent at a known point in the process's execution, but this one can't. With this test, the SIGINT is sometimes delivered while the TUI is still starting up, and at that point, the signal can result in exceptions (teardown of the TUI tries to access attributes that weren't created because startup was interrupted). So, remove this test and rely on the remaining one for coverage of how SIGINT behaves when interrupting our TUI. Signed-off-by: Matt Wozniski <[email protected]>
Capture stdout from some tests that run the TUI, so that it doesn't flash across the screen while running the test suite. Signed-off-by: Matt Wozniski <[email protected]>
5196081
to
3e3473a
Compare
Closes #238
Describe your changes
This patch ports TUI using rich to textual.
Testing performed
Here is a small sketch representing the different components of the live TUI and their interactions.
Additional context
This is still a work in progress since I might need some help to:
tests/unit/test_tui_reporter.py
but couldn't find the correct way to make it work with my work).switching threads
behavior.Remove the horizontal data table scroll.rich
version (e.g. the data table).Thanks for your help! :)