-
Notifications
You must be signed in to change notification settings - Fork 13.4k
Actually add rustc-guide to toolstate, don't fail builds for the guide #62759
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
Changes from 3 commits
0fdf24b
97b4156
8070bb8
b2d05db
8b87162
17c4084
8940a27
1aa1079
9c48ed4
92d432a
82d1841
11a3b74
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -25,6 +25,7 @@ python2.7 "$X_PY" test --no-fail-fast \ | |
src/doc/rust-by-example \ | ||
src/doc/embedded-book \ | ||
src/doc/edition-guide \ | ||
src/doc/rustc-guide \ | ||
src/tools/clippy \ | ||
src/tools/rls \ | ||
src/tools/rustfmt \ | ||
|
@@ -88,7 +89,6 @@ status_check() { | |
# these tools are not required for beta to successfully branch | ||
check_dispatch $1 nightly miri src/tools/miri | ||
check_dispatch $1 nightly embedded-book src/doc/embedded-book | ||
check_dispatch $1 nightly rustc-guide src/doc/rustc-guide | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Put this back. This line only verifies that if you have updated There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I feel it would be beneficial to remove it. If I include There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Disagreed. If it is really a transient failure you could just If the link is an actual bad link it could simply be updated or removed. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It takes time to investigate why something failed. It involves loading log files. It involves investigating if it is transient or legitimate. It requires time to remove from a PR, and reporting issues. These are all things I do not want to do. Particularly for rustc-guide, which is not really published from here (I love rustc-guide BTW, don't get me wrong). No other documentation checks external links, and I don't think it is a good idea to gate on it. If it is enforced, I probably won't include rustc-guide in book updates. Someone else can submit updates for it. I apologize for sounding curt, but I just don't want to spend my time on it. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. If we don't care about whether a link failed why do we add a linkchecker? Ignoring the alarm isn't good. Besides, not gating on it is even worse for debugging since the maintainer of rustc-guide would now need to dig the log archive to get the error message. While with gating at least the Rust-Log-Analyzer could help you extract the relevant logs. If you don't want to investigate you could just mention the rustc-guide maintainer. Since other books are already gated on doc-tests you do need to investigate the log to find out which book is broken anyway. Furthermore you seem to be exaggerating the probability of spurious external link failure. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
The status is saved in the local toolstate file by the call to There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. So @ehuss @mark-i-m how can we proceed here? Personally I agree with @kennytm and, as @mark-i-m said, "not gating update PRs on this might be less helpful because the status would just remain broken". If a PR updates this submodule and tests still don't pass, surely something is wrong with that PR? If you have spuriously failing tests, the precedent with RLS is to disable/ignore those tests on your side so that at least the other tests can still do their job. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. As I said, I'm fine adding it back and seeing how it goes. I just don't want to spend much time dealing with failures going forward. I personally don't think a failure indicates a problem with the PR. It just indicates the problem hasn't been fixed, yet. A PR that updates a broken rustc-guide when it remains broken doesn't make the problem worse, it's already broken. Making me take time to remove it from the PR doesn't magically make it fixed, it just takes my time, with no benefit for anyone. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. They way I see it, allowing tools/doctests to fail at all is a concession to the fact that synchronized updates are hard. But really a failing tool is not an acceptable state. If you are updating a tool and your tests are failing, that should be rejected just like when you are updating rustc and tests are failing. Making sure tests pass is not a waste of time, it is a basic part of software maintenance. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Thank you :) I will add it back. If it fails again, feel free to just drop rustc-guide and I can investigate.
Yes, this is the approach I have been taking with rust-lang/rustc-dev-guide#388. Also, Michael-F-Bryan re-wrote the linkchecker to take better advantage of caching, and maybe it will have more flexible handling of timeouts and server errors later too, so hopefully spurious failures will be less common in the future too. |
||
} | ||
|
||
# If this PR is intended to update one of these tools, do not let the build pass | ||
|
Uh oh!
There was an error while loading. Please reload this page.