diff options
author | selias <samuel.elias@pantheon.tech> | 2016-04-29 12:50:33 +0200 |
---|---|---|
committer | Matej Klotton <mklotton@cisco.com> | 2016-05-06 17:23:41 +0200 |
commit | c478afc5aec0161cc66e837c1ab919542b68ebbc (patch) | |
tree | 7817c20b6b81807a1999ca5330959911da272bc3 /tests/suites | |
parent | 07c0ae2e49665961af4a8b9734218e9c5f8cd3ca (diff) |
Add Honeycomb interface management tests (ipv4, ipv6, ethernet, routing)
- add test cases for managing ipv4, ipv6, ethernet and routing
configuration on VPP interface
- add keywords used in these tests to set and verify configuration
- add method and vat template for dumping an interface's
configured IP addresses
- add method for converting between ipv4 netmasks and
network prefixes
- clean up documentation of older Honeycomb keywords
Note: Test cases are tagged with a placeholder tag to allow manual
test runs locally. It should be replaced with the appropriate
environment tags once Honeycomb service is deployed on virl.
Change-Id: I99ce1e72c8550f520f8c35ef4a93eaebb530db78
Signed-off-by: selias <samelias@cisco.com>
Signed-off-by: Matej Klotton <mklotton@cisco.com>
Diffstat (limited to 'tests/suites')
-rw-r--r-- | tests/suites/honeycomb/interface_management.robot | 50 |
1 files changed, 48 insertions, 2 deletions
diff --git a/tests/suites/honeycomb/interface_management.robot b/tests/suites/honeycomb/interface_management.robot index 37200d023f..f741f9543b 100644 --- a/tests/suites/honeycomb/interface_management.robot +++ b/tests/suites/honeycomb/interface_management.robot @@ -12,8 +12,19 @@ # limitations under the License. *** Variables *** +# Node and interface to run tests on. | ${node}= | ${nodes['DUT1']} | ${interface}= | ${node['interfaces'].values()[0]['name']} +# Configuration which will be set and verified during tests. +| @{ipv4_address}= | 192.168.0.2 | 255.255.255.0 +| @{ipv4_neighbor}= | 192.168.0.3 | 08:00:27:c0:5d:37 +| &{ipv4_settings}= | enabled=${True} | forwarding=${True} | mtu=9000 +| @{ipv6_address}= | 10::10 | 64 +| @{ipv6_neighbor}= | 10::11 | 08:00:27:c0:5d:37 +| &{ipv6_settings}= | enabled=${True} | forwarding=${True} | mtu=9000 +| ... | dup-addr-detect-transmits=5 +| &{ethernet}= | mtu=9000 +| &{routing}= | vrf-id=27 *** Settings *** | Resource | resources/libraries/robot/default.robot @@ -27,8 +38,8 @@ | ... | Test suite uses the first interface of the first DUT node. *** Test Cases *** -| Honeycomb modifies interface state -| | [Documentation] | Check if Honeycomb API can modify the admin state of +| Honeycomb configures and reads interface state +| | [Documentation] | Check if Honeycomb API can modify the admin state of\ | | ... | VPP interfaces. | | [Tags] | honeycomb_sanity | | Given Interface state is | ${node} | ${interface} | down @@ -40,3 +51,38 @@ | | Then Interface state from Honeycomb should be | | ... | ${node} | ${interface} | down | | And Interface state from VAT should be | ${node} | ${interface} | down + +| Honeycomb modifies interface configuration - ipv4 +| | [Documentation] | Check if Honeycomb API can configure interfaces for ipv4. +| | [Tags] | honeycomb_sanity +| | When Honeycomb sets interface ipv4 configuration +| | ... | ${node} | ${interface} | @{ipv4_address} | @{ipv4_neighbor} +| | ... | ${ipv4_settings} +| | Then IPv4 config from Honeycomb should be +| | ... | ${node} | ${interface} | @{ipv4_address} | @{ipv4_neighbor} +| | ... | ${ipv4_settings} +| | And IPv4 config from VAT should be +| | ... | ${node} | ${interface} | @{ipv4_address} + +| Honeycomb modifies interface configuration - ipv6 +| | [Documentation] | Check if Honeycomb API can configure interfaces for ipv6. +| | [Tags] | honeycomb_sanity +| | When Honeycomb sets interface ipv6 configuration +| | ... | ${node} | ${interface} | @{ipv6_address} | @{ipv6_neighbor} +| | ... | ${ipv6_settings} +| | Then IPv6 config from Honeycomb should be +| | ... | ${node} | ${interface} | @{ipv6_address} | @{ipv6_neighbor} +| | ... | ${ipv6_settings} +| | And IPv6 config from VAT should be +| | ... | ${node} | ${interface} | @{ipv6_address} + +| Honeycomb modifies interface configuration - ethernet,routing +| | [Documentation] | Check if Honeycomb API can configure interface ethernet\ +| | ... | and routing settings. +| | [Tags] | honeycomb_sanity +| | When Honeycomb sets interface ethernet and routing configuration +| | ... | ${node} | ${interface} | ${ethernet} | ${routing} +| | Then Interface ethernet and routing configuration from Honeycomb should be +| | ... | ${node} | ${interface} | ${ethernet} | ${routing} +| | And Interface ethernet and routing configuration from VAT should be +| | ... | ${node} | ${interface} | ${ethernet['mtu']} | ${routing['vrf-id']} |