-
-
Notifications
You must be signed in to change notification settings - Fork 209
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
some tests for keywords added in later drafts #376
some tests for keywords added in later drafts #376
Conversation
03b19d6
to
64946a2
Compare
rebased. |
64946a2
to
aaf16b5
Compare
d016cfe
to
81e0551
Compare
these are mostly the same as tests from draft2019-09, with the results adjusted to accomodate for the keywords not being recognized. In most cases this results in validation always being true, but in some cases (such as contains + minContains) the results from existing keywords change their outcomes as well.
81e0551
to
45bda8b
Compare
To bikeshed the name (sorry), maybe "future-keywords" is a bit more correct than "unknown-keywords"? Presumably we should have some for a random nonexistent keyword (that all instances are valid), but I suspect that exists already in the suite somewhere. |
sure. Unknown is in the context of the current draft - "unknown to us", not "unknown to other drafts", but I have no strong feelings either way. |
I renamed the files from unknown-keywords.json to future-keywords.json. I also added a file for 2019-09 containing a very very basic test of $dynamicRef (copied from ref.json). If/when we ever have some $recursiveRef tests in 2019-09 we can copy them into there with |
Not sure I follow the 2019-09 piece -- (apologies, probably I don't know what dynamicRef is, so if I should just look somewhere let me know? Is this a keyword that's going to be in the 2020 draft?) |
$dynamicRef is being defined in json-schema-org/json-schema-spec#930. actually I should add prefixItems too. |
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.
Shouldn’t these tests be in a different draft directory? Eg. draft2020-xx or something.
No, tthey are in the right place. They are checking that these keywords are not recognized in draft2019-09, and the results will be different than this for draft2020-0X. |
I’m not sure I see the purpose in adding new keywords to tests for all older drafts every time there’s a new draft. That, to me, is like requiring testing for all possible keywords that don’t exist in a draft. 🤷♂️ |
Just to flesh this out a little bit more, I’ll just brain dump and think “aloud”: doesn’t this mandate testing for unmandated behaviour? For example, if a draft doesn’t say that the existence of an unknown keyword shouldn’t do something, doesn’t the existence of a test for that mandate something that’s unmandated? Does that make sense? Bottom line is: maybe there’s a way to test unmandated keywords for each spec in a different and less tedious way. Just mulling here... I’m not specifically against testing things that don’t belong in a spec, it’s just a lot to keep track of and it feels like it should be easier. That would be nice. :) |
tests/draft4/future-keywords.json
Outdated
{ | ||
"data": 1, | ||
"description": "cannot match: $ref is not found", | ||
"valid": false |
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.
If an implementation doesn't know what $anchor
is, then this isn't going to be false
, it's going to emit an undefined reference error when it encounters {$ref: "#foo"}
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.
agreed, I'll take this out. I wrote this before the discussion on undefined-behaviour-not-being-the-same-as-invalid.
The drafts don't say keywords that are unknown should do nothing, they say they should be ignored -- and that implementations can add their own. So I think the point actually is good here -- I do see good reasons to add these for reasons you probably are saying (so that implementations can ensure they don't leak backwards functionality if they want that guarantee for themselves) But an implementation is free to make the reverse choice, and add additional keywords to older drafts, and it's still valid for that draft (e.g. someone can add Which essentially means these tests probably need to go in optional, since yeah, a valid implementation may still not pass them. Does that make sense? |
Ok, sure, but "do nothing" is the same as "ignored", isn't it? :)
Yes and no -- some draft revisions are not backportable to previous drafts without changing existing behaviour that would violate the spec -- for example, At least now (starting with draft2019-09), modifications to the core specification should be made more clear, by the presence of the $vocabulary keyword in a metaspec. So that means that a schema with |
Yes sorry, all I mean is "they don't say 'you must not implement additional behavior", they just say "don't blow up" essentially -- if that's clear we can use whichever terminology :D. (I don't know about the rest yet, I have to think a bit more carefully, probably about each example individually, as you say). |
An e.g. draft 7 validator is free to optionally add support for draft 2019-09 keywords, at least ones which do not modify the behavior of draft 7 keywords, so these are in fact optional to pass, albeit helpful to prevent leaking if one doesn't intend to add support for them. (See the discussion in #376 (comment)).
Merged (after rebasing and moving as per the above). Thanks! |
I'm sad that the "squash!" commits made it into the main branch without being squashed :/ I left them unsquashed in the PR to make it easier to review, and the intention was to clean up the branch prior to merging. |
The last commit added to this pull request made the tests incorrect. The tests were in the non-optional section before and all marked as |
See the discussion above (which you agreed with) -- that was where they belonged, as an implementation is indeed allowed to implement the keywords even on older drafts before they were part of the spec. |
Sorry, glancing at this again given I left it open on a tab, perhaps what you're referring to by "incorrect" is specifically draft2019-09, with what you'd said previously:
which it seems we indeed didn't hash out here, but which I still believe is correct as merged. The spec (in 2019-09 and newer) does not say an implementation may not add keywords itself. The vocabulary mechanism allows schema authors to tell the implementation they require support for some vocabulary, but does not prohibit the implementation from offering other additional supported keywords. If that's what you disagree with, can you point out where in the spec says that to you? I just double checked, and in support of the above, the spec says in §6.5:
i.e. a schema author cannot depend on it, but an implementation may offer it and enable it. And in §4.3.3:
Both of which to me confirm the above, but happy to be wrong if you see something else. |
Okay there's two things being conflated here, and I think you missed the second point:
It really should be required to run new tests against an implementation to confirm that the results are satisfactory before merging, otherwise it's way too easy for mistakes to be made and incorrect tests can get merged. |
I did not miss the second point. The tests are correct as is, and are meant to catch exactly the same scenario you originally sent them for -- any implementation which knows it does not implement future keywords will enable the optional tests and ensure the same thing you originally filed this for. Any implementation which does implement newer keywords will not enable the optional test file. It's true such an implementation would benefit from an exactly conflicting file with "true/false behaviored" results. Feel free to PR one, but I don't think any implementations really do such a thing, so it doesn't seem high priority to add. The point was simply an implementation is allowed to do so, so the tests cannot go in the required directory. |
No thank you. I would object to such a PR. I don't see the sense in a set of optional tests that all return true. The tests aren't really saying anything at all. "Do this. Maybe. Or not. Whatever. We don't care." What is the point? This isn't what I intended with this PR at all. But I submitted it over two years ago, so I'm not really sure now what I was thinking at the time. I would have appreciated a chance to revisit it before it was merged, let alone changed in a way that I didn't intend. |
The original intent of the PR was to give implementations a chance to prevent leakage. That intent is preserved, it simply is opt-in, in order to comply with the spec. I'm not sure what to say about revisiting -- please do take the time to revisit any of the PRs you have opened beside this one, I pinged you on a few to review. I'll be merging or closing them in the next few days so now's the time. There's no real reason to fret doing this before or after though -- if something is wrong, we can fix it going forward. In the case of this PR, everything's fine as far as I see, unless there's something in the spec saying it isn't. |
I haven't gotten any pings. As I subscribe to all these repositories, all emails for them go into one folder and an explicit ping is lost. If I appear unresponsive on something, feel free to poke me in slack. I've moved them all to draft until I have a chance to look at them again. |
#559 reverts this PR. |
I can't tell if you're not reading my comments. #559 is incorrect, as I explained above in my last comment, which you must have seen? Going to close it. Happy to explain further if it's unclear. |
I noticed the back and forth through the github slack channel and thought I'd take a look. @Julian I have to say it's not clear to me. For one thing, I can't figure out why this PR is in a closed state but apparently merged? And there was a move of something to somewhere? Is that move commit ea68a4f and was it done in a separate PR somewhere? Assuming that's correct, is the debate here about whether they make sense in "optional" vs somewhere else? To me these make more sense in a "future" directory as they're not really testing spec-mandated optional behavior, but perhaps I don't understand what "optional" is supposed to mean? |
I'm also confused about the process here. Did you request changes from @karenetheridge , @Julian ? This is why I was asking about the other commit being in a PR as I was trying to understand who reviewed that further change. |
GitHub is confused by the rebase yes.
Yes, essentially. Optional is conflated (which is a known issue that's intended to be fixed, see e.g. #361 or #345 or a few other issues. We need to fix it, but today optional essentially has any test that an implementation may or may not need to run depending either on its implementation language or choices.
Yes, awhile back, and then just made them myself to merge this. |
Oh. I see that "awhile back" was in 2020, and there doesn't appear to have been a check-in about it before merging. I have to say if someone had done that to one of my PRs on the spec repo I'd feel a bit miffed. I'm still trying to understand what's going on as I don't see where @karenetheridge agreed to the move, as there was only one comment between you proposing that move and you doing it. But I also can't quite figure out if she was outright disagreeing, or on what grounds, so maybe I'm just missing a lot here. I get the This all seems to be related to the ongoing murky conversations about cross-draft behavior. Perhaps it would be reasonable to back this out as proposed in #559 so we can get consensus? I suspect the JSON Schema world can wait another week for these cases. |
I took that comment as agreement, though indeed I'd completely forgotten we didn't address 2019-09 (though again I believe the newer specs to be no different). I'm happy to back this out while we discuss, @karenetheridge can you elaborate on whatever you feel needs changing? |
Let's discuss on #561 so we're not using a closed PR. |
I hadn't been to this ticket in two years. If I had been poked about it I would have been happy to revisit it, clean up the "squash!" commits that should have never been merged in this form, and run the tests against my implementation again to see if I still agreed with how they were written. I would have made some substantial changes here had I had a chance to review it. |
these are mostly the same as tests from draft2019-09, with the results
adjusted to accomodate for the keywords not being recognized. In most cases
this results in validation always being true, but in some cases (such as
contains + minContains) the results from existing keywords change their
outcomes as well.