Re: [i2rs] Benoit Claise's Discuss on draft-ietf-i2rs-yang-l3-topology-13: (with DISCUSS and COMMENT)

"Alexander Clemm" <ludwig@clemm.org> Thu, 14 December 2017 07:53 UTC

Return-Path: <ludwig@clemm.org>
X-Original-To: i2rs@ietfa.amsl.com
Delivered-To: i2rs@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 0FED6127011; Wed, 13 Dec 2017 23:53:52 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -1.919
X-Spam-Level:
X-Spam-Status: No, score=-1.919 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, RCVD_IN_DNSWL_NONE=-0.0001, RCVD_IN_MSPIKE_H3=-0.01, RCVD_IN_MSPIKE_WL=-0.01, URIBL_BLOCKED=0.001] autolearn=ham autolearn_force=no
Received: from mail.ietf.org ([4.31.198.44]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id KNwWoUmFhQSY; Wed, 13 Dec 2017 23:53:49 -0800 (PST)
Received: from mout.perfora.net (mout.perfora.net [74.208.4.194]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 1DF551200CF; Wed, 13 Dec 2017 23:53:49 -0800 (PST)
Received: from LAPTOPR7T053C2 ([73.71.191.170]) by mrelay.perfora.net (mreueus001 [74.208.5.2]) with ESMTPSA (Nemesis) id 0M88Ot-1fCHid2B73-00vhZe; Thu, 14 Dec 2017 08:53:22 +0100
From: Alexander Clemm <ludwig@clemm.org>
To: 'Benoit Claise' <bclaise@cisco.com>, 'The IESG' <iesg@ietf.org>
Cc: draft-ietf-i2rs-yang-l3-topology@ietf.org, shares@ndzh.com, i2rs-chairs@ietf.org, shares@ndzh.com, i2rs@ietf.org, mvasko@cesnet.cz, ladislav.lhotka@nic.cz
References: <151315550826.30150.3938652389982359856.idtracker@ietfa.amsl.com>
In-Reply-To: <151315550826.30150.3938652389982359856.idtracker@ietfa.amsl.com>
Date: Wed, 13 Dec 2017 23:53:19 -0800
Message-ID: <027c01d374b0$9d4c3640$d7e4a2c0$@clemm.org>
MIME-Version: 1.0
Content-Type: text/plain; charset="UTF-8"
Content-Transfer-Encoding: quoted-printable
X-Mailer: Microsoft Outlook 16.0
Thread-Index: AQLRFYWYFZeNhI0H/5BlwMHmqKor1aFHNeBQ
Content-Language: en-us
X-Provags-ID: V03:K0:Rmn0Bb98G0XaWj8ga0pO/BmV/fYQXeaYVPDxC6cMqaisLcwz4B5 HWYpxb9lI9Ux6hSDy3hybTYhpCOkt+FmVWIWEhNdw+HYaskeh2AWQNEhGYGYp5SKufMF7Gn HQA+e/g6/d48n87DARkf3278ajdlsAQFj9cteFv0RJ+WJM5IWQ8dT/PFdb7Gx8mlJs0zGlZ GPq48Rsehx+lB7Vu2uLCw==
X-UI-Out-Filterresults: notjunk:1;V01:K0:lH4H9JpAFGM=:evPZDT40+FaEdSpxLMoHoW GALzcvn/YFMkUQr2rj4PclWxyMIagMuNwel4kTFjW+KcOTgJ/bhQwzzSJgQaSIFPMAhNZbwyA zQn51Ll+WFY0+lxN12ovO5Cu4XCXNH485wYz1UxoJn++pnO/a+OgA+JMdFTmY1DAGDFyBCeFx JGek0HxtYmF6ycybvUS2AvBsFa9fRgmQ0gVpyJLYUUIlHKuE6epsOUR1Da+Hb/iUPvwyCwEuv B8IQti7lqCYnAZ7JY/dUJEAhXHim2HAr895lDcqGUGHmz/8KyUGD4W+QkRccD51uF/LWFS1+L A+AV5dKIvxU5lEOwDrd9y8i0FgTfObuPTFC/22SKeVEp86ZvEwBXiFVzjRLp8eZRZ17aZiLNW FC6QgsPyZ9fErwxAerixVBcvdPtF8XBZVFiKIO3EvryviVBgzNRMkMRdX+DfeEHo8f/2rO5sR UA0b5f/engc2b19IL8UJ9awthfeMG/n4MjIrDau7y9O015bAFHywwZtqThtpCJqqyuGoi/4ID mYKEabiEAC3h+kvejTdJewgWmanf4Sg/Osh8SmTSosIh8SOF5KwV0MFWWbBhmoiSpnK4Gijoe Wy91mxt1cIG37TnXjevMxxZ4gSsebu3s5yX4wH7ZWnam3Aig/TcMHemqyJ3+ftaTl1t4xuqju 48OyjXaiYQXWlwgphqKv1SeHsbtCC/jDerw7jKCtGh6Bsbaqeoa7IxijwBQJ8ZySu1Lnfb3l9 tifYTFyrnpnvmuss+nFZV8JhLm3C273MPKIpb6EjSkQjZU6Nz7R6O3JwyOk=
Archived-At: <https://mailarchive.ietf.org/arch/msg/i2rs/el5ei_jUQjAnOIHjPCbsVA4iSE8>
Subject: Re: [i2rs] Benoit Claise's Discuss on draft-ietf-i2rs-yang-l3-topology-13: (with DISCUSS and COMMENT)
X-BeenThere: i2rs@ietf.org
X-Mailman-Version: 2.1.22
Precedence: list
List-Id: "Interface to The Internet Routing System \(IRS\)" <i2rs.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/i2rs>, <mailto:i2rs-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/i2rs/>
List-Post: <mailto:i2rs@ietf.org>
List-Help: <mailto:i2rs-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/i2rs>, <mailto:i2rs-request@ietf.org?subject=subscribe>
X-List-Received-Date: Thu, 14 Dec 2017 07:53:52 -0000

Dear all,

I have fixed the validation issue (thank you, Michal!) and just posted a new revision -14 that has all the comments addressed.  

Thanks
--- Alex

-----Original Message-----
From: Benoit Claise [mailto:bclaise@cisco.com] 
Sent: Wednesday, December 13, 2017 12:58 AM
To: The IESG <iesg@ietf.org>
Cc: draft-ietf-i2rs-yang-l3-topology@ietf.org; shares@ndzh.com; i2rs-chairs@ietf.org; shares@ndzh.com; i2rs@ietf.org; mvasko@cesnet.cz; ladislav.lhotka@nic.cz
Subject: Benoit Claise's Discuss on draft-ietf-i2rs-yang-l3-topology-13: (with DISCUSS and COMMENT)

Benoit Claise has entered the following ballot position for
draft-ietf-i2rs-yang-l3-topology-13: Discuss

When responding, please keep the subject line intact and reply to all email addresses included in the To and CC lines. (Feel free to cut this introductory paragraph, however.)


Please refer to https://www.ietf.org/iesg/statement/discuss-criteria.html
for more information about IESG DISCUSS and COMMENT positions.


The document, along with other ballot positions, can be found here:
https://datatracker.ietf.org/doc/draft-ietf-i2rs-yang-l3-topology/



----------------------------------------------------------------------
DISCUSS:
----------------------------------------------------------------------

Here is another validation issue, on the latest v13, that must be corrected.
Actually multiple mistakes, all with the same root cause. Note that those warnings were reported in the datatracker:
   - Yang catalog entry for ietf-l3-unicast-topology-state@2017-11-15.yang
   - Yang catalog entry for ietf-l3-unicast-topology@2017-11-15.yang

Thanks to Michal, here is the detailed explanation.
Hi Benoit,
firstly, you see the output only with -V because it changes verbosity to 'warnings' instead of the default one 'errors'. So, the warnings are valid and the when conditions are wrong. In short, in these cases the local module is not ietf-l3-unicast-topology, but ietf-network (despite being defined in
ietf-l3-unicast-topology) - "ietf-network:network-types/l3-unicast-topology"
should be
"ietf-network:network-types/ietf-l3-unicast-topology:l3-unicast-topology" or even "network-types/ietf-l3-unicast-topology:l3-unicast-topology".

To explain, here is the (long) justification. I will use the first warning as an example, all the other warnings are caused by the same mistake. We are dealing with a when condition "nw:network-types/l3-unicast-topology" in an augment "/nw:networks/nw:network" in the module ietf-l3-unicast-topology. As per [1], the context node of the XPath expression (when condition) is the augment target node "/nw:networks/nw:network". If you notice, the warning warns about not finding the node "l3-unicast-topology", not "nw:network-types". So, what node is actually referenced by "l3-unicast-topology"? Looking at [2], second bullet point, the namespace (prefix) should that of the "current node".
Sadly, there is no (I have found none) formal definition of "current node" but I dared to assume it to be the node returned by the "current()" [3] function.
As was said at the beginning, the "initial context node" is "/nw:networks/nw:network". Finally, we can now decide that "l3-unicast-topology" actually takes the prefix of the module "ietf-network"
and there is no such node, this node is defined in the module "ietf-l3-unicast-topology".

I hope it is clear now.

Kind regards,
Michal

[1] https://tools.ietf.org/html/rfc7950#page-137
[2] https://tools.ietf.org/html/rfc7950#section-6.4.1
[3] https://tools.ietf.org/html/rfc7950#section-10.1.1

On Tuesday, December 12, 2017 16:49 CET, Benoit Claise <bclaise@cisco.com>
wrote:

> Hi Radek,
>
> I'm looking at warnings for
> ietf-l3-unicast-topology-state@2017-11-15.yang and 
> ietf-l3-unicast-topology-state@2017-11-15.yang
> See http://www.claise.be/IETFYANGPageCompilation.html
>
> Here is something interesting: the warnings only appear with the -V option.
>
> bclaise@bclaise-VirtualBox:~/ietf/YANG-all$ yanglint 
> ietf-l3-unicast-topology@2017-11-15.yang
> bclaise@bclaise-VirtualBox:~/ietf/YANG-all$ yanglint -i 
> ietf-l3-unicast-topology@2017-11-15.yang
> bclaise@bclaise-VirtualBox:~/ietf/YANG-all$ yanglint -i -V 
> ietf-l3-unicast-topology@2017-11-15.yang
> warn: Schema node "l3-unicast-topology" not found
> (ietf-network:network-types/l3-unicast-topology) with context node 
> "/ietf-network:networks/network".
> warn: Schema node "l3-unicast-topology" not found
> (../ietf-network:network-types/l3-unicast-topology) with context node 
> "/ietf-network:networks/network/node".
> warn: Schema node "l3-unicast-topology" not found
> (../ietf-network:network-types/l3-unicast-topology) with context node 
> "/ietf-network:networks/ietf-network:network/link".
> warn: Schema node "l3-unicast-topology" not found
> (../../ietf-network:network-types/l3-unicast-topology) with context 
> node
>
"/ietf-network:networks/ietf-network:network/ietf-network:node/termination-point".
> bclaise@bclaise-VirtualBox:~/ietf/YANG-all$ yanglint -v > yanglint 
> 0.13.79 >
bclaise@bclaise-VirtualBox:~/ietf/YANG-all$ > > bclaise@bclaise-VirtualBox:~/ietf/YANG-all$ yanglint > ietf-l3-unicast-topology-state@2017-11-15.yang > bclaise@bclaise-VirtualBox:~/ietf/YANG-all$ yanglint -i > ietf-l3-unicast-topology-state@2017-11-15.yang > bclaise@bclaise-VirtualBox:~/ietf/YANG-all$ yanglint -i -V > ietf-l3-unicast-topology-state@2017-11-15.yang > warn: Schema node "l3-unicast-topology" not found >
(ietf-network:network-types/l3-unicast-topology) with context node > "/ietf-network:networks/network". > warn: Schema node "l3-unicast-topology" not found > (../ietf-network:network-types/l3-unicast-topology) with context node > "/ietf-network:networks/network/node". > warn: Schema node "l3-unicast-topology" not found >
(../ietf-network:network-types/l3-unicast-topology) with context node > "/ietf-network:networks/ietf-network:network/link". > warn: Schema node "l3-unicast-topology" not found >
(../../ietf-network:network-types/l3-unicast-topology) with context node > "/ietf-network:networks/ietf-network:network/ietf-network:node/termination-point".
> warn: Schema node "l3-unicast-topology" not found >
(ietf-network-state:network-types/l3-unicast-topology) with context node > "/ietf-network-state:networks/network". > warn: Schema node "l3-unicast-topology" not found >
(../ietf-network-state:network-types/l3-unicast-topology) with context > node "/ietf-network-state:networks/network/node". > warn: Schema node "l3-unicast-topology" not found >
(../ietf-network-state:network-types/l3-unicast-topology) with context > node "/ietf-network-state:networks/ietf-network-state:network/link".

> warn: Schema node "l3-unicast-topology" not found
> (../../ietf-network-state:network-types/l3-unicast-topology) with 
> context node
>
"/ietf-network-state:networks/ietf-network-state:network/ietf-network-state:node/termination-point".
> bclaise@bclaise-VirtualBox:~/ietf/YANG-all$ > > Should we pay 
> attention to
those? > > Regards, Benoit

====================================================
Preliminary note: I hope I'm doing the right thing by updating this DISCUSS point as  I understand that the document is back to the WG. However, since I reviewed the version 11, since some of my ballot points have been addressed (thank you), and since I wanted to share my feedback publicly, here is my feedback.

1. The examples.
In the AUTH48 for the RESTCONF RFC, the example YANG module discussion came up (again).  And the examples in draft-ietf-i2rs-yang-l3-topology were also discussed. Here is the feedback from one YANG doctor, from a couple of days ago.

Look at this:

   module example-ietf-ospf-topology {
     ...
     namespace
       "urn:ietf:params:xml:ns:yang:example-ietf-ospf-topology";
     ...
     description
       "This module defines a model for OSPF network topologies.
        Copyright (c) 2017 IETF Trust and the persons identified as
        authors of the code.

They are using the IANA-controlled namespace w/o registering it.

This module *really* looks like a proper normative module, rather than an example.  They went to far in trying to mimic a real module.

It is clear that we need more guidelines in 6087 for how to write example modules.

I was going to ask if this module passed YANG doctor review - then I checked and saw that version -02 was reviewed, which didn't include this example.  How should we (the YANG doctors) handle such a case?

In this case they should:

  1.  change the name to example-ospf-topology
  2.  change the namespace to urn:example:ospf-topology
  3.  remove the top-level statements:
          organization, contact, revision

  4.  change the top-level description to what the text in the draft
      says:

      description
        "This module is intended as an example for how the
         Layer 3 Unicast topology model can be extended to cover
         OSFP topologies.";

(same for the other example module)

As I mentioned to the authors, respective chairs and AD already, we should follow the decision in this NETMOD email thread https://www.ietf.org/mail-archive/web/netmod/current/msg17428.html This will hopefully resolve fast. Once settled, the examples should be updated.

4.

       leaf-list router-id {
           type inet:ip-address;
           description
             "Router-id for the node";
         }

My initial DISCUSS was: We don't want to wait for
https://tools.ietf.org/html/draft-ietf-rtgwg-routing-types-00 (btw, we should expedite this publication), but any good reason why this is aligned with its definition?
    typedef router-id {
       type yang:dotted-quad;
       description
         "A 32-bit number in the dotted quad format assigned to each
          router. This number uniquely identifies the router within an
          Autonomous System.";
     }

My NEW DISCUSS: since is in IETF LC and on the telechat on Oct 12th, it makes sense to import its router-id


----------------------------------------------------------------------
COMMENT:
----------------------------------------------------------------------

- YANG definition "YANG: A data definition language for NETCONF"
I would use:
   YANG is a data modeling language used to model configuration data,
   state data, Remote Procedure Calls, and notifications for network
   management protocols [RFC7950]

- There are multiple slightly different definitions of the datastore in the different RFCs.
Let's not add to the confusion.
Pick one (RFC6241 should be the latest one) and mention the reference.

I'm copying Lada, as the responsible YANG doctor, in case he wants to add anything.
- section 7
OLD:
The moodel defines
NEW:
The model defines