-
Notifications
You must be signed in to change notification settings - Fork 13k
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
test suite: ERROR and WARN annotations are not mandatory in UI tests #55596
Comments
I had thought this was deliberate, in the sense that if you didn’t have any such annotation, then the output wasn’t checked? |
From what I've seen no annotations usually mean forgotten annotations. Annotations also make compile-fail tests readable - you can see what the test is testing, what lines have issues. Otherwise you have to compare the source and the output side-by-side and that's hard and unreliable, especially given that line numbers in I'd prefer to keep this minor annotation burden to avoid tests that are accidentally wrong or unreadable. |
I personally agree that no annotations usually mean forgotten (or at least unanticipated) annotations. And I'm certainly a strong proponent of using annotations when one really wants to ensure that daagnostics are actually associated with particular points in the code. Personally I think we should require them for ERROR (*) But I don't want to require them in all cases for NOTE or HELP; that would make the annotation burden for test writers too extreme. And I don't know what to think about whether to require it for WARN or not. That dilemma is what I think got us to where we are today, where (in principle), if you write a single annotation of a certain kind, then you get checking for all annotations and diagnostics of that kind for the given test. (*): The fact that currently we don't is probably a holdover from the categorization of the tests into ui/compile-fail/run-pass directories. (In hindsight, maybe everything would have been better doing the same thing to |
Lets discuss this at the compiler meeting. |
Discussed at T-compiler meeting. The general consensus was that we should do what @petrochenkov suggests (in that we should require tests in the My main hesitation about this was about the barrier this would introduce for test authors. But then I was reminded that if a test wants to opt out, it can just add |
Beside that, UI tests |
This will also remove warnings from the |
With We should actually make a pass through tests and remove |
A somewhat opposite issue - #56277. |
@petrochenkov I would like to help with this. I am a newbie to rust. |
#65759 (comment) tells how to resolve this issue. |
@saleemjaffer |
Example:
ui/parser/if-in-in.rs
.The test has errors and has corresponding
.stderr
file, but has no//~ ERROR
annotations and it still passes.This should not happen,
//~ ERROR
and//~ WARN
annotations must be mandatory even if none of them are written in the test yet.The text was updated successfully, but these errors were encountered: