Commit Graph

314 Commits

Author SHA1 Message Date
29a8bae899 Add get_bondethernets() 2022-03-24 16:34:45 +00:00
de95e522ab Move VPPApi into a Reconciler class, add (empty) prune() create() and sync() methods. Add --force flag to enable making progress after warnings are issued 2022-03-24 15:57:12 +00:00
2e2f63e1dd Fix reporting of YAML tests; send retval based on the bitflags of tests passing/failing 2022-03-24 15:15:26 +00:00
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