Script requires python 3.7 or higher.
To install python dependencies use following command:
pip install -r requirements.txt
(if python3 use pip3 instead of pip)
-
edit ./cf_runtests/input/credentials.py
-
set controller IP in ./cf_runtests/input/cf_config.py file
-
Create a test queue for the profile you want to test, for example Functional-4x100G
-
Next create a new project (do not copy the existing NSO project)and configure a single HTTP Throughput test and selectin the above Test Queue, next configure your Subnets/Networks as normal (the Network Profiles and HTTP protocols options are set in create_tests_nso.csv file) and run this new test as we need the Test Run ID.
-
Once the test is completed, close the Live Charts and open your project and load the same HTTP Throughput test.
-
Copy the test id from the browser url bar (last part of URL)
-
Next paste the same test id under create_test.py section of the cf_config.py file as shown below
#create_tests.py base test ID - use working HTTP Throughput test from controller
#create_tests will use this ID to copy port group, subnets and other settings from
create_tests_base_test_id = '6f9cf64409bdd97428a78f9509dab444'
create_test_source_csv = 'create_tests_nso.csv' # located in input sub directory, do not put subdir in var
-
Optionally edit ./cf_runtests/input/create_tests_nso.csv file for number of tests to create, this is the "include" column (default setting will run 27 tests)
-
Now create the tests cd cf_runtests ; python3 ./create_tests.py (this takes a couple seconds per test, once completed you will see the tests created in your Project)
-
Optionally edit capacity_adjust column in ./cf_runtests/input/run_tests.csv file, this is the “capacity_adj” column. The default value, “auto” will set the load to SimUser per core. For further control this can be set for the profile, e.g. C100-S3 10G, client use 2 ports, then set capacity_adjust to 6 (3*2 = 6, has 3 cores per port, 2 ports used), S3-100G use 14 (suppose 1 port used), C200-100G use 16 (1 port used), etc.
-
Finally run the tests cd cf_runtests ; python3 ./run_tests.py (on a C100-S3, 4x100G this took about 3rs 45min)
-
The results will be in the report dir:
jsutton$ pwd
./cf_runtests/report
$ ls -l
total 3944
-rw-r--r-- 1 jsutton 1275193766 1059622 May 28 03:26 20200527-2136_Detailed.csv
-rw-r--r-- 1 jsutton 1275193766 12871 May 28 03:26 20200527-2136_all.csv
-rw-r--r--@ 1 jsutton 1275193766 298465 May 28 03:26 20200527-2136_all.html
-rw-r--r-- 1 jsutton 1275193766 76568 May 28 03:26 20200527-2136_kpi.html
-rw-r--r-- 1 jsutton 1275193766 47897 May 28 03:26 20200527-2136_sum.html
In case of path errors when executing the scripts. Add project to python path (add the project, not the cf_runtest sub dir)
Linux: export PYTHONPATH=/path/to/cf-netsecopen-tests:$PYTHONPATH
Windows: set PYTHONPATH=%PYTHONPATH%;C:\path\to\cf-netsecopen-tests
- name: name of the test in CyberFlood
- id: CyberFlood test ID, this is the id at the end of a tests configuration URL.
- type: CyberFlood test type, can be 'http_throughput', 'http_connections_per_second', 'open_connections' or 'emix'.
- run: Y or N to run test, useful to run only select tests.
- run_oder: tests run in order of this field 0 being first. When multiple tests have the same order number they run in order of the list. To support sub ordering later 11 will run before 2.
- goal_seek: Y or N for goal seeking. If N, the script runs the tests per the load spec with ramp to the start_load value.
- ramp_seek: Y or N for optional additional ramp to ramp_kpi value after ramp to start_load and before goal seeking.
- ramp_kpi: tps, cps, bw, conns or ttfb, kpi type for ramp_value.
- ramp_value: number the script will attempt to ramp up to.
- ramp_step: number of steps to ramp up to the ramp_value before starting goal seeking.
- duration: maximum duration of test. When goal seeking the test will stop if the goal has not been reached after this time. Without goal seeking the duration minus startup, rampup, rampdown and shutdown is the steady state period of the test.
- startup: time before traffic starts.
- rampup: duration of ramp to start_load value.
- rampdown: duration of ramp to no load at the end of the steady phase. Not used when goal seeking.
- shutdown: time after rampdown to allow connections to close.
- sustain_period: time to run test after maximum load has been reached in goal seeking. Only used in goal seeking. The script report has the average of this phase. Default is 30s. NetSecOPEN certification requires this value to be changed to 300s.
- kpi_1: tps (default), cps, bw, conns or ttfb. Primary kpi to determine if load is stable before further load increases.
- kpi_2: cps (default), tps, bw, conns or ttfb. Secondary kpi to determine if load is stable before further load increases.
- kpi_and_or: 'AND' or 'OR'. If set to OR load stability is determined from either value. If set to AND both KPIs have to be stable before further load increases.
- load_type: 'Simusers', 'Simusers/Second', Bandwidth', 'Connections/Second' or 'connections'. CyberFlood load spec type for start_load and incremental load values.
- start_load: starting load for selected load_type. Every test will ramp up to this load. Defaults are starting simuser load type. If load is set to bandwidth 1000000 is 1 Gbps.
- incr_low: initial goal seek load increase and subsequent increases if average kpi_1 increase is higher than low_threshold. For simusers(/second) load type the threshold is a percentage between 0 and 100. For other load types it is the actual value, for example, when low_threshold is set to 5Gbps increases will be by this value in bandwidth.
- incr_med: subsequent goal seek load increase if kpi_1 increase is between low_ and med_threshold.
- incr_high: subsequent goal seek load increase if kpi_1 increase is between med_ and high_threshold.
- low_threshold: threshold for load increase for incr_low.
- med_threshold: threshold for load increase for incr_med.
- high_threshold: stops goal seeking if load increase of kpi_1 is below this value.
- variance_sample_size: number of result interval samples to determine load stability, default is 3. Can go higher, lower is not recommended.
- max_variance: maximum allowed variance within variance_sample_size to allow load increase. Default is 0.03 (3%) between minimum and maximum values in variance_sample_size.
- capacity_adj: multiplies load values start_load, incr_low, _med and _high. If set to 'auto' multiple will be based on client core count in test when set to simusers(/second) and to port count for other load types. Can be set to a number also.
- ramp_low: percentage of load at ramp_seek complete phase to set goal seek incr_low value. Only used with ramp_seek and goal_seek. Default 60(%).
- ramp_med: percentage of load at ramp_seek complete phase to set goal seek incr_med value. Only used with ramp_seek and goal_seek. Default 40(%).
- ramp_high: percentage of load at ramp_seek complete phase to set goal seek incr_high value. Only used with ramp_seek and goal_seek. Default 20(%).
- living_simusers_max: none (default) or maximum number of living simusers in a test. Can be useful in Simusers/Second load spec to prevent tests from failing.