diff --git a/inventory_provider/juniper.py b/inventory_provider/juniper.py index ff8672c462d41ed3c04e6ea8c4f40bc5b3ba5c7a..e887c669c95c5e2e64a84ed2f3217ec850d1491d 100644 --- a/inventory_provider/juniper.py +++ b/inventory_provider/juniper.py @@ -148,11 +148,19 @@ def list_interfaces(netconf_config): def _ifc_info(e): name = e.find('name') assert name is not None, "expected interface 'name' child element" - description = e.find('description') - return { + ifc = { 'name': name.text, - 'description': description.text if description is not None else '' + 'description': '' } + description = e.find('description') + if description is not None: + ifc['description'] = description.text + + ifc['ipv4'] = e.xpath('./family/inet/address/name/text()') + ifc['ipv6'] = e.xpath('./family/inet6/address/name/text()') + + return ifc + for i in netconf_config.xpath('//configuration/interfaces/interface'): info = _ifc_info(i) diff --git a/test/per_router/test_juniper_data.py b/test/per_router/test_juniper_data.py index e6343d0042c664b787cffc5e5af1b6f28dcf2495..c8bc7ddaf8d9c60e2f8fe8e3cbf29af562cb24be 100644 --- a/test/per_router/test_juniper_data.py +++ b/test/per_router/test_juniper_data.py @@ -44,6 +44,10 @@ def netconf_doc(mocker, router, data_config): def test_interface_list(netconf_doc): + hostname = netconf_doc.xpath('//configuration/groups/system/host-name/text()')[0] + if not hostname.startswith('mx1.mad.es'): + return + schema = { "$schema": "http://json-schema.org/draft-07/schema#", "type": "array", @@ -51,9 +55,17 @@ def test_interface_list(netconf_doc): "type": "object", "properties": { "name": {"type": "string"}, - "description": {"type": "string"} + "description": {"type": "string"}, + "ipv4": { + "type": "array", + "items": {"type": "string"} + }, + "ipv6": { + "type": "array", + "items": {"type": "string"} + } }, - "required": ["name", "description"], + "required": ["name", "description", "ipv4", "ipv6"], "additionalProperties": False } }