cfcbec239c
Cosmetic rename instance of config/validator class
2022-03-24 15:05:15 +00:00
672dd65f11
Rename validator/ to config/
2022-03-24 13:56:04 +00:00
e8e41098be
Assert that all PHYs in the config also exist in VPP
2022-03-24 12:29:16 +00:00
8129235031
Clean up logging a little bit
2022-03-24 12:14:26 +00:00
b43d7903fd
Add a few additional useful functions
...
- is_*() returns True if the interface name is of a certain type
is_bondethernet() is_loopback() is_bvi() is_bridgedomain()
is_vxlan_tunnel() is_phy()
- get_phys() by process of elimination, returns all interface names
that are supposed to be physical network interfaces.
Add unit tests for validator/vxlan_tunnel.py
=> Notable: while here, fix a bug in get_by_name()
Add unit tests for all the is_*() and get_phys() functions.
2022-03-24 10:55:33 +00:00
ac5b8fcc8f
Simple VPPApi abstraction, which fetches the necessary info from VPP, and a few dumpers
2022-03-23 23:29:19 +00:00
8ac9b50d94
Add some clarification to the reconsiliation algorithm
2022-03-23 23:28:12 +00:00
f37b80c012
Break into three sections
2022-03-23 17:16:29 +00:00
bcc4c8ff05
Merge branch 'main' of github.com:pimvanpelt/vppcfg into main
2022-03-23 17:11:46 +00:00
7390322693
Add first stab approximation of the reconsiliation order
2022-03-23 17:11:34 +00:00
613b4a27c7
Update README.md
2022-03-22 23:03:22 +01:00
df1b1bbbef
Update README.md
2022-03-22 22:58:38 +01:00
c37faecd3f
Buffer output, print when errors occur. Introduce debug/quiet flags
2022-03-22 20:11:32 +00:00
4cb07cf2da
Add -d and -q flags
2022-03-22 19:52:19 +00:00
0ab907f155
Add get_bridgedomains()
2022-03-22 18:57:45 +00:00
27ce2351c7
Cosmetic: use '.. LCP' consistently
2022-03-22 18:49:31 +00:00
97fef9bfd2
Assert get_by_name() with non-existent name returns a tuple of None,None
2022-03-22 18:31:03 +00:00
5ecd1ef22c
Add unit tests for loopbacks; While here, fix a bug in get_by_name(), yaay
2022-03-22 18:03:38 +00:00
36fbbf9b35
Add a full set of get_*_by_name() tests
2022-03-22 17:53:40 +00:00
1e7227a52a
Allow for bridgedomains without any member interfaces
2022-03-22 15:38:43 +00:00
7bf940be0a
Become a bit stricter: do full-line pattern match, and update unit tests to capture the full error output
2022-03-22 15:10:40 +00:00
7303adb74a
Assert is_l2() on sub-ints cannot have address or LCP
2022-03-22 15:02:38 +00:00
077d49cb88
Assert that is_l2() interfaces cannot have LCP or address; Fix consistency on 'be' vs 'have' an LCP.
2022-03-22 14:54:09 +00:00
6688c6b243
Add the case of the ifname being the source of an l2xc to the is_l2() logic1
...
This is more strict than VPP itself, which does allow a destination to
be L3 while the source is L2:
DBGvpp# show mode
l3 local0
l3 GigabitEthernet3/0/0
l3 GigabitEthernet3/0/1
l3 HundredGigabitEthernet12/0/0
l3 HundredGigabitEthernet12/0/1
DBGvpp# set interface l2 xconnect GigabitEthernet3/0/0 GigabitEthernet3/0/1
DBGvpp# show mode
l3 local0
l2 xconnect GigabitEthernet3/0/0 GigabitEthernet3/0/1
l3 GigabitEthernet3/0/1
l3 HundredGigabitEthernet12/0/0
l3 HundredGigabitEthernet12/0/1
But it seems undesirable to have Gi3/0/1 be in l3 mode even though it's
the target of a cross connect, so I'm going to leave the behavior
stricter than VPP.
2022-03-22 14:21:32 +00:00
5ebaf5e005
Add optional filtering of get_lcps() based on type of interface
2022-03-22 14:17:36 +00:00
907412f49c
Fix bug in get_l2xc_interfaces(), and add tests for it
2022-03-22 13:15:21 +00:00
7ae82c297c
Add get_lcps() to enumerate all LCP names in the system
2022-03-22 13:04:56 +00:00
c18f04fa55
Refactor: stop trying to derive implicit LCP names. Make it mandatory and explicitly configured
2022-03-21 11:06:15 +00:00
551b06bb67
Move the output around - first print the unexpected messages, only then fail the assertions
2022-03-21 10:23:49 +00:00
58d0ebe71e
Complete test_qinx now that get_*_by_name() returns tuples
2022-03-21 08:53:40 +00:00
ba22b1aad8
Refactor for *_get_by_name()
...
They now all return a list [ifname, iface]. If no interface was found
they return None,None. If one was found, they return the (string) name
and the dictionary with interface contents.
2022-03-21 08:47:05 +00:00
5247e3a241
Add the beginning of a test_qinx() suite, will complete after a refactor in an upcoming commit
2022-03-20 23:32:59 +00:00
e44db47989
Add interface.get_qinx_parent_by_name()
2022-03-20 23:10:54 +00:00
c55fe93e16
Add unit tests for bridgedomain - move is_bridge_interface*() functions to validator/bridgedomain.py
2022-03-20 22:45:07 +00:00
47757b702c
Correct name for LCP tests
2022-03-20 22:17:56 +00:00
1f07f7eadf
Add unit tests for bondethernet
2022-03-20 22:17:41 +00:00
31c3d13c12
Isolate LCP into its own tests
2022-03-20 22:04:49 +00:00
14cd365ad3
Move LCP tests to their own test_*py file
2022-03-20 22:01:51 +00:00
459346878a
Move to assertEqual
2022-03-20 21:54:28 +00:00
8445140842
Add unittests for validator/interface.py
2022-03-20 21:49:08 +00:00
e46cf3d3a8
Make the test.errors.count value explicit, update tests which had an implicit count
2022-03-20 19:44:29 +00:00
1ff3ae95cc
Fully move yamltest to unittest framework, assert errors instead of printing them
2022-03-20 19:27:23 +00:00
3291c60d9a
Start refactoring YAML tests into unittest framework
2022-03-20 18:59:40 +00:00
2036795ef1
Move unittest YAML files into their own directory, pending more python unit tests in a followup commit
2022-03-20 16:59:13 +00:00
dbd7bca8f3
Add get_encapsulation; refactor unique_encapsulation to use it. All tests pass.
2022-03-20 16:45:03 +00:00
7a1dc2f326
Test the boundary of valid LCP namelen
2022-03-17 00:37:46 +00:00
343c1097c7
Stop trying to police interface names -- they will be validated by get_by_name()
2022-03-17 00:20:22 +00:00
f921b1721a
Expand autocreated LCP namelen to all possible (dot1q, qin*) scenarios. Allow manually set LCP to be 15char in length
2022-03-17 00:15:18 +00:00
3663a04cde
Bugfix: check sub_iface instead of iface
2022-03-16 23:57:47 +00:00
59cbc8b886
Add description len=64 to avoid runaway strings
2022-03-16 23:23:28 +00:00