OFTest OpenFlow Testing Framework


Introduction

OFTest is a Python based framework for OpenFlow switch testing.

In this project we use OFTest to ensure OpenFlow conformance of the switches used to implement the network infrastructure of the OpenCord project.

At this moment the switches supported are Accton switches. For more information abot that check the wiki page at wiki.opencord.org

This code base was forked from macauleycheng which was forked from floodlight. This documentationn aims to describe the specific test cases developed for OpenCord. To get started on the basics of OFTest please check their documentation.


How it is organized

This codebase is organized by branches. Each OFDPA release correspond to a different branch. At this moment the following releases are available:

OFDPA versionBranchStatus
i19i19Archived
i12i12Archived
i12_1.7cord-1.0Released
2.0 GA2.0-gaArchived
3.0 EA0masterDeveloping <- current branch

The test case collection for OpenCord are under the folder ofdpa. They are listed under the section Test case collection.

Installing Prerequisites

Following packages need to be installed before running OFTest:

sudo apt-get install python python-pip python-dev python-lxml -y
sudo pip install ncclient
sudo pip install scapy pycripto
sudo apt-get install python-ecdsa git

Start Testing

On the switch side:

  1. Purge the switch flow/group table by running

    	client_cfg_purge
    
  2. Connect the switch to the testing controller

    	brcm-indigo-ofdpa-ofagent -t <controller_ip>
    

On the controller side:

  1. Clone the source code and switch to the correct branch

    	git clone -b master git://github.com/opencord/fabric-oftest
    
  2. Run all test cases in OFTest

    	sudo ./oft -V1.3 --test-dir=ofdpa flows -i 24@eth1 -i 12@eth2
    

    This command assumes you connected the switch port 24 to interface eth1 on the OFtest server and port 12 to eth2

Useful commands

  • List all available test cases

    	./oft --list --test-dir=ofdpa flows
    
  • Run only specific test case

    	sudo ./oft -V1.3 --test-dir=ofdpa flows.PacketInArp -i 24@eth1 -i 12@eth2
    

Test Result Summary

The following tests are implemented and these are their results.

Test Resultsi12_1.72.0 GA3.0 EA03.0 EA4
/0UcastXokokok
/24UnicastTaggedokokokok
/32UnicastTaggedokokokok
/24ECMPL3okokokok
/32ECMPL3okokokok
/24ECMPVPNokokokok
/32ECMPVPNokokokok
/32VPNokokokok
/24VPNokokokok
EcmpGroupModXXokok
PacketInArpokokokok
MTU1500okokokok
MplsTerminationokokokok
MplsFwdXokokok
L2FloodQinQokokokok
L2UnicastTaggedokokokok
L3McastToL3okXokok
L3McastToL2_1*??okok
L3McastToL2_2**??okok
L3McastToL2_3***??okok
L3McastToL2_4****ok?okok
L3McastToL2_5*****??okok
FloodGroupModXXokok
PacketInUDPokokokok
UnfilteredXokXok
Untaggedokn/aokok
PacketInIPTableXXokok
  •   Untag -> Untag (4094 as internal vlan)
    

** Untag -> Tag *** Tag -> Untag **** Tag -> Tag ***** Tag -> Tag (Translated)

n/a means test is not available for that version of the pipeline.

VLAN Test Result Summary

The following tests are implemented in vlan_flows.py and these are their results.

Test Results3.0 EA03.0 EA4
L2ForwardingStackedVLANokok
L2ForwardingStackedVLAN2okok
L2ForwardingStackedVLAN3okok
L2ForwardingStackedVLAN4okok
L2ForwardingStackedVLAN5okok

For major details on the test look the comments in the code.

Pseudowire Test Result Summary

The following tests are implemented in pw_flows.py and these are their results.

Test Results3.0 EA03.0 EA4
UntaggedPWInitiation_2_Labelsokok
Untagged2PWInitiation_2_Labelsokok
UntaggedPWInitiation_3_Labelsokok
Untagged2PWInitiation_3_Labelsokok
TaggedPWInitiation_2_Labelsxok*
Tagged2PWInitiation_2_Labelsxok*
TaggedPWInitiation_3_Labelsxok*
Tagged2PWInitiation_3_Labelsxok*
DoubleTaggedPWInitiation_2_Labelsxok*
DoubleTagged2PWInitiation_2_Labelsxok*
DoubleTaggedPWInitiation_3_Labelsxok*
DoubleTagged2PWInitiation_3_Labelsxok*
IntraCO_2_Labelsokok*
IntraCO_3_Labelsokok*
InterCOokok*
UntaggedPWTerminationokok
Untagged2PWTerminationxx
TaggedPWTerminationokok
DoubleTaggedPWTerminationokok
BoSBugxx
  • The test may fail intermittently

For major details on the test look the comments in the code.

IPv6 Test Result Summary

The following tests are implemented in ipv6_flows.py and these are their results.

Test Results3.0 EA03.0 EA4
PacketInICMPv6okok
PacketInIPv6Tableokok
_128UcastUnTaggedokok
_128ECMPVpnokok
_128ECMPL3okok
_64UcastUntaggedokok
_64ECMPVpnokok
_64ECMPL3okok
_0UcastV6okok
_MPLSTerminationV6okok

For major details on the test look the comments in the code.