[As a contributor]

Hi Kent,

Please see [RW] inline

From: Kent Watsen <[email protected]>
Sent: 31 March 2020 16:37
To: Rob Wilton (rwilton) <[email protected]>
Cc: Andy Bierman <[email protected]>; Martin Björklund <[email protected]>; 
[email protected]
Subject: Re: [netmod] All IETF YANG modules MUST include revision-label 
statements

[replying to Reshad as well]

Hi Rob,


My impression is that Semver 2.0.0 works fine if you can always force clients 
to move to the latest version of the API whenever any bugfixes are made to the 
API (whether they are BC or NBC).  This is a natural fit for open source 
projects, but not so great for long life paid support contracts.

Agreed.



The goal of YANG semver is not to facilitate release branching.  It is to allow 
vendors to fix YANG modules without forcing clients to update to the latest 
version of that YANG module (which may contain other unrelated NBC changes and 
have lots of dependencies on other modules).

This is what Reshad was pointing to as well.  I’m very familiar with the issue, 
from my Juniper days, where there were all sorts of patch and (gasp) customer 
special releases, either of which could introduce any number of NBCs.

The background, of course, is that [very important] customers have 
working/validated infrastructure running a specific release and simply cannot 
tolerate any change beyond the very specific one they need *NOW*

I get it, truly,  but I feel that the ‘m’ / ‘M’ suffixes are both inconsistent 
with general understanding and insufficiently to express what is needed.
[RW]
The aim is for the ‘m’/’M’ suffix to provide a mechanism to describe where the 
module has deviated from the rules in a limited way.

The hope/intention is that these should be avoided whenever possible, i.e. they 
are designed to be limited in what they can express to encourage regular semver 
and a non-branched revision history.

As YANG APIs become more mature, and as automation becomes more important, then 
I would expect that these APIs become more hardened, and there should be less 
usage of the suffix.



A possible fix might be to allow for <major>.<minor>.<patch>[-<anystring>], 
thereby enabling vendors to encode any format off a base release…and rely on 
inspection of the “revision” history indicate if/when NBC changes occurred.
[RW]
But this would look like a valid semver 2.0.0 (rule 10), but presumably one 
that is not following the semver 2.0.0 rules.  I also don’t see how having each 
vendor design their own scheme really helps interop.

I agree that one option is to tell everyone to look at the revision dates and 
revision history.  But I think for most people a semantic version number is 
much easier to mentally process than a date.


But then I question (again) the need for the simplified format at all, as 
opposed to just using revision dates.  For instance, if <anysting> represents a 
long history of NBCs, that they were based on some source M.m.p starts to lose 
relevance.

Is the expectation that the vendor's module versions will use 
<major>.<minor>.<patch> values mimicking their release numbers?  For instance, 
would FooBar OS version 20.1.2 implement YANG module 
"[email protected]<mailto:[email protected]>”?
[RW]
No, the plan would be to given the modules semantic version numbers that are 
not tied to release, i.e. the API is versioned independently.


   I can see product mangers pushing for this, but then are companies (like 
Juniper) that use alternate release name-formatting strategies disadvantaged?  
How is that fair?   To thwart this, would the WG be willing to assert that the 
history MUST start at 0.0.0 and MUST only monotonically increment values?
[RW]
The solution allows allows any revision label to be used.  E.g. if you wanted 
to label it after release then you could call it “r20.1.2”, the ‘r’ prefix 
stops it being parsed as semantic version number.

So the choices that the drafts currently present are:

1)      Modules can just use revision dates if they wish.

2)      Modules can use YANG Semver, noting that all Semver 2.0.0 versions are 
valid YANG Semver versions with the same semantic meaning.

3)      Modules can use whatever revision label/scheme that they like, as long 
as it doesn’t conform to the regex for a YANG semantic version number.  This 
rule is only currently there to avoid requiring a separate statement to define 
the versioning scheme.  The YANG Semver draft could also define a statement to 
indicate that the YANG Semver scheme is being used, and then that restriction 
would go away.



Note that OpenConfig also hit this problem, but they proposed a different 
solution.  I.e. ship the base module with another module that contains 
deviations to fix any bugs in the base module.  Alas this completely decouples 
the real module history from any revision-date/version number contained in the 
module, since to really understand the version of the module you also need to 
know the set of associated patch modules containing any deviations to the base 
module.

I’d need to see an illustration of this to be sure I understand, but my first 
impression is that it is yet another attempt to fit a square into a circle.
[RW]
Yes, it is an attempt to pretend that Semver 2.0.0 is sufficient except when it 
isn’t.

At the end of day, we could just standardize using regular Semver 2.0.0.  But 
when push comes to shove, and that customer is demanding a fix, I doubt many 
vendors will say “no, I’m sorry, but our versioning scheme prevents us from 
providing you a fix”, instead my supposition is that most vendors will provide 
the fix, and just break the rules, probably labelling it a patch release (e.g. 
going from 1.0.0 to 1.0.1 if 1.1.0 had already been used).  In this scenario it 
is better to have a scheme that vendors don’t actually follow, or is it better 
to have a slightly ugly scheme that does at least truly express that a non 
patch change has occurred (i.e. going 1.0.1m)?

In the end, I see no substitute to relying on “revision” history which 1) 
perfectly tracks branching history and can flag if/when NBC changes occurred.

[RW]
I think that both are useful/required.

If the client is doing a large upgrade between releases then I think that you 
need to rely on tooling that compares and reports the exact differences between 
the schema.

But I still think that semantic version numbers give helpful easier to 
understand information for humans.  E.g. I personally find it easier to 
remember that the first version of ietf-types.yang is 1.0.0 (RFC 6021), the 
second version (RFC 6991) is 1.1.0, the third version will be 1.2.0 
(rfc6991bis), rather than trying to remember the revision dates AND knowing 
whether or not any NBC changes have been made between the definitions.  I don’t 
argue that YANG semver is perfect, but I do still believe that it is better 
than all of the alternatives.

As a corollary to this point, I note that a lot more software artifacts tend to 
use explicit version labels rather than revision dates.  I presume that this is 
the case because most people find them easier to deal with.

Regards,
Rob


Kent // contributor



_______________________________________________
netmod mailing list
[email protected]
https://www.ietf.org/mailman/listinfo/netmod

Reply via email to