Skip to content
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

define "independent" #167

Open
nigelmegitt opened this issue Feb 21, 2018 · 32 comments
Open

define "independent" #167

nigelmegitt opened this issue Feb 21, 2018 · 32 comments
Assignees
Milestone

Comments

@nigelmegitt
Copy link
Contributor

I've recently had cause to discuss what the Process's use of the term "independent" means, as applying to implementation experience.

The term is not defined in the Process, and some folk might want to bend what I consider to be a common sense interpretation to meet their own objectives. (Or maybe they have the common sense and I'm the one bending the interpretation!) There's room for clarification in relation to the following aspects:

I'm sure that the Director has some meaning of "independent" in mind; it would be helpful at least to set out some guidance, even if not to lock it down to a tight definition.

@dwsinger
Copy link
Contributor

Indeed, are two implementations that don't share code, were written by different engineers, but are from the same company, 'independent'? (We have this case in WebVTT). If the same consultant wrote different implementations for two different companies, are they 'independent'? And so on. Saying a little what the goal of 'independence' is would be good (presumably, that the spec. is clear enough that implementations by people who merely read the spec. and didn't talk much to each other nonetheless interoperate).

@dwsinger dwsinger added the Needs AB Feedback Advisory Board Input needed label Mar 9, 2018
@jeffjaffe
Copy link

A feature of the process is to allow the Director to apply judgment rather than rigorously defining every term. The problem with the latter is that it sometimes locks you in to a definition - and then a new case arrives which "should" be viewed as independent, but is somewhat different in its details. Before we change this it would be useful to have some use cases where this has been a problem in the past.

@vfournier17
Copy link

@jeffjaffe This should be an objective determination, rather than being one person's subjective decision. Members may not be comfortable with the Director (or any other person) making an individual determination regarding IP rights that will affect all members. I agree that it would help to look at use cases to help define the parameters of an independent implementation.

@wseltzer
Copy link
Member

The term is used in a series of non-exhaustive examples and as a description of the goal, to show that a specification is sufficiently clear, complete, and relevant to market needs, to ensure that independent interoperable implementations of each feature of the specification will be realized."

On which of those do you want more clarity?

@nigelmegitt
Copy link
Contributor Author

Hi @wseltzer I was thinking about the independence of implementations mainly. If the definition for that differs from the definition of other usages of the term, then that's another good reason for adding further clarification.

@wseltzer
Copy link
Member

Has this been a problem in practice? if you can share a pointer to that discussion, it might help to indicate what clarity would help in the future.

@nigelmegitt
Copy link
Contributor Author

@wseltzer Yes, it has. It was recently discussed in the TTWG and has previously been discussed there (private discussion, no link) in the context of CR exit criteria and implementation reports.

@wseltzer
Copy link
Member

@plehegar or @swickr any input here?

@chaals
Copy link
Contributor

chaals commented Apr 11, 2018

@dwsinger wrote:

Saying a little what the goal of 'independence' is would be good (presumably, that the spec. is clear enough that implementations by people who merely read the spec. and didn't talk much to each other nonetheless interoperate)

That is exactly the goal, and why "independent" is hard to define here. It is probably not even a useful term, but it came with the old language that was even less about relevance to reality and more about being able to check some boxes and say "we met the criteria".

@michaelchampion
Copy link

I think I've made this point before, maybe in another thread. This language is a legacy of the "waterfall" era when the accepted work mode was to collaborate on an authoritative spec, then independently develop proprietary implementations. If the spec wasn't clear enough for at least 2 independent implementations of a feature to interoperate, that is evidence that the spec is not good enough.

That's still a useful criterion in situations where there are independent implementations, but we can't let it get in the way of the more common collaboration mode these days to collaborate on code and then document and standardize the "interoperability surface" APIs/protocols/formats. Even when there are multiple open source implementations such as the browser engines, they tend to look at each others code so demanding "independent" implementation experience would inhibit standardization.

So I agree with Chaals; it's probably not a useful term in the process document anymore. Or it is a useful abstract goal, but it's not a useful constraint on proving standards readiness. We've moved from a philosophy of "tests prove whether the spec is clear enough to implement" to "tests prove whether the spec is a good description of what interoperates across implementations".

@wseltzer
Copy link
Member

This is a case-by-case determination for the Director, who is willing to discuss it with WG participants as needed, but we don't think adding more to the Process will be helpful.

@frivoal frivoal added Closed: Rejected DoC This has been referenced from a Disposition of Comments (or predates the use of DoCs) and removed Needs AB Feedback Advisory Board Input needed labels Dec 8, 2018
@frivoal
Copy link
Collaborator

frivoal commented Dec 8, 2018

@nigelmegitt I am preparing a Disposition of Comments for this year's iteration on the Process. It was decided not to address this in Process 2019. Since you raised the initial issue, I would appreciate if you can let us know if this is something you can live with, or if you wish to object to.

@nigelmegitt
Copy link
Contributor Author

nigelmegitt commented Dec 10, 2018

Hi @frivoal clearly it is possible to live with this, since W3C has been doing so for some time. So an objection seems too strong and I won't object. I would like to register that the issue has not been resolved however.

Indeed, given the recent announcement by Microsoft about Edge, the question of independence of implementation seems more relevant than ever. Perhaps this is a wider topic that should be raised with the AC or the AB: what is important to W3C here?

@frivoal
Copy link
Collaborator

frivoal commented Dec 10, 2018

Thanks for the clarification. You make a good point, and I have raised an issue in the private AB tracker to think through what the decreasing diversity in browser engines meant for us.

@frivoal frivoal added Commenter satisfied/accepting conclusion confirmed as accepted by the commenter, even if not preferred choice and removed Commenter Response Pending labels Dec 10, 2018
@nigelmegitt
Copy link
Contributor Author

For the record, the labels "Closed: rejected" and "Commenter satisfied" do a very bad job at reflecting the status of this issue and of my response. I am not satisfied, I just don't want to object to Process 2019 on that basis.

I would prefer that we consider it to be deferred pending further discussion, i.e. moved away from Process 2019, to reflect the purpose noted in #167 (comment).

@frivoal
Copy link
Collaborator

frivoal commented Dec 12, 2018

"Commenter satisfied" do a very bad job at reflecting the status of this issue and of my response

Point taken.

Separately from whether this should be deferred rather than rejected, commenter satisfied is meant to cover "proposal rejected, commenter confirms no objection". Do you have a suggestion of a better wording for the label itself?


I would prefer that we consider it to be deferred pending further discussion

I was just labeling issues after the fact, and this was just closed. I wasn't following this when the decision to close was taken (and I am not chair). @dwsinger with your chair hat on, is this deferred or rejected?

@dwsinger
Copy link
Contributor

I believe that Wendy maintained, and the process CG agreed, that defining 'independent' clearly in the process would be hard, and take too much text. But indeed somewhere we need explanation or guidance.

@nigelmegitt
Copy link
Contributor Author

Separately from whether this should be deferred rather than rejected, commenter satisfied is meant to cover "proposal rejected, commenter confirms no objection". Do you have a suggestion of a better wording for the label itself?

I think the problem is with the Closed: rejected label, when the response I gave was specifically in relation to the text "decided not to address this in Process 2019". I took that to mean a deferral rather than an outright rejection. In that scenario an approach I've seen before is to assign issues to a milestone, e.g. Process 2019 or Process 2020 or Process future and filter the issues for reporting based on the milestone. Of course in this case the issue was raised against Process 2019 so it does make sense to include it in the dispositions. Maybe a Deferred label could be helpful here.

Or the issue could be closed with a reference to a new issue specifically opened against a future process milestone, in which case closing this issue would be acceptable because the problem itself is still being tracked and worked on. I don't really like tracing through histories that span issues though.

@dwsinger
Copy link
Contributor

I'm fine with leaving this open until such time as we understand how/where this is documented and defined. re-opening.

@wseltzer wseltzer removed their assignment Aug 15, 2019
@dwsinger dwsinger removed this from the Process 2020 milestone Aug 28, 2019
@frivoal frivoal removed the DoC This has been referenced from a Disposition of Comments (or predates the use of DoCs) label Mar 11, 2020
@frivoal frivoal added this to the Deferred milestone Mar 11, 2020
@nigelmegitt
Copy link
Contributor Author

New at this

@datbossg31030 Please could you elaborate a little more? I don't understand this comment as it is.

@dbaron
Copy link
Member

dbaron commented Apr 8, 2020

So there are a few characteristics of standards that I think are valuable that I think the independence of the implementations helps verify. But those different characteristics depend on different definitions:

  1. It's important to know that the specification (perhaps supplemented by the test suite) contains enough information to produce interoperable implementations without reverse-engineering an existing implementation. To verify this, it's important that the implementations be done by different people or by non-overlapping teams (since one person is likely to make the same assumptions across multiple implementations).

  2. For specifications that are specifying a feature that is to be added to existing pieces of software, it's important to ensure that the specification doesn't make assumptions that are specific to one of those pieces of software that would make it much harder to add to a different one. To verify this, it's important that the implementations are done in different pieces of existing software. (This actually also helps to verify the previous criterion, since assumptions are also built into existing pieces of software.)

  3. For some specifications, it's important to know that it has broad enough support within the industry that multiple companies are willing to invest in its success. One thing that can help verify this is if multiple companies are willing to invest in implementing it.

  4. For some specifications, the existence of multiple implementations of a specification gives the users of that specification more confidence that they would be able to switch to a different implementation if they needed to (for example, to avoid a security vulnerability in one implementation). To verify this, it may be important not only that the implementations be in different pieces of software but also that they lack common dependencies.

I'm sure there are also more that I haven't listed here.

We seem to have settled on two independent implementations as the threshold for advancement to Proposed Recommendation. It's a clear threshold, but at the same time, for many of these things, three is better than two, etc. But if needed, more can also come after a specification advances to Proposed Recommendation.

@frivoal
Copy link
Collaborator

frivoal commented May 18, 2020

@dbaron I agree with your list, and that for many of these criteria, 3 or more is better than two.

The harder (to me) question is what to do when something has many deployments and broad adoption but only one implementation, such as the case where a single open source library is used by everybody to implement a particular feature.

This gives evidence to your point 3: even if they didn't implement it independently, multiple organizations found it worth shipping, and multiple organizations may have been willing to spend resources on developing / bugfixing the shared implementation.

The fact that it is adopted in multiple products also gives some evidence for point 2: if the spec and library could be used in multiple products, then that gives some assurance about too strong assumptions about a particular product architecture.

For point 1, it's fuzzy: while it's a single open source library, its various contributors, who may not be strongly coordinated, have settled on one interpretation of the spec. It may be by accident, the spec may still be ambiguous, etc, but it's better than nothing. In particular, if there are tests and the test have either been authored or reviewed by someone other than the implementer, this could have given the chance to notice any discrepancy between the spec and the implementation. It's not as strong as multiple implementations, but it's better than what a single closed-source implementation without a shared test suite would be.

For point 4, it's pretty bad: if that particular implementation turns out to have some bad security flaw, there's nothing you can switch to, without starting a new implementation at that point. That ought to be doable thanks to point 1 through 3, but it's not as good as knowing something already is available and could be adopted.

To, what this means is that for a standalone product implementing on its own a spec, we absolutely need more than one implementation to be able to graduate to PR and beyond.

But for when a spec corresponds to a feature inside a product rather than to the entirety of the product, multiple independent implementations are still desirable, but multiple integrations of a single implementation (or of several implementations which aren't fully independent) may be tolerable, even if it is not as good.

@plehegar
Copy link
Member

plehegar commented Oct 7, 2020

will work on a guidlines document as an intermediate document

@hober
Copy link
Member

hober commented May 6, 2021

@frivoal frivoal modified the milestones: Process 2021, Deferred Jul 14, 2021
@hober
Copy link
Member

hober commented Feb 23, 2022

See also #522

@nigelmegitt
Copy link
Contributor Author

In particular: #522 (comment)

@nigelmegitt
Copy link
Contributor Author

Breakout session at TPAC 2022: https://www.w3.org/2022/09/14-iii-minutes.html

@michaelchampion
Copy link

michaelchampion commented Oct 10, 2022

Thanks for the link to the breakout session. There seems to have been at least 3 different views expressed about what it should take to get to Recommendation:

  1. The spec document itself is high quality, and COULD be interoperably implemented
  2. The spec documents a technology or set of practices that SHOULD be implemented and deployed
  3. The spec documents a technology that REALLY IS interoperably implemented and deployed in the real world

Is that a reasonable summary?
IMHO the answer should be "all 3". I'd eventually like to see success criteria at least as strong as CSS's https://www.w3.org/2020/12/css-wg-charter.html#success-criteria baked into the Process. I assume there is not broad consensus in the CG to put that in the Process yet 😢 . It will take some effort by the AB and TAG to make authoritative statements on the values a Recommendation SHOULD promote, and it will take some effort to define what "implemented and deployed in the real world" means, especially for guidelines documents that are normative rather than empirical.

@plehegar plehegar removed this from the Deferred milestone Jan 11, 2023
@plehegar plehegar removed the P2023 label Jan 17, 2023
@plehegar plehegar added this to the Deferred milestone Jan 17, 2023
@plehegar
Copy link
Member

@nigelmegitt
Copy link
Contributor Author

Is that a reasonable summary?

I don't think so, no, specifically because of the conjunction of "implemented" and "deployed in the real world" at step 3. Deployment should be broken out into a separate bullet, since it is independent from "implementation". There are many examples where standards work precedes deployment, and this is the reality of the commercial world: folk don't want to commit to something that it not yet standardised (whatever that means to them), even if they would support that standardisation activity and agree that the result would be beneficial.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

12 participants