Testing
E2E Tests
(These reports are for the last 1000 test runs only)
Environment / Framework
Initial Deployment
The picture below shows the initial deployment that should be installed in a kubernetes cluster in order to execute the complete e2e test suite in dualstack. With only IPv4, elements containing v6 are not used, and with only IPv6, elements containing v4 are not used. Elements between [] are configurable via parameters, see the Configuration section. 
Configuration
| Name | Type | Description | 
|---|---|---|
| traffic-generator-cmd | string | Command to use to connect to the traffic generator. All occurences of '{trench}' will be replaced with the trench name. | 
| script | string | Path + script used by the e2e tests | 
| skip | string | Skip specific tests | 
| focus | string | Focus on specific tests | 
| log-collector-enabled | bool | Is log collector enabled | 
| ignore-lost-connections | bool | If set to true, the tests will pass even if there is lost connections | 
| k8s-namespace | string | Name of the namespace | 
| target-a-deployment-name | string | Name of the target deployment | 
| trench-a | string | Name of the trench | 
| attractor-a-1 | string | Name of the attractor | 
| conduit-a-1 | string | Name of the conduit | 
| stream-a-I | string | Name of the stream | 
| stream-a-II | string | Name of the stream | 
| tcp-destination-port-0 | int | Destination port 0 | 
| tcp-destination-port-1 | int | Destination port 1 ( tcp-destination-port-0+ 1) | 
| tcp-destination-port-2 | int | Destination port 2 ( tcp-destination-port-1+ 1) | 
| udp-destination-port-0 | int | Destination port 0 | 
| vip-1-v4 | string | Address of the vip v4 number 1 | 
| vip-1-v6 | string | Address of the vip v6 number 1 | 
| target-b-deployment-name | string | Name of the target deployment | 
| trench-b | string | Name of the trench | 
| conduit-b-1 | string | Name of the conduit | 
| stream-b-I | string | Name of the stream | 
| vip-2-v4 | string | Address of the vip v4 number 2 | 
| vip-2-v6 | string | Address of the vip v6 number 2 | 
| stream-a-III | string | Name of the stream | 
| conduit-a-2 | string | Name of the conduit | 
| stream-a-IV | string | Name of the stream | 
| vip-3-v4 | string | Address of the vip v4 number 3 | 
| vip-3-v6 | string | Address of the vip v6 number 3 | 
| conduit-a-3 | string | Name of the conduit | 
| tcp-destination-port-nat-0 | int | Destination port natted 0 | 
| stateless-lb-fe-deployment-name-attractor-a-1 | string | Name of stateless-lb-fe deployment in attractor-a-1 | 
| stateless-lb-fe-deployment-name-attractor-b-1 | string | Name of stateless-lb-fe deployment in attractor-b-1 | 
| stateless-lb-fe-deployment-name-attractor-a-2 | string | Name of stateless-lb-fe deployment in attractor-a-2 | 
| stateless-lb-fe-deployment-name-attractor-a-3 | string | Name of stateless-lb-fe deployment in attractor-a-3 | 
| ip-family | string | IP Family | 
For more details about each parameter, check the picture above in the Initial Deployment section.
Script
A bash script file must be passed as parameter of the e2e tests. The script is required to allowed the e2e tests to be run in every environment (Helm/Operator deployement...). The following functions has to be implemented in the script:
| Name | Description | 
|---|---|
| init () error | Executed once before running the tests | 
| end () error | Executed once after running the tests | 
| on_failure () error | Executed on failure | 
| delete_create_trench | Executed just before running the delete-create-trenchtest | 
| delete_create_trench_revert | Executed just before running the delete-create-trenchtest and after thedelete_create_trenchscript | 
| new_vip () error | Executed just before running the new-viptest | 
| new_vip_revert () error | Executed just after running the new-viptest | 
| new_stream () error | Executed just before running the new-streamtest | 
| new_stream_revert () error | Executed just after running the new-streamtest | 
| stream_max_targets () error | Executed just before running the stream-max-targetstest | 
| stream_max_targets_revert () error | Executed just after running the stream-max-targetstest | 
| new_flow () error | Executed just before running the new-flowtest | 
| new_flow_revert () error | Executed just after running the new-flowtest | 
| flow_priority () error | Executed just before running the flow-prioritytest | 
| flow_priority_revert () error | Executed just after running the flow-prioritytest | 
| flow_destination_ports_range () error | Executed just before running the flow-destination-ports-rangetest | 
| flow_destination_ports_range_revert () error | Executed just after running the flow-destination-ports-rangetest | 
| flow_byte_matches () error | Executed just after running the flow-byte-matchestest | 
| flow_byte_matches_revert () error | Executed just after running the flow-byte-matchestest | 
| new_attractor_nsm_vlan () error | Executed just before running the new-attractor-nsm-vlantest | 
| new_attractor_nsm_vlan_revert () error | Executed just after running the new-attractor-nsm-vlantest | 
| conduit_destination_port_nats () error | Executed just before running the conduit-destination-port-natstest | 
| conduit_destination_port_nats_revert () error | Executed just after running the conduit-destination-port-natstest | 
List of tests
| Name | Type | Description | 
|---|---|---|
| TCP-IPv4 | IngressTraffic | Send TCP traffic in trench-awithvip-1-v4as destination IP andtcp-destination-port-0as destination port | 
| TCP-IPv6 | IngressTraffic | Send TCP traffic in trench-awithvip-1-v6as destination IP andtcp-destination-port-0as destination port | 
| UDP-IPv4 | IngressTraffic | Send UDP traffic in trench-awithvip-1-v4as destination IP andudp-destination-port-0as destination port | 
| UDP-IPv6 | IngressTraffic | Send UDP traffic in trench-awithvip-1-v6as destination IP andudp-destination-port-0as destination port | 
| MT-Switch | MultiTrenches | Disconnect a target from target-a-deployment-namefromtrench-aand connect it totrench-b | 
| MT-Parallel | MultiTrenches | Send traffic in trench-aandtrench-bat the same time | 
| Scale-Down | Scaling | Scale down target-a-deployment-name | 
| Scale-Up | Scaling | Scale up target-a-deployment-name | 
| close-open | TAPA | Close stream-a-Iin one of the target fromtarget-a-deployment-nameand re-open it | 
| open-second-stream | TAPA | Open stream-a-IIin one of the target fromtarget-a-deployment-nameand close it | 
| open-second-stream-second-conduit | TAPA | Open stream-a-IVin one of the target fromtarget-a-deployment-nameand close it | 
| delete-create-trench | Trench | Delete trench-aand recreate and reconfigure it | 
| new-vip | Vip | Configure vip-2-v4andvip-2-v6inflow-a-z-tcpandattractor-a-1 | 
| new-stream | Stream | Configure stream-a-IIIinconduit-a-1with a new flow with tcp,tcp-destination-port-2as destination port andvip-1-v4andvip-1-v6 | 
| stream-max-targets | Stream | Configure stream-a-IIIas innew-streamtest with the max-targets field set to 1 and 2 targets withstream-a-IIIopened | 
| new-flow | Flow | Configure a new flow with tcp, tcp-destination-port-2as destination port andvip-1-v4andvip-1-v6instream-a-I | 
| flow-priority | Flow | Set priority to 3 and add tcp-destination-port-1as destination port inflow-a-z-tcp | 
| flow-destination-ports-range | Flow | Set priority to 3 and set ' tcp-destination-port-0'-'tcp-destination-port-2' as destination port inflow-a-z-tcp | 
| flow-byte-matches | Flow | Add tcp-destination-port-2to destination ports offlow-a-z-tcpand add a byte-match to allow onlytcp-destination-port-2 | 
| new-attractor-nsm-vlan | Attractor | Configure a new attractor with new vips vip-2-v4andvip-2-v6, gateways, conduitconduit-a-3, streamstream-a-IIIand flow with tcp andtcp-destination-port-0as destination port | 
| conduit-destination-port-nats | Conduit | Configure flow-a-z-tcpwithtcp-destination-port-nat-0as destination port andconduit-a-1with a port nat withtcp-destination-port-nat-0as port andtcp-destination-port-0as target-port | 
Steps
Kind + Helm
- Deploy environment (Kind + Gateways + NSM + Spire) and Meridio (trench-a + trench-b + target-a + target-b)
make -s -C test/e2e/environment/kind-helm/ KUBERNETES_VERSION=v1.25 NSM_VERSION=v1.6.1 KUBERNETES_IP_FAMILY=dualstack KUBERNETES_WORKERS=2
- Run e2e tests
make e2e
- Uninstall environment
make -s -C docs/demo/scripts/kind/ clean
Kind + Operator
- Deploy environment (Kind + Gateways + NSM + Spire) and Meridio (operator + trench-a + trench-b + target-a + target-b)
make -s -C test/e2e/environment/kind-operator/ KUBERNETES_VERSION=v1.26 NSM_VERSION=v1.6.1 IP_FAMILY=dualstack KUBERNETES_WORKERS=2
- Run e2e tests
make e2e E2E_ENVIRONMENT="kind-operator"
- Uninstall environment
make -s -C docs/demo/scripts/kind/ clean