-
Notifications
You must be signed in to change notification settings - Fork 2.5k
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
Display crate version on timings graph #12420
Conversation
Thanks for the pull request, and welcome! The Rust team is excited to review your changes, and you should hear from @epage (or someone else) soon. Please see the contribution instructions for more information. Namely, in order to ensure the minimum review times lag, PR authors and assigned reviewers should ensure that the review label (
|
src/cargo/core/compiler/timings.js
Outdated
@@ -111,7 +111,7 @@ function render_pipeline_graph() { | |||
ctx.textAlign = 'start'; | |||
ctx.textBaseline = 'middle'; | |||
ctx.font = '14px sans-serif'; | |||
const label = `${unit.name}${unit.target} ${unit.duration}s`; | |||
const label = `${unit.name} v${unit.version}${unit.target} ${unit.duration}s`; |
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.
For me, my biggest concern is how easily can I digest the timing numbers. I feel that rendering like quote v1.0.28 0.45s
makes this difficult
Ideas
- @weihanglo mentioned only showing versions on duplicates
- In --timings: show crate version in the graph? #7384, parenthesis were used, adding noise but also making it easier to scan
- Tooltips might be a possibility
Any other ideas?
Something else I want to keep in mind is that some improvement is better than no improvement, so if we can't converge on a solution quickly enough, we probably should just move forward.
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 have no strong opinion, much like @weihanglo. I opened the PR with the simple one line solution exactly for the same reason: displaying the version always is better than not showing at all.
I can implement "showing versions on duplicates" or change the format relatively easily, but tooltips on rendered graphs might be beyond my JS abilities.
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 can definitely understanding of limited JS abilities; I'm in a similar boat :). As I said, some improvement is better than none so I didn't want to put too much of a burden on this PR.
Just checked in with @weihanglo and if you are ok with limiting this to dupes, let's go with that. We can iterate on this further later.
This comment was marked as duplicate.
This comment was marked as duplicate.
Sorry, something went wrong.
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 do believe the browser can't search in the graph itself.
Oops. My bad. I forgot it is an SVG.
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 got a simple deduplication implementation using the name and target as a "tag", something like this:
const unitCount = new Map();
// snip
const tag = `${unit.name}${unit.target}`;
const count = unitCount.get(tag) || 0;
unitCount.set(tag, count + 1);
// snip
const tag = `${unit.name}${unit.target}`;
const labelName = (unitCount.get(tag) || 0) > 1 ? `${unit.name} v${unit.version}${unit.target}` : tag;
const label = `${labelName} ${unit.duration}s`;
(See the full change in the da0fab3 commit, I'd like to squash these once we settle on a proper behavior)
But I'm still getting some duplicate behavior, apparently we are compiling the same crate twice? Or it's showing on the graph twice and I'm not sure why. It does differentiate per target, so at least that:
I'm not exactly happy with the duplicated versions, but it does seem to be at least de-duping multiple versions correctly. Unfortunately, it does create some more noise.
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.
Thanks for trying it out and sharing the results!
I am curious why syn build script (run)
doesn't have a version because that should be a dupe.
What do you think of adding separator between labelName
and duration
so we get a little bit more visual distinction? Maybe :
or -
?
But I'm still getting some duplicate behavior, apparently we are compiling the same crate twice?
I suspect this is because we compile for "host" for build scripts and "target" for everything else. We try to de-duplicate these build steps. Unsure what is going on that this de-duplication isn't working. I wonder if its related to the debug info shrinking or something else.
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 am curious why syn build script (run) doesn't have a version because that should be a dupe.
Because the target is different. I explicitly used name + target for uniqueness, but that's easy enough to change.
What do you think of adding separator between labelName and duration so we get a little bit more visual distinction? Maybe : or -?
I like :
.
@epage @weihanglo
I'm willing to implement any chosen format as long as we decide which one. I personally still lean towards always showing the versions as I find it less confusing (someone looking at this might ask: "why is it showing the version for X and Y but not Z?") but that's just me.
If consistent formatting with the rest of the output is not necessary here, may I suggest one of these formats:
serde_json v1.2.3 syn build script (run): 0.21s
serde_json (v1.2.3) syn build script (run): 0.21s
serde_json v1.2.3 syn build script (run) - 0.21s
serde_json (v1.2.3) syn build script (run) - 0.21s
Bear in mind that target can be empty string and, since we're showing versions only on duplicate entries, so can it.
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.
Unsure what is going on that this de-duplication isn't working. I wonder if its related to the debug info shrinking or something else.
Could be. I think we can move on and deal with it afterward.
Regarding the format, I'll leave the choice to you :)
BTW, could you help updates screenshots in that pages? Some of them could be in a better resolution.
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.
Thanks! Let's merge it :)
@bors r+ |
Display crate version on timings graph ### What does this PR try to resolve? Fixes #7384 The solution here is the simplest one: since duplicate crates with different versions can cause confusion, we always output the version. ### How should we test and review this PR? Build any create using the `--timings` option: ``` cargo build --timings ``` and verify the resulting HTML file. ### Additional information The formatting is consistent with how the crates are displayed in the terminal output for Cargo and also on the table below the graph. Initially, [this comment](#7384 (comment)) suggested said formatting for ease of searching, but I do believe the browser can't search in the graph itself. Sample console output: ``` Compiling lazycell v1.3.0 Compiling unicode-xid v0.2.4 Compiling unicode-width v0.1.10 Compiling glob v0.3.1 Compiling curl-sys v0.4.65+curl-8.2.1 Compiling curl v0.4.44 Compiling git2 v0.17.2 ``` Sample rendered HTML output: ![image](https://github.com/rust-lang/cargo/assets/17818024/23aae84e-5107-4352-8d0f-ecdfcac59187) ### Possible issues and future work A possible issue in this solution is that the output becomes too noisy. Other possible solutions: - Only display the version if there are two "units" with the same name. One possible implementation is to count the names, aggregate them in a simple map and look it up during rendering. - Create a small selection to select the disambiguate method between "Never", "Always" and "Only duplicates". This may be overkill.
Thought you've changed the format but apparently not. Will wait for you replying back :) @bors r- |
☀️ Try build successful - checks-actions |
@weihanglo I've adjusted the format to number 2, only showing the version when there are duplicate crates and taking epage's suggestion to add a cargo-timing-20230801T120113Z.tar.gz
I'm sorry, I don't know which screenshots you mean, but I'm happy to help if you point me in the correct direction. |
Was talking about https://doc.rust-lang.org/nightly/cargo/reference/timings.html, though it is not necessary for this pull request. Anyway, thanks for the contribution! @bors r+ |
Anything different in the cargo/src/cargo/core/compiler/unit.rs Lines 37 to 85 in c91a693
|
Thanks for working with us on this! |
☀️ Test successful - checks-actions |
No problem! This was quite an easy process. Thanks for the reviews and iteration on the PR! I'll contribute again when I can. |
Update cargo 8 commits in c91a693e7977e33a1064b63a5daf5fb689f01651..6dc1deaddf62c7748c9097c7ea88e9ec77ff1a1a 2023-07-31 00:26:46 +0000 to 2023-08-02 00:23:54 +0000 - `#[allow(internal_features)]` in RUSTC_BOOTSTRAP test (rust-lang/cargo#12429) - ci: rewrite bump check and respect semver (rust-lang/cargo#12395) - fix(update): Tweak CLI behavior (rust-lang/cargo#12428) - chore(deps): update compatible (rust-lang/cargo#12426) - Display crate version on timings graph (rust-lang/cargo#12420) - chore(deps): update alpine docker tag to v3.18 (rust-lang/cargo#12427) - Use thiserror for credential provider errors (rust-lang/cargo#12424) - Clarify in `--help` that `cargo test --all-targets` excludes doctests (rust-lang/cargo#12422) r? `@ghost`
Update cargo 8 commits in c91a693e7977e33a1064b63a5daf5fb689f01651..6dc1deaddf62c7748c9097c7ea88e9ec77ff1a1a 2023-07-31 00:26:46 +0000 to 2023-08-02 00:23:54 +0000 - `#[allow(internal_features)]` in RUSTC_BOOTSTRAP test (rust-lang/cargo#12429) - ci: rewrite bump check and respect semver (rust-lang/cargo#12395) - fix(update): Tweak CLI behavior (rust-lang/cargo#12428) - chore(deps): update compatible (rust-lang/cargo#12426) - Display crate version on timings graph (rust-lang/cargo#12420) - chore(deps): update alpine docker tag to v3.18 (rust-lang/cargo#12427) - Use thiserror for credential provider errors (rust-lang/cargo#12424) - Clarify in `--help` that `cargo test --all-targets` excludes doctests (rust-lang/cargo#12422) r? ``@ghost``
Update cargo 10 commits in c91a693e7977e33a1064b63a5daf5fb689f01651..020651c52257052d28f6fd83fbecf5cfa1ed516c 2023-07-31 00:26:46 +0000 to 2023-08-02 16:00:37 +0000 - Update rustix to 0.38.6 (rust-lang/cargo#12436) - replace `master` branch by default branch in documentation (rust-lang/cargo#12435) - `#[allow(internal_features)]` in RUSTC_BOOTSTRAP test (rust-lang/cargo#12429) - ci: rewrite bump check and respect semver (rust-lang/cargo#12395) - fix(update): Tweak CLI behavior (rust-lang/cargo#12428) - chore(deps): update compatible (rust-lang/cargo#12426) - Display crate version on timings graph (rust-lang/cargo#12420) - chore(deps): update alpine docker tag to v3.18 (rust-lang/cargo#12427) - Use thiserror for credential provider errors (rust-lang/cargo#12424) - Clarify in `--help` that `cargo test --all-targets` excludes doctests (rust-lang/cargo#12422) r? `@ghost`
Update cargo 10 commits in c91a693e7977e33a1064b63a5daf5fb689f01651..020651c52257052d28f6fd83fbecf5cfa1ed516c 2023-07-31 00:26:46 +0000 to 2023-08-02 16:00:37 +0000 - Update rustix to 0.38.6 (rust-lang/cargo#12436) - replace `master` branch by default branch in documentation (rust-lang/cargo#12435) - `#[allow(internal_features)]` in RUSTC_BOOTSTRAP test (rust-lang/cargo#12429) - ci: rewrite bump check and respect semver (rust-lang/cargo#12395) - fix(update): Tweak CLI behavior (rust-lang/cargo#12428) - chore(deps): update compatible (rust-lang/cargo#12426) - Display crate version on timings graph (rust-lang/cargo#12420) - chore(deps): update alpine docker tag to v3.18 (rust-lang/cargo#12427) - Use thiserror for credential provider errors (rust-lang/cargo#12424) - Clarify in `--help` that `cargo test --all-targets` excludes doctests (rust-lang/cargo#12422) r? `@ghost`
What does this PR try to resolve?
Fixes #7384
The solution here is the simplest one: since duplicate crates with different versions can cause confusion, we always output the version.
How should we test and review this PR?
Build any create using the
--timings
option:and verify the resulting HTML file.
Additional information
The formatting is consistent with how the crates are displayed in the terminal output for Cargo and also on the table below the graph. Initially, this comment suggested said formatting for ease of searching, but I do believe the browser can't search in the graph itself.
Sample console output:
Sample rendered HTML output:
Possible issues and future work
A possible issue in this solution is that the output becomes too noisy. Other possible solutions: