-
Notifications
You must be signed in to change notification settings - Fork 8
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
Interpreting TAP streams lacking version numbers #41
Comments
This is an interesting question. I wonder what the behaviors are in practice across implementations? That should be our guide, in my opinion. For node-tap, the version line is completely optional, and the parser will faithfully emit a But, all streams are interpreted as TAP 14, regardless of reported version. So you can have child tests, pragmas, etc., regardless of the reported version. I'd say, if other implementations are the same, then that's a bug in the spec, which we should fix. If other implementations are different, then that's a bug in node-tap, which I should fix. (Or at least, a deviation from the spec that should be called out, made opt-in, etc.) Personally, I prefer node-tap's behavior here. Maybe we could thread the needle somehow by saying that a version greater than a harness's supported version may be an error or warning (though maybe also state that the harness should do its best with it, since TAP is likely to continue to shoot for backwards-compatibility), and that a missing version should be interpreted as TAP 14 (since TAP 14 is backwards compatible to TAP 12 anyway). What do you all think? |
I'd be okay with defining it as "missing version means 12, and TAP harnesses cannot treat that as an error unless they treat version 12 as an error due to not implementing 12". Which seems unlikely that someone wouldn't implement version 12. 😆 It seems to me that that was what TAP13 specified. |
FWIW meson currently just swallows it (we only handle version 12/ 13) but the version field is used in accordance with:
to select whether the "report them in some other fashion" tells the user to report it as a feature request to implement (because we don't implement TAP 14 functionality yet), or "probably a bug in the test". In either case, the test passes, it's just noisy.
So I think you're suggesting e.g. to change:
to
And change:
to:
|
Yes, I think that would bring node-tap into compliance, and seems sensible to me. Just need two other implementations to agree, assuming we're still following the rule of 3. That brings up another question: what's the path to make further edits and refinements to the spec, if they introduce some functional change like this? Even if it's to fix a spec bug, do we call that "tap 15"? That seems heavy handed. "14.0.1"? |
Yes, this sounds sensible to me too |
I would say that it technically means the same thing depending on the exact wording, so give it a bugfix release number. I'll further consider the wording over the weekend and submit a change, I guess. 😄 |
My proposed wording:
|
A TAP14 stream *must* have a version line saying "TAP version 14" in order to be TAP14. It's confusing to say that a TAP stream *must* have that line when describing the syntax, though. Reword this to make it clear that a version line must be that line, and the semantics of *missing* that line is that this is not a TAP14 stream -- not that it's a TAP14 stream with an error in it. Of course, a harness that interprets TAP14, when given not-TAP14, can reasonably decide to report an error. Add the note about TAP13 compatibility into a new section on backwards compatibility, making it clear that both the "may" handle TAP13 and the "may" report an error for missing version, are... all about handling backwards compatibility with That Which Is Not TAP14. Ref. TestAnything#41
Submitted an attempted rewording. Treating a missing version number as implicitly version 12, and then silently handling that as a valid/supported TAP stream, is what Meson used to do before the TAP14 wording, and I am more than happy to revert to that state of affairs ;) so,
I guess Meson counts as the second? |
Sounds good to me too. |
Having slept on this, the only concern I'd have is that it seems like if you have a stream like this:
I want to interpret that as TAP14 (ie, handle the child test as a child test, not as non-TAP lines). But, if the rule is What about something like this:
|
Tbh, I think the "TAP version" line is kind of a regrettable wart. I always forget to write it when I'm manually outputting test results, and it seems like its only purpose is to enable adding non-backwards-compatible features to the spec, which we all agreed is kind of a bad idea anyway. 🤷 I'd be fine with removing it entirely in a future TAP version, though I realize I'm probably in the minority on that. |
Yes, I agree that the extra paragraph makes things clearer. |
That paragraph contradicts the TAP Philosophy:
Do you want a consumer to rigorously adhere to the TAP spec, or do you want them to follow that directive and ignore any lines that are unparsable? |
#25 (comment)
Let's pull this into a new issue here :)
eli-schwartz 1 hour ago
I implemented this in Meson as a passing test which verbosely warns you not to do this. I got a response:
mesonbuild/meson#11186 (comment)
Meson is able to parse TAP12 and TAP13, therefore it does not have to warn if the version line is missing.
IMO the "Harnesses may treat any TAP stream lacking a version as a failed test" is just silly. The point of TAP is exactly that it is easy to produce without relying on a library that handles the versioning and formatting for you, so good luck enforcing that with dozens of TAP producers.
Thoughts?
@eli-schwartz eli-schwartz 1 hour ago
More importantly:
In fact the test-anything.org page says:
Here’s what a TAP test stream looks like:
1..4
ok 1 - Input file opened
not ok 2 - First line of the input valid
ok 3 - Read the rest of the file
not ok 4 - Summarized correctly # TODO Not written yet
Which regardless of anything else seems to be a problem -- the homepage of https://testanything.org/ describes a TAP stream without the soft-mandatory version, so it is valid TAP 12 but a TAP 14 harness can report it as a test failure. Maybe this should include a version...
@bonzini bonzini 1 hour ago
Thanks for bringing it up here @eli-schwartz. In my opinion the correct reading of the spec is:
a TAP harness MUST treat a missing version line as version 12
a TAP harness MAY reject versions below any limit they would like to apply (even though it's not a good idea :))
The latter does imply rejecting input without a version line (which puts the limit at version 13), but does not mean that harnesses should warn if the version line is absent.
The text was updated successfully, but these errors were encountered: