| """ + str(value) + """ |
@@ -496,7 +510,7 @@ class lf_report():
function fallbackCopyTextToClipboard(text) {
var textArea = document.createElement("textarea");
textArea.value = text;
-
+
// Avoid scrolling to bottom
textArea.style.top = "0";
textArea.style.left = "0";
@@ -561,6 +575,16 @@ function copyTextToClipboard(ele) {
# Unit Test
if __name__ == "__main__":
+ parser = argparse.ArgumentParser(
+ prog="lf_report.py",
+ formatter_class=argparse.RawTextHelpFormatter,
+ description="Reporting library Unit Test")
+ parser.add_argument('--lfmgr', help='sample argument: where LANforge GUI is running', default='localhost')
+ # the args parser is not really used , this is so the report is not generated when testing
+ # the imports with --help
+ args = parser.parse_args()
+ print("LANforge manager {lfmgr}".format(lfmgr=args.lfmgr))
+
# Testing: generate data frame
dataframe = pd.DataFrame({
'product': ['CT521a-264-1ac-1n', 'CT521a-1ac-1ax', 'CT522-264-1ac2-1n', 'CT523c-2ac2-db-10g-cu',
@@ -573,7 +597,7 @@ if __name__ == "__main__":
print(dataframe)
- # Testing: generate data frame
+ # Testing: generate data frame
dataframe2 = pd.DataFrame({
'station': [1, 2, 3, 4, 5, 6, 7],
'time_seconds': [23, 78, 22, 19, 45, 22, 25]
@@ -605,4 +629,3 @@ if __name__ == "__main__":
report.write_pdf()
print("report path {}".format(report.get_path()))
-
diff --git a/py-scripts/lf_report_test.py b/py-scripts/lf_report_test.py
index 0923f1e9..114af078 100755
--- a/py-scripts/lf_report_test.py
+++ b/py-scripts/lf_report_test.py
@@ -2,13 +2,13 @@
'''
NAME: lf_report_test.py
-PURPOSE:
+PURPOSE:
Common file for testing lf_report and lf_graph Library generates html and pdf output
-SETUP:
+SETUP:
/lanforge/html-reports directory needs to be present or output generated in local file
-EXAMPLE:
+EXAMPLE:
./lf_report_test.py : currently script does not accept input
COPYWRITE
@@ -26,8 +26,9 @@ import numpy as np
import pandas as pd
import pdfkit
import random
+import argparse
+
-
sys.path.append(os.path.join(os.path.abspath(__file__ + "../../../")))
lf_report = importlib.import_module("py-scripts.lf_report")
@@ -38,10 +39,45 @@ lf_scatter_graph = lf_graph.lf_scatter_graph
lf_stacked_graph = lf_graph.lf_stacked_graph
lf_horizontal_stacked_graph = lf_graph.lf_horizontal_stacked_graph
-
# Unit Test
-if __name__ == "__main__":
+
+
+def main():
# Testing: generate data frame
+ parser = argparse.ArgumentParser(
+ prog="lf_report_test.py",
+ formatter_class=argparse.RawTextHelpFormatter,
+ description='''\
+-----------------
+NAME: lf_report_test.py
+
+PURPOSE:
+Common file for testing lf_report and lf_graph Library generates html and pdf output
+
+SETUP:
+/lanforge/html-reports directory needs to be present or output generated in local file
+
+EXAMPLE:
+./lf_report_test.py : currently script does not accept input
+
+COPYWRITE
+ Copyright 2021 Candela Technologies Inc
+ License: Free to distribute and modify. LANforge systems must be licensed.
+
+INCLUDE_IN_README
+''')
+
+ parser.add_argument(
+ '--mgr',
+ '--lfmgr',
+ dest='lfmgr',
+ help='sample argument: where LANforge GUI is running',
+ default='localhost')
+ # the args parser is not really used , this is so the report is not generated when testing
+ # the imports with --help
+ args = parser.parse_args()
+ print("LANforge manager {lfmgr}".format(lfmgr=args.lfmgr))
+
dataframe = pd.DataFrame({
'product': ['CT521a-264-1ac-1n', 'CT521a-1ac-1ax', 'CT522-264-1ac2-1n', 'CT523c-2ac2-db-10g-cu',
'CT523c-3ac2-db-10g-cu', 'CT523c-8ax-ac10g-cu', 'CT523c-192-2ac2-1ac-10g'],
@@ -53,7 +89,7 @@ if __name__ == "__main__":
print(dataframe)
- # Testing: generate data frame
+ # Testing: generate data frame
dataframe2 = pd.DataFrame({
'station': [1, 2, 3, 4, 5, 6, 7],
'time_seconds': [23, 78, 22, 19, 45, 22, 25]
@@ -108,7 +144,7 @@ if __name__ == "__main__":
_xaxis_categories=x_axis_values,
_graph_image_name="Bi-single_radio_2.4GHz",
_label=["bi-downlink", "bi-uplink", 'uplink'],
- _color=['darkorange', 'forestgreen','blueviolet'],
+ _color=['darkorange', 'forestgreen', 'blueviolet'],
_color_edge='red',
_grp_title="Throughput for each clients",
_xaxis_step=5,
@@ -117,7 +153,7 @@ if __name__ == "__main__":
_text_rotation=45,
_xticks_font=7,
_legend_loc="best",
- _legend_box=(1,1),
+ _legend_box=(1, 1),
_legend_ncol=1,
_legend_fontsize=None,
_enable_csv=True)
@@ -127,7 +163,7 @@ if __name__ == "__main__":
print("graph name {}".format(graph_png))
report.set_graph_image(graph_png)
- # need to move the graph image to the results
+ # need to move the graph image to the results
report.move_graph_image()
if graph.enable_csv:
report.set_csv_filename(graph_png)
@@ -140,7 +176,7 @@ if __name__ == "__main__":
_graph_image_name="image_name1",
_color=None,
_label=["s1", "s2", "s3"],
- _enable_csv = False)
+ _enable_csv=False)
graph_png = graph2.build_scatter_graph()
print("graph name {}".format(graph_png))
@@ -149,14 +185,15 @@ if __name__ == "__main__":
report.move_graph_image()
report.build_graph()
- # this will generate graph which is independent,we can customize the value with different colors
+ # this will generate graph which is independent,we can customize the value
+ # with different colors
graph2 = lf_scatter_graph(_x_data_set=set1, _y_data_set=[45, 67, 45, 34], _values=[0, 0, 0, 1],
_xaxis_name="x-axis",
_yaxis_name="y-axis",
_graph_image_name="image_name_map",
_color=None,
_label=["s1", "s2"],
- _enable_csv = False)
+ _enable_csv=False)
graph_png = graph2.build_scatter_graph()
print("graph name {}".format(graph_png))
@@ -165,14 +202,15 @@ if __name__ == "__main__":
report.move_graph_image()
report.build_graph()
- dataset = [["1", "2", "3", "4"], [12, 45, 67, 34], [23, 67, 23, 12], [25, 45, 34, 23]]
+ dataset = [["1", "2", "3", "4"], [12, 45, 67, 34],
+ [23, 67, 23, 12], [25, 45, 34, 23]]
graph = lf_stacked_graph(_data_set=dataset,
_xaxis_name="Stations",
_yaxis_name="Login PASS/FAIL",
_label=['Success', 'Fail', 'both'],
_graph_image_name="login_pass_fail1",
_color=None,
- _enable_csv = False)
+ _enable_csv=False)
graph_png = graph.build_stacked_graph()
@@ -192,7 +230,7 @@ if __name__ == "__main__":
_graph_image_name="image_name_pass_fail",
_color=["r", "g"],
_figsize=(9, 4),
- _enable_csv = False)
+ _enable_csv=False)
graph_png = graph.build_horizontal_stacked_graph()
@@ -215,3 +253,5 @@ if __name__ == "__main__":
# report.write_pdf(_page_size = 'Legal', _orientation='Portrait')
# report.generate_report()
+if __name__ == "__main__":
+ main()
diff --git a/py-scripts/lf_rvr_test.py b/py-scripts/lf_rvr_test.py
index 628f7720..1f14225c 100755
--- a/py-scripts/lf_rvr_test.py
+++ b/py-scripts/lf_rvr_test.py
@@ -124,7 +124,7 @@ class RvrTest(cvtest):
lf_host="localhost",
lf_port=8080,
ssh_port=22,
- local_path="",
+ local_lf_report_dir="",
graph_groups=None,
lf_user="lanforge",
lf_password="lanforge",
@@ -167,8 +167,8 @@ class RvrTest(cvtest):
self.raw_lines_file = raw_lines_file
self.sets = sets
self.ssh_port = ssh_port
- self.local_path = local_path
self.graph_groups = graph_groups
+ self.local_lf_report_dir = local_lf_report_dir
def setup(self):
# Nothing to do at this time.
@@ -212,7 +212,7 @@ class RvrTest(cvtest):
self.create_and_run_test(self.load_old_cfg, self.test_name, self.instance_name,
self.config_name, self.sets,
self.pull_report, self.lf_host, self.lf_user, self.lf_password,
- cv_cmds, ssh_port=self.ssh_port, local_lf_report_dir=self.local_path,
+ cv_cmds, ssh_port=self.ssh_port, local_lf_report_dir=self.local_lf_report_dir,
graph_groups_file=self.graph_groups)
self.rm_text_blob(self.config_name, blob_test) # To delete old config with same name
@@ -226,6 +226,39 @@ def main():
Example:
+ ./lf_rvr_test.py --mgr localhost --port 8080 --lf_user lanforge --lf_password lanforge \\
+ --instance_name rvr-instance --config_name test_con --upstream 1.1.eth1 \\
+ --dut RootAP --duration 15s --station 1.1.wlan0 \\
+ --download_speed 85% --upload_speed 56Kbps \\
+ --raw_line 'pkts: MTU' \\
+ --raw_line 'directions: DUT Transmit' \\
+ --raw_line 'traffic_types: TCP' \\
+ --test_rig Ferndale-Mesh-01 --pull_report \\
+ --raw_line 'attenuator: 1.1.1040' \\
+ --raw_line 'attenuations: 0..+50..950' \\
+ --raw_line 'attenuator_mod: 3' \\
+ --influx_host c7-graphana --influx_port 8086 --influx_org Candela \\
+ --influx_token=-u_Wd-L8o992701QF0c5UmqEp7w7Z7YOMaWLxOMgmHfATJGnQbbmYyNxHBR9PgD6taM_tcxqJl6U8DjU1xINFQ== \\
+ --influx_bucket ben \\
+ --influx_tag testbed Ferndale-Mesh
+
+ ./lf_rvr_test.py --mgr localhost --port 8080 --lf_user lanforge --lf_password lanforge \\
+ --instance_name rvr-instance --config_name test_con --upstream 1.1.eth1 \\
+ --dut RootAP --duration 15s --station 1.1.wlan0 \\
+ --download_speed 85% --upload_speed 56Kbps \\
+ --raw_line 'pkts: MTU' \\
+ --raw_line 'directions: DUT Transmit' \\
+ --raw_line 'traffic_types: TCP' \\
+ --test_rig Ferndale-Mesh-01 --pull_report \\
+ --raw_line 'attenuator: 1.1.1040' \\
+ --raw_line 'attenuations: 0..+50..950' \\
+ --raw_line 'attenuator_mod: 3' \\
+ --pull_report \\
+ --local_lf_report_dir /tmp/rvr-report \\
+ --raw_line 'notes0: my rvr notes' \\
+ --raw_line 'notes1: are here.' \\
+ --raw_line 'rvr_bringup_wait: 30000' \\
+ --raw_line 'first_byte_wait: 30000'
"""
)
@@ -240,13 +273,14 @@ def main():
parser.add_argument("--dut", default="",
help="Specify DUT used by this test, example: linksys-8450")
parser.add_argument("--download_speed", default="",
- help="Specify requested download speed. Percentage of theoretical is also supported. Default: 85%")
+ help="Specify requested download speed. Percentage of theoretical is also supported. Default: 85")
parser.add_argument("--upload_speed", default="",
help="Specify requested upload speed. Percentage of theoretical is also supported. Default: 0")
parser.add_argument("--duration", default="",
help="Specify duration of each traffic run")
parser.add_argument("--graph_groups", help="File to save graph_groups to", default=None)
parser.add_argument("--report_dir", default="")
+ parser.add_argument("--local_lf_report_dir", help="--local_lf_report_dir default '' put where dataplane script run from",default="")
args = parser.parse_args()
@@ -260,6 +294,7 @@ def main():
config_name=args.config_name,
upstream=args.upstream,
pull_report=args.pull_report,
+ local_lf_report_dir = args.local_lf_report_dir,
load_old_cfg=args.load_old_cfg,
download_speed=args.download_speed,
upload_speed=args.upload_speed,
diff --git a/py-scripts/lf_rx_sensitivity_test.py b/py-scripts/lf_rx_sensitivity_test.py
old mode 100644
new mode 100755
diff --git a/py-scripts/lf_snp_test.py b/py-scripts/lf_snp_test.py
index d5a54f8f..05c183c1 100755
--- a/py-scripts/lf_snp_test.py
+++ b/py-scripts/lf_snp_test.py
@@ -1,41 +1,41 @@
#!/usr/bin/env python3
-'''
+"""
NAME: lf_snp_test.py snp == Scaling and Performance
-PURPOSE:
+PURPOSE:
-This program is to test an AP connected to a controller.
+This program is to test an AP connected to a controller.
The AP name is configurable.
- The controler
- with with a specific ap mode, wifi mode (2.4 Ghz or 5 Ghz), Bandwidth (20,40,80,160) and TX power.
-The controller will configure the AP.
-The Lanforge radios are configured for a specific client dencity, Packet type (TCP, UDP), Direction (download, upload) and Packet-size.
+ The controler
+ with with a specific ap mode, wifi mode (2.4 Ghz or 5 Ghz), Bandwidth (20,40,80,160) and TX power.
+The controller will configure the AP.
+The Lanforge radios are configured for a specific client dencity, Packet type (TCP, UDP), Direction (download, upload) and Packet-size.
The transmission rate will be recorded and compared against the expected rate to determine pass or fail.
The results will be recorded in CSV file with the following data
AP, Band, wifi_mode, Bandwidth, encryption, ap mode, number of clients, packet type, direction, packet size, measured rx bytes, upload bits per second,
-download bits per second.
+download bits per second.
unique test id, pass / fail, epoch time, and time.
TECHNICAL UNDERSTANDING:
LANForge Monitored Values Per Polling Interval
'rx bytes' - bytes transmitted
- 'rx rate' - bits per second
+ 'rx rate' - bits per second
- in DL direction: -B tx -> -A rx, (side_b_tx_min_bps) LANforge Eth endpoint transmits bytes (AP/DUT),
+ in DL direction: -B tx -> -A rx, (side_b_tx_min_bps) LANforge Eth endpoint transmits bytes (AP/DUT),
station endpoint (Wifi) LANForge receives them. station-end-rx-bps (bits per second) is download rx-bps (bits per second)
- in UL direction: -A tx -> -B rx, (side_a_tx_min_bps) LANforge Eth endpoint receives bytes (AP/DUT),
+ in UL direction: -A tx -> -B rx, (side_a_tx_min_bps) LANforge Eth endpoint receives bytes (AP/DUT),
station endpoint (Wifi) LANForge transmits them. ethernet-end-rx-bps (bits per second) is upload load rx-bps (bits per second)
configured bps (side_a_tx_min_bps and side_b_tx_min_bps) if lists not same lenght shorter list padded out with 256000 if upload and download selected.
NOTES:
1. The controller_client_densities are indpendent of the number of stations on a radio
- 2. The --side_a_tx_min_bps (download) and --side_b_tx_min_bps (upload) is used to set the rate
- a. default 256000
+ 2. The --side_a_tx_min_bps (download) and --side_b_tx_min_bps (upload) is used to set the rate
+ a. default 256000
The script is devided into parts:
-1. Controller Class : CreateCtlr controller interface.
+1. Controller Class : CreateCtlr controller interface.
Configurable by script:
a. Band : a (5ghz) b (2.4ghz)
b. wifi_mode : supported modes based on radio
@@ -47,13 +47,13 @@ The script is devided into parts:
g. packet_type: lf_udp lf_tcp
h. traffic direction: upload / download
i. pdu: --side_a_min_pdu, --side_b_min_pdu Note: LANforge configuration
-
+
2. Traffic Generation Class : L3VariableTime
a. Creates and brings up stations/clients on radios
b. Measures connections
c. reports results
-3. Scaling And Performance Main
+3. Scaling And Performance Main
a. Command parcing
b. Fixed Configuration Coded Into The Script
c. Script Controller Configurations
@@ -66,51 +66,51 @@ OUTPUT:
html results , default .html
pdf results , default .pdf
csv results_snp_.csv , results reflected in html and pdf files
- csv details_snp_.csv raw data
+ csv details_snp_.csv raw data
* radios and con
-EXAMPLE:
+EXAMPLE:
Use --print_test_config at end of command to see test configuration
Test configurations take presidence to command line parameters
Using Coded Test Configuration --controller_test_1
- ./lf_snp_test.py --controller_ip 10.195.197.234 --controller_user admin --controller_passwd Milpitas@123
+ ./lf_snp_test.py --controller_ip 10.195.197.234 --controller_user admin --controller_passwd Milpitas@123
--controller_aps 'Vanc-e' --controller_series "9800" --endp_types 'lf_udp' --upstream_port eth2 --controller_prompt "Can-SnP-9120" --controller_test_1
--print_test_config
Using Coded Test Configuration --controller_test_1
- ./lf_snp_test.py --controller_ip 10.195.197.234 --controller_user admin --controller_passwd Milpitas@123
+ ./lf_snp_test.py --controller_ip 10.195.197.234 --controller_user admin --controller_passwd Milpitas@123
--controller_aps 'Vanc-e' --controller_series "9800" --endp_types 'lf_udp' --upstream_port eth2 --controller_prompt "Can-SnP-9120" --controller_test_1
--print_test_config
Using Coded Test Configuration:
- ./lf_snp_test.py -cc 192.168.100.112 -cu admin -cpw Cisco123 -cca APA453.0E7B.CF9C -cs "3504" --endp_types 'lf_udp' --upstream_port eth2 --controller_test_3
- --controller_prompt "(Cisco Controller)"
+ ./lf_snp_test.py -cc 192.168.100.112 -cu admin -cpw Cisco123 -cca APA453.0E7B.CF9C -cs "3504" --endp_types 'lf_udp' --upstream_port eth2 --controller_test_3
+ --controller_prompt "(Cisco Controller)"
--print_test_config
Using Commandline with defaults:
- ./lf_snp_test.py --controller_ip 192.168.100.112 --controller_user admin --controller_passwd Cisco123 --controller_aps APA453.0E7B.CF9C --controller_series "3504"
- --controller_prompt "(Cisco Controller)" --radio "radio==1.wiphy0 stations==1 ssid==test_candela ssid_pw==[BLANK] security==open wifimode==auto"
+ ./lf_snp_test.py --controller_ip 192.168.100.112 --controller_user admin --controller_passwd Cisco123 --controller_aps APA453.0E7B.CF9C --controller_series "3504"
+ --controller_prompt "(Cisco Controller)" --radio "radio==1.wiphy0 stations==1 ssid==test_candela ssid_pw==[BLANK] security==open wifimode==auto"
--print_test_config
Using Commandline:
- ./lf_snp_test.py --controller_ip 192.168.100.112 --controller_user admin --controller_passwd Cisco123 --controller_aps APA453.0E7B.CF9C
- --controller_series "3504" --upstream_port eth2 --controller_prompt "(Cisco Controller)" --controller_wifimode "a" --controller_chan_5ghz "36"
- --radio "radio==1.wiphy0 stations==10 ssid==test_candela ssid_pw==[BLANK] security==open wifimode==ac" --controller_client_densities "10"
+ ./lf_snp_test.py --controller_ip 192.168.100.112 --controller_user admin --controller_passwd Cisco123 --controller_aps APA453.0E7B.CF9C
+ --controller_series "3504" --upstream_port eth2 --controller_prompt "(Cisco Controller)" --controller_wifimode "a" --controller_chan_5ghz "36"
+ --radio "radio==1.wiphy0 stations==10 ssid==test_candela ssid_pw==[BLANK] security==open wifimode==ac" --controller_client_densities "10"
--print_test_config
Using Commandline: Setting --test_duration "20s" --polling_interval to 5s -ccd "2" (--controller_client_densities)
- ./lf_snp_test.py --controller_ip 192.168.100.112 --controller_user admin --controller_passwd Cisco123 --controller_aps APA453.0E7B.CF9C
- --controller_series "3504" --upstream_port eth2 --controller_prompt "(Cisco Controller)" --controller_wifimode "auto" --controller_chan_5ghz "36"
- --radio "radio==1.wiphy0 stations==2 ssid==test_candela ssid_pw==[BLANK] security==open wifimode==an" --controller_client_densities "2"
+ ./lf_snp_test.py --controller_ip 192.168.100.112 --controller_user admin --controller_passwd Cisco123 --controller_aps APA453.0E7B.CF9C
+ --controller_series "3504" --upstream_port eth2 --controller_prompt "(Cisco Controller)" --controller_wifimode "auto" --controller_chan_5ghz "36"
+ --radio "radio==1.wiphy0 stations==2 ssid==test_candela ssid_pw==[BLANK] security==open wifimode==an" --controller_client_densities "2"
--print_test_config
SAMPLE TEST CONFIG: --controller_test_1 output from --print_test_config option
2021-04-21 05:43:25,040 __main__ INFO: USING: controller_test_1
-2021-04-21 05:43:25,040 __main__ INFO: TEST CONFIG:
+2021-04-21 05:43:25,040 __main__ INFO: TEST CONFIG:
2021-04-21 05:43:25,040 __main__ INFO: controller_aps ('-cca' ,'--controller_aps'): ['vanc-e']
2021-04-21 05:43:25,040 __main__ INFO: controller_bands ('-ccf' ,'--controller_bands'): ['a', 'b']
2021-04-21 05:43:25,040 __main__ INFO: controller_wifimodes ('-cwm' ,'--controller_wifimodes'): ['an', 'anAX', 'anAC', 'abgn', 'bg']
@@ -136,7 +136,7 @@ COPYWRITE
Copyright 2021 Candela Technologies Inc
License: Free to distribute and modify. LANforge systems must be licensed.
-'''
+"""
import sys
import os
import importlib
@@ -154,57 +154,62 @@ if sys.version_info[0] != 3:
print("This script requires Python 3")
exit(1)
-
+from lf_report import lf_report
+
sys.path.append(os.path.join(os.path.abspath(__file__ + "../../../")))
LFUtils = importlib.import_module("py-json.LANforge.LFUtils")
realm = importlib.import_module("py-json.realm")
Realm = realm.Realm
-lf_report = importlib.import_module("py-scripts.lf_report")
# lf_graph = importlib.import_module("py-scripts.lf_graph")
# lf_bar_graph = lf_graph.lf_bar_graph
FORMAT = '%(asctime)s %(name)s %(levelname)s: %(message)s'
+
+
# see https://stackoverflow.com/a/13306095/11014343
class FileAdapter(object):
def __init__(self, logger):
self.logger = logger
+
def write(self, data):
# NOTE: data can be a partial line, multiple lines
- data = data.strip() # ignore leading/trailing whitespace
- if data: # non-blank
- self.logger.info(data)
+ data = data.strip() # ignore leading/trailing whitespace
+ if data: # non-blank
+ self.logger.info(data)
+
def flush(self):
pass # leave it to logging to flush properly
+
################################################################################
#
# Controller Class : CrateCtlr controller interface
#
################################################################################
-class CreateCtlr():
+class CreateCtlr:
def __init__(self,
- _scheme,
- _port,
- _series,
- _ctlr,
- _prompt,
- _user,
- _passwd,
- _ap,
- _band,
- _chan_5ghz,
- _chan_24ghz,
- _chan_width,
- _ap_mode,
- _tx_power,
- _wlan,
- _cap_ctl_out):
+ _scheme,
+ _port,
+ _series,
+ _ctlr,
+ _prompt,
+ _user,
+ _passwd,
+ _ap,
+ _band,
+ _chan_5ghz,
+ _chan_24ghz,
+ _chan_width,
+ _ap_mode,
+ _tx_power,
+ _wlan,
+ _cap_ctl_out):
self.scheme = _scheme
- self.port = _port
+ self.port = _port
self.series = _series
self.ctlr = _ctlr
self.prompt = _prompt
@@ -221,8 +226,8 @@ class CreateCtlr():
self.cap_ctl_out = _cap_ctl_out
self.client_density = 0
- #show summary (to get AP) (3400/9800)
- #./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 --action summary --series 9800 --log stdout
+ # show summary (to get AP) (3400/9800)
+ # ./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 --action summary --series 9800 --log stdout
def controller_show_summary(self):
pss = ""
try:
@@ -237,553 +242,670 @@ class CreateCtlr():
series: {} \
band: {} \
action: {}".format(
- self.scheme,
- self.ctlr,
- self.port,
- self.prompt,
- self.user,
- self.passwd,
- self.ap,
- self.series,
- self.band,
- "summary"))
+ self.scheme,
+ self.ctlr,
+ self.port,
+ self.prompt,
+ self.user,
+ self.passwd,
+ self.ap,
+ self.series,
+ self.band,
+ "summary"))
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py",
- "--scheme", self.scheme,
- "--prompt", self.prompt,
- "--port", self.port,
- "-d", self.ctlr,
- "-u", self.user,
- "-p", self.passwd,
- "-a", self.ap,
- "--series", self.series,
- "--band", self.band,
- "--action", "summary"],
- capture_output=self.cap_ctl_out,
+ ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py",
+ "--scheme", self.scheme,
+ "--prompt", self.prompt,
+ "--port", self.port,
+ "-d", self.ctlr,
+ "-u", self.user,
+ "-p", self.passwd,
+ "-a", self.ap,
+ "--series", self.series,
+ "--band", self.band,
+ "--action", "summary"],
+ capture_output=self.cap_ctl_out,
check=True)
if self.cap_ctl_out:
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}"
- .format(process_error.returncode, process_error.output))
- time.sleep(1)
- exit(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
+ exit(1)
return pss
- #show ap dot11 5ghz summary (band defaults to 5ghz) --band a
- #show ap dot11 24ghz summary use --band b for 2.4 ghz
- #action advanced (3400/9800)
- #./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 --action advanced --series 9800 --log stdout
+ # show ap dot11 5ghz summary (band defaults to 5ghz) --band a
+ # show ap dot11 24ghz summary use --band b for 2.4 ghz
+ # action advanced (3400/9800)
+ # ./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 --action advanced --series 9800 --log stdout
def controller_show_ap_summary(self):
pss = ""
try:
logg.info("\
- scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(self.scheme,
- self.ctlr,self.port,self.prompt,self.user,
- self.passwd,self.ap,self.series,self.band,"advanced"))
+ scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(
+ self.scheme,
+ self.ctlr, self.port, self.prompt, self.user,
+ self.passwd, self.ap, self.series, self.band, "advanced"))
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d", self.ctlr, "-u",
- self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--band", self.band, "--action", "advanced"],
- capture_output=True, check=True)
+ ctl_output = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port,
+ "-d", self.ctlr, "-u",
+ self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--band", self.band, "--action", "advanced"],
+ capture_output=True, check=True)
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".
- format(process_error.returncode, process_error.output))
- time.sleep(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
exit(1)
return pss
- #show wlan summary
+ # show wlan summary
def controller_show_wlan_summary(self):
try:
- logg.info("scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(self.scheme,
- self.ctlr,self.port,self.prompt,self.user,
- self.passwd,self.ap,self.series,self.band,"show wlan summary"))
+ logg.info(
+ "scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(
+ self.scheme,
+ self.ctlr, self.port, self.prompt, self.user,
+ self.passwd, self.ap, self.series, self.band, "show wlan summary"))
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d", self.ctlr, "-u",
- self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--band", self.band, "--action", "show_wlan_summary"],
- capture_output=self.cap_ctl_out, check=True)
+ ctl_output = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port,
+ "-d", self.ctlr, "-u",
+ self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--band", self.band, "--action", "show_wlan_summary"],
+ capture_output=self.cap_ctl_out, check=True)
if self.cap_ctl_out:
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".
- format(process_error.returncode, process_error.output))
- time.sleep(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
exit(1)
- #disable AP
- #./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action disable --series 9800
+ # disable AP
+ # ./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action disable --series 9800
def controller_disable_ap(self):
try:
- logg.info("scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(self.scheme,
- self.ctlr,self.port,self.prompt,self.user,
- self.passwd,self.ap,self.series,self.band,"disable"))
+ logg.info(
+ "scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(
+ self.scheme,
+ self.ctlr, self.port, self.prompt, self.user,
+ self.passwd, self.ap, self.series, self.band, "disable"))
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d",
- self.ctlr, "-u",self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--band", self.band, "--action", "disable"],
- capture_output=self.cap_ctl_out, check=True)
+ ctl_output = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port,
+ "-d",
+ self.ctlr, "-u", self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--band", self.band, "--action", "disable"],
+ capture_output=self.cap_ctl_out, check=True)
if self.cap_ctl_out:
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".
- format(process_error.returncode, process_error.output))
- time.sleep(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
exit(1)
- #disable wlan
- #./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action disable_wlan --series 9800
+ # disable wlan
+ # ./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action disable_wlan --series 9800
def controller_disable_wlan(self):
try:
- logg.info("scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} wlan: {} action: {}".format(self.scheme,
- self.ctlr,self.port,self.prompt,self.user,
- self.passwd,self.ap,self.series,self.band,self.wlan,"disable_wlan"))
+ logg.info(
+ "scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} wlan: {} action: {}".format(
+ self.scheme,
+ self.ctlr, self.port, self.prompt, self.user,
+ self.passwd, self.ap, self.series, self.band, self.wlan, "disable_wlan"))
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d", self.ctlr, "-u",
- self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--band", self.band,"--wlan", self.wlan, "--action", "disable_wlan"],
- capture_output=self.cap_ctl_out, check=True)
+ ctl_output = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port,
+ "-d", self.ctlr, "-u",
+ self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--band", self.band, "--wlan", self.wlan, "--action",
+ "disable_wlan"],
+ capture_output=self.cap_ctl_out, check=True)
if self.cap_ctl_out:
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".
- format(process_error.returncode, process_error.output))
- time.sleep(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
exit(1)
- #disable network 5ghz
- #./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action disable_network_5ghz --series 9800
+ # disable network 5ghz
+ # ./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action disable_network_5ghz --series 9800
def controller_disable_network_5ghz(self):
if self.series == "9800":
try:
- logg.info("scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(self.scheme,
- self.ctlr,self.port,self.prompt,self.user,
- self.passwd,self.ap,self.series,self.band,"disable_network_5ghz"))
+ logg.info(
+ "scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(
+ self.scheme,
+ self.ctlr, self.port, self.prompt, self.user,
+ self.passwd, self.ap, self.series, self.band, "disable_network_5ghz"))
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d", self.ctlr, "-u",
- self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--band", self.band, "--action", "disable_network_5ghz"],
- capture_output=self.cap_ctl_out, check=True)
+ ctl_output = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port,
+ "-d", self.ctlr, "-u",
+ self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--band", self.band, "--action", "disable_network_5ghz"],
+ capture_output=self.cap_ctl_out, check=True)
if self.cap_ctl_out:
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".
- format(process_error.returncode, process_error.output))
- time.sleep(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
exit(1)
else:
try:
- logg.info("scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {} value: {}".format(self.scheme,
- self.ctlr,self.port,self.prompt,self.user,self.passwd, self.ap, self.series,
- self.band,"cmd","config 802.11a disable network"))
+ logg.info(
+ "scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {} value: {}".format(
+ self.scheme,
+ self.ctlr, self.port, self.prompt, self.user, self.passwd, self.ap, self.series,
+ self.band, "cmd", "config 802.11a disable network"))
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d", self.ctlr, "-u",
- self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--band", self.band, "--action", "cmd", "--value", "config 802.11a disable network"],
- capture_output=self.cap_ctl_out, check=True)
+ ctl_output = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port,
+ "-d", self.ctlr, "-u",
+ self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--band", self.band, "--action", "cmd", "--value",
+ "config 802.11a disable network"],
+ capture_output=self.cap_ctl_out, check=True)
if self.cap_ctl_out:
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".
- format(process_error.returncode, process_error.output))
- time.sleep(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
exit(1)
- #disable network 24ghz
- #./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action disable_network_24ghz --series 9800
+ # disable network 24ghz
+ # ./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action disable_network_24ghz --series 9800
def controller_disable_network_24ghz(self):
if self.series == "9800":
try:
- logg.info("scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(self.scheme,
- self.ctlr,self.port,self.prompt,self.user,
- self.passwd,self.ap,self.series,self.band,"disable_network_24ghz"))
+ logg.info(
+ "scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(
+ self.scheme,
+ self.ctlr, self.port, self.prompt, self.user,
+ self.passwd, self.ap, self.series, self.band, "disable_network_24ghz"))
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d", self.ctlr, "-u",
- self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--band", self.band, "--action", "disable_network_24ghz"],
- capture_output=self.cap_ctl_out, check=True)
+ ctl_output = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port,
+ "-d", self.ctlr, "-u",
+ self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--band", self.band, "--action", "disable_network_24ghz"],
+ capture_output=self.cap_ctl_out, check=True)
if self.cap_ctl_out:
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".
- format(process_error.returncode, process_error.output))
- time.sleep(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
exit(1)
else:
try:
- logg.info("scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {} value: {}".format(self.scheme,
- self.ctlr,self.port,self.prompt,self.user,self.passwd, self.ap, self.series,
- self.band,"cmd","config 802.11b disable network"))
+ logg.info(
+ "scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {} value: {}".format(
+ self.scheme,
+ self.ctlr, self.port, self.prompt, self.user, self.passwd, self.ap, self.series,
+ self.band, "cmd", "config 802.11b disable network"))
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d", self.ctlr, "-u",
- self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--band", self.band, "--action", "cmd", "--value", "config 802.11b disable network"],
- capture_output=self.cap_ctl_out, check=True)
+ ctl_output = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port,
+ "-d", self.ctlr, "-u",
+ self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--band", self.band, "--action", "cmd", "--value",
+ "config 802.11b disable network"],
+ capture_output=self.cap_ctl_out, check=True)
if self.cap_ctl_out:
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".
- format(process_error.returncode, process_error.output))
- time.sleep(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
exit(1)
- #set manual mode - Series 9800 must be set to manual mode
- #./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action manual --series 9800
+ # set manual mode - Series 9800 must be set to manual mode
+ # ./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action manual --series 9800
# ap name dot11 5ghz radio role manual client-serving
def controller_role_manual(self):
if self.series == "9800":
try:
- logg.info("scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(self.scheme,
- self.ctlr,self.port,self.prompt,self.user,
- self.passwd,self.ap,self.series,self.band,"manual"))
+ logg.info(
+ "scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(
+ self.scheme,
+ self.ctlr, self.port, self.prompt, self.user,
+ self.passwd, self.ap, self.series, self.band, "manual"))
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d", self.ctlr, "-u",
- self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--band", self.band, "--action", "manual"],
- capture_output=self.cap_ctl_out, check=True)
+ ctl_output = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port,
+ "-d", self.ctlr, "-u",
+ self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--band", self.band, "--action", "manual"],
+ capture_output=self.cap_ctl_out, check=True)
if self.cap_ctl_out:
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".
- format(process_error.returncode, process_error.output))
- time.sleep(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
exit(1)
else:
- logg.info("Check the controller scheme used attemping 9800 series on 3504 controller: {}".format(self.scheme))
+ logg.info(
+ "Check the controller scheme used attemping 9800 series on 3504 controller: {}".format(self.scheme))
- #set manual mode - Series 9800 must be set to auto mode
- #./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action auto --series 9800
+ # set manual mode - Series 9800 must be set to auto mode
+ # ./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action auto --series 9800
# ap name dot11 5ghz radio role manual client-serving
def controller_role_auto(self):
if self.series == "9800":
try:
- logg.info("scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(self.scheme,
- self.ctlr,self.port,self.prompt,self.user,
- self.passwd,self.ap,self.series,self.band,"auto"))
+ logg.info(
+ "scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(
+ self.scheme,
+ self.ctlr, self.port, self.prompt, self.user,
+ self.passwd, self.ap, self.series, self.band, "auto"))
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d", self.ctlr, "-u",
- self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--band", self.band, "--action", "auto"],
- capture_output=self.cap_ctl_out, check=True)
+ ctl_output = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port,
+ "-d", self.ctlr, "-u",
+ self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--band", self.band, "--action", "auto"],
+ capture_output=self.cap_ctl_out, check=True)
if self.cap_ctl_out:
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".
- format(process_error.returncode, process_error.output))
- time.sleep(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
exit(1)
else:
- logg.info("Check the controller scheme used attemping 9800 series on 3504 controller: {}".format(self.scheme))
+ logg.info(
+ "Check the controller scheme used attemping 9800 series on 3504 controller: {}".format(self.scheme))
- #test parameters summary (txPower 1-8)
- #./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action txPower --value 5 --series 9800
+ # test parameters summary (txPower 1-8)
+ # ./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action txPower --value 5 --series 9800
def controller_set_tx_power(self):
try:
- logg.info("scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {} value {}".format(self.scheme,
- self.ctlr,self.port,self.prompt,self.user,self.passwd, self.ap, self.series,
- self.band,"txPower", self.tx_power )) # TODO fix txPower to tx_power in wifi_ctl_9800_3504.py
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d", self.ctlr, "-u",
- self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--band", self.band,
- "--action", "txPower","--value", self.tx_power],
- capture_output=self.cap_ctl_out, check=True)
+ logg.info(
+ "scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {} value {}".format(
+ self.scheme,
+ self.ctlr, self.port, self.prompt, self.user, self.passwd, self.ap, self.series,
+ self.band, "txPower", self.tx_power)) # TODO fix txPower to tx_power in wifi_ctl_9800_3504.py
+ ctl_output = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port,
+ "-d", self.ctlr, "-u",
+ self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--band", self.band,
+ "--action", "txPower", "--value", self.tx_power],
+ capture_output=self.cap_ctl_out, check=True)
if self.cap_ctl_out:
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".
- format(process_error.returncode, process_error.output))
- time.sleep(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
exit(1)
- #set channel [36, 64, 100]
- #./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action channel --value 36 --series 9800
+ # set channel [36, 64, 100]
+ # ./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action channel --value 36 --series 9800
# 9800 : ap name dot11 [5ghz | 24ghz] channel
# 3504 : (controller Controller) >config 802.11a channel ap APA453.0E7B.CF9C 52
def controller_set_channel(self):
try:
- if (self.band == "a"):
+ if self.band == "a":
controller_channel = self.chan_5ghz
else:
controller_channel = self.chan_24ghz
- logg.info("scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {} value {}".format(self.scheme,
- self.ctlr,self.port,self.prompt,self.user,self.passwd, self.ap, self.series,
- self.band,"channel", controller_channel ))
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d", self.ctlr, "-u",
- self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--band", self.band,
- "--action", "channel","--value", controller_channel],
- capture_output=self.cap_ctl_out, check=True)
+ logg.info(
+ "scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {} value {}".format(
+ self.scheme,
+ self.ctlr, self.port, self.prompt, self.user, self.passwd, self.ap, self.series,
+ self.band, "channel", controller_channel))
+ ctl_output = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port,
+ "-d", self.ctlr, "-u",
+ self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--band", self.band,
+ "--action", "channel", "--value", controller_channel],
+ capture_output=self.cap_ctl_out, check=True)
if self.cap_ctl_out:
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".
- format(process_error.returncode, process_error.output))
- time.sleep(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
exit(1)
- #set bandwidth [20 40 80 160]
- #./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action bandwidth --value 40 --series 9800
+ # set bandwidth [20 40 80 160]
+ # ./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action bandwidth --value 40 --series 9800
def controller_set_bandwidth(self):
try:
- logg.info("scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {} value {}".format(self.scheme,
- self.ctlr,self.port,self.prompt,self.user,self.passwd, self.ap, self.series,
- self.band,"channel", self.chan_width ))
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d", self.ctlr, "-u",
- self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--band", self.band,
- "--action", "channel","--value", self.chan_width],
- capture_output=self.cap_ctl_out, check=True)
+ logg.info(
+ "scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {} value {}".format(
+ self.scheme,
+ self.ctlr, self.port, self.prompt, self.user, self.passwd, self.ap, self.series,
+ self.band, "channel", self.chan_width))
+ ctl_output = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port,
+ "-d", self.ctlr, "-u",
+ self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--band", self.band,
+ "--action", "channel", "--value", self.chan_width],
+ capture_output=self.cap_ctl_out, check=True)
if self.cap_ctl_out:
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
-
+
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".
- format(process_error.returncode, process_error.output))
- time.sleep(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
exit(1)
- #create wlan
- #./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action create_wlan --wlan "open-wlan" --wlanID 1 --series 9800
+ # create wlan
+ # ./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action create_wlan --wlan "open-wlan" --wlanID 1 --series 9800
def controller_create_wlan(self):
if self.series == "9800":
try:
- logg.info("scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {} wlan {} wlanID {} wlanSSID {}".format(self.scheme,
- self.ctlr,self.port,self.prompt,self.user,self.passwd, self.ap, self.series,
- self.band,"create_wlan", self.wlan, self.wlanID, self.wlanSSID ))
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d", self.ctlr, "-u",
- self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--band", self.band,
- "--action", "create_wlan","--wlan", self.wlan, "--wlanID", self.wlanID, "--wlanSSID", self.wlanSSID],
- capture_output=self.cap_ctl_out, check=True)
+ logg.info(
+ "scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {} wlan {} wlanID {} wlanSSID {}".format(
+ self.scheme,
+ self.ctlr, self.port, self.prompt, self.user, self.passwd, self.ap, self.series,
+ self.band, "create_wlan", self.wlan, self.wlanID, self.wlanSSID))
+ ctl_output = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port,
+ "-d", self.ctlr, "-u",
+ self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--band", self.band,
+ "--action", "create_wlan", "--wlan", self.wlan, "--wlanID", self.wlanID, "--wlanSSID",
+ self.wlanSSID],
+ capture_output=self.cap_ctl_out, check=True)
if self.cap_ctl_out:
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
-
+
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".
- format(process_error.returncode, process_error.output))
- time.sleep(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
exit(1)
else:
- logg.info("Check the controller_scheme used attemping 9800 series on 3504 controller: {}".format(self.scheme))
+ logg.info(
+ "Check the controller_scheme used attemping 9800 series on 3504 controller: {}".format(self.scheme))
- #create wireless tag policy --9800 series needs to have wireless tag policy set
- #./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action wireless_tag_policy --series 9800
+ # create wireless tag policy --9800 series needs to have wireless tag policy set
+ # ./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action wireless_tag_policy --series 9800
def controller_set_wireless_tag_policy(self):
if self.series == "9800":
try:
- logg.info("scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(self.scheme,
- self.ctlr,self.port,self.prompt,self.user,self.passwd, self.ap, self.series,
- self.band,"wireless_tag_policy" ))
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d", self.ctlr, "-u",
- self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--band", self.band,
- "--action", "wireless_tag_policy"],
- capture_output=self.cap_ctl_out, check=True)
+ logg.info(
+ "scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(
+ self.scheme,
+ self.ctlr, self.port, self.prompt, self.user, self.passwd, self.ap, self.series,
+ self.band, "wireless_tag_policy"))
+ ctl_output = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port,
+ "-d", self.ctlr, "-u",
+ self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--band", self.band,
+ "--action", "wireless_tag_policy"],
+ capture_output=self.cap_ctl_out, check=True)
if self.cap_ctl_out:
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".
- format(process_error.returncode, process_error.output))
- time.sleep(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
exit(1)
else:
- logg.info("Check the controller_scheme used attemping 9800 series on 3504 controller: {}".format(self.scheme))
+ logg.info(
+ "Check the controller_scheme used attemping 9800 series on 3504 controller: {}".format(self.scheme))
- #enable wlan
- #./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action enable_wlan --series 9800
+ # enable wlan
+ # ./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action enable_wlan --series 9800
def controller_enable_wlan(self):
try:
- logg.info("scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} wlan: {} action: {}".format(self.scheme,
- self.ctlr,self.port,self.prompt,self.user,self.passwd, self.ap, self.series,
- self.band, self.wlan,"enable_wlan"))
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d", self.ctlr, "-u",
- self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--band", self.band, "--wlan", self.wlan,
- "--action", "enable_wlan"],
- capture_output=self.cap_ctl_out, check=True)
+ logg.info(
+ "scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} wlan: {} action: {}".format(
+ self.scheme,
+ self.ctlr, self.port, self.prompt, self.user, self.passwd, self.ap, self.series,
+ self.band, self.wlan, "enable_wlan"))
+ ctl_output = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port,
+ "-d", self.ctlr, "-u",
+ self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--band", self.band, "--wlan", self.wlan,
+ "--action", "enable_wlan"],
+ capture_output=self.cap_ctl_out, check=True)
if self.cap_ctl_out:
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
-
+
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".
- format(process_error.returncode, process_error.output))
- time.sleep(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
exit(1)
- #enable 5ghz
- #./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action enable_network_5ghz --series 9800
+ # enable 5ghz
+ # ./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action enable_network_5ghz --series 9800
def controller_enable_network_5ghz(self):
if self.series == "9800":
try:
- logg.info("scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(self.scheme,
- self.ctlr,self.port,self.prompt,self.user,self.passwd, self.ap, self.series,
- self.band,"enable_network_5ghz"))
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d", self.ctlr, "-u",
- self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--band", self.band,
- "--action", "enable_network_5ghz"],
- capture_output=self.cap_ctl_out, check=True)
+ logg.info(
+ "scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(
+ self.scheme,
+ self.ctlr, self.port, self.prompt, self.user, self.passwd, self.ap, self.series,
+ self.band, "enable_network_5ghz"))
+ ctl_output = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port,
+ "-d", self.ctlr, "-u",
+ self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--band", self.band,
+ "--action", "enable_network_5ghz"],
+ capture_output=self.cap_ctl_out, check=True)
if self.cap_ctl_out:
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
-
+
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".
- format(process_error.returncode, process_error.output))
- time.sleep(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
exit(1)
else:
try:
- logg.info("scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {} value: {}".format(self.scheme,
- self.ctlr,self.port,self.prompt,self.user,self.passwd, self.ap, self.series,
- self.band,"cmd","config 802.11a enable network"))
+ logg.info(
+ "scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {} value: {}".format(
+ self.scheme,
+ self.ctlr, self.port, self.prompt, self.user, self.passwd, self.ap, self.series,
+ self.band, "cmd", "config 802.11a enable network"))
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d", self.ctlr, "-u",
- self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--band", self.band, "--action", "cmd", "--value", "config 802.11a enable network"],
- capture_output=self.cap_ctl_out, check=True)
+ ctl_output = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port,
+ "-d", self.ctlr, "-u",
+ self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--band", self.band, "--action", "cmd", "--value",
+ "config 802.11a enable network"],
+ capture_output=self.cap_ctl_out, check=True)
if self.cap_ctl_out:
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".
- format(process_error.returncode, process_error.output))
- time.sleep(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
exit(1)
- #enable 24ghz
- #./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action enable_network_24ghz --series 9800
+ # enable 24ghz
+ # ./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action enable_network_24ghz --series 9800
def controller_enable_network_24ghz(self):
if self.series == "9800":
try:
- logg.info("scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(self.scheme,
- self.ctlr,self.port,self.prompt,self.user,self.passwd, self.ap, self.series,
- self.band,"enable_network_24ghz"))
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d", self.ctlr, "-u",
- self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--band", self.band,
- "--action", "enable_network_24ghz"],
- capture_output=self.cap_ctl_out, check=True)
+ logg.info(
+ "scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(
+ self.scheme,
+ self.ctlr, self.port, self.prompt, self.user, self.passwd, self.ap, self.series,
+ self.band, "enable_network_24ghz"))
+ ctl_output = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port,
+ "-d", self.ctlr, "-u",
+ self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--band", self.band,
+ "--action", "enable_network_24ghz"],
+ capture_output=self.cap_ctl_out, check=True)
if self.cap_ctl_out:
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".
- format(process_error.returncode, process_error.output))
- time.sleep(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
exit(1)
else:
try:
- logg.info("scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {} value: {}".format(self.scheme,
- self.ctlr,self.port,self.prompt,self.user,self.passwd, self.ap, self.series,
- self.band,"cmd","config 802.11b enable network"))
+ logg.info(
+ "scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {} value: {}".format(
+ self.scheme,
+ self.ctlr, self.port, self.prompt, self.user, self.passwd, self.ap, self.series,
+ self.band, "cmd", "config 802.11b enable network"))
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d", self.ctlr, "-u",
- self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--band", self.band, "--action", "cmd", "--value", "config 802.11b enable network"],
- capture_output=self.cap_ctl_out, check=True)
+ ctl_output = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port,
+ "-d", self.ctlr, "-u",
+ self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--band", self.band, "--action", "cmd", "--value",
+ "config 802.11b enable network"],
+ capture_output=self.cap_ctl_out, check=True)
if self.cap_ctl_out:
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".
- format(process_error.returncode, process_error.output))
- time.sleep(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
exit(1)
- #enable (band a)
- #./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action enable --series 9800
+ # enable (band a)
+ # ./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action enable --series 9800
def controller_enable_ap(self):
try:
- logg.info("scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(self.scheme,
- self.ctlr,self.port,self.prompt,self.user,self.passwd, self.ap, self.series,
- self.band,"enable"))
- ctl_output = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d", self.ctlr, "-u",
- self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--band", self.band,
- "--action", "enable"],
- capture_output=self.cap_ctl_out, check=True)
+ logg.info(
+ "scheme: {} ctlr: {} port: {} prompt: {} user: {} passwd: {} AP: {} series: {} band: {} action: {}".format(
+ self.scheme,
+ self.ctlr, self.port, self.prompt, self.user, self.passwd, self.ap, self.series,
+ self.band, "enable"))
+ ctl_output = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port,
+ "-d", self.ctlr, "-u",
+ self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--band", self.band,
+ "--action", "enable"],
+ capture_output=self.cap_ctl_out, check=True)
if self.cap_ctl_out:
pss = ctl_output.stdout.decode('utf-8', 'ignore')
logg.info(pss)
except subprocess.CalledProcessError as process_error:
- logg.info("Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".
- format(process_error.returncode, process_error.output))
- time.sleep(1)
+ logg.info(
+ "Command Error, Controller unable to commicate to AP or unable to communicate to controller error code: {} output {}".format(
+ process_error.returncode, process_error.output))
+ time.sleep(1)
exit(1)
- #advanced (showes summary)
- #./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action advanced --series 9800
+ # advanced (showes summary)
+ # ./wifi_ctl_9800_3504.py --scheme ssh -d 172.19.36.168 -p --port 23 -a "9120-Chamber-1" --band a --action advanced --series 9800
def controller_show_ap_channel(self):
- advanced = subprocess.run(["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d", self.ctlr, "-u",
- self.user, "-p", self.passwd,
- "-a", self.ap,"--series", self.series, "--action", "ap_channel"], capture_output=True)
+ advanced = subprocess.run(
+ ["../wifi_ctl_9800_3504.py", "--scheme", self.scheme, "--prompt", self.prompt, "--port", self.port, "-d",
+ self.ctlr, "-u",
+ self.user, "-p", self.passwd,
+ "-a", self.ap, "--series", self.series, "--action", "ap_channel"], capture_output=True)
pss = advanced.stdout.decode('utf-8', 'ignore')
logg.info(pss)
if self.series == "9800":
- if (self.band == "a"):
+ if self.band == "a":
controller_channel = self.chan_5ghz
else:
controller_channel = self.chan_24ghz
@@ -793,44 +915,55 @@ class CreateCtlr():
logg.info("line {}".format(line))
element_list = line.lstrip().split()
logg.info("element_list {}".format(element_list))
- if (line.lstrip().startswith(search_str)):
+ if line.lstrip().startswith(search_str):
logg.info("line {}".format(line))
element_list = line.lstrip().split()
logg.info("element_list {}".format(element_list))
# AP Name (0) mac (1) slot (2) Admin State [enable/disable] (3) Oper State [Up/Down] (4) Width (5) Txpwr (6,7) channel (8) mode (9)
- logg.info("ap: {} slof {} channel {} chan_width {}".format(element_list[0],element_list[2],element_list[8],element_list[5]))
- if (str(controller_channel) in str(element_list[8])) and (str(self.chan_width) in str(element_list[5])):
- logg.info("ap {} configuration successful: channel {} in expected {} chan_width {} in expected {}"
- .format(element_list[0],controller_channel,element_list[8],self.chan_width,element_list[5]))
+ logg.info("ap: {} slof {} channel {} chan_width {}".format(element_list[0], element_list[2],
+ element_list[8], element_list[5]))
+ if (str(controller_channel) in str(element_list[8])) and (
+ str(self.chan_width) in str(element_list[5])):
+ logg.info(
+ "ap {} configuration successful: channel {} in expected {} chan_width {} in expected {}".format(
+ element_list[0],
+ controller_channel,
+ element_list[8],
+ self.chan_width,
+ element_list[5]))
else:
logg.info("WARNING ap {} configuration: channel {} in expected {} chan_width {} in expected {}"
- .format(element_list[0],controller_channel,element_list[8],self.chan_width,element_list[5]))
+ .format(element_list[0], controller_channel, element_list[8], self.chan_width,
+ element_list[5]))
break
else:
logg.info("checking for 802.11{}".format(self.band))
- if (self.band == "a"):
+ if self.band == "a":
controller_channel = self.chan_5ghz
else:
controller_channel = self.chan_24ghz
for line in pss.splitlines():
- #logg.info("line {}".format(line))
+ # logg.info("line {}".format(line))
search_str = "802.11{}".format(self.band)
- if (line.lstrip().startswith(search_str)):
+ if line.lstrip().startswith(search_str):
logg.info("line {}".format(line))
element_list = line.lstrip().split()
logg.info("element_list {}".format(element_list))
- logg.info("ap: {} channel {} chan_width {}".format(self.ap,element_list[4],element_list[5]))
- if (str(controller_channel) in str(element_list[4])) and (str(self.chan_width) in str(element_list[5])):
+ logg.info("ap: {} channel {} chan_width {}".format(self.ap, element_list[4], element_list[5]))
+ if (str(controller_channel) in str(element_list[4])) and (
+ str(self.chan_width) in str(element_list[5])):
logg.info("ap configuration successful: channel {} in expected {} chan_width {} in expected {}"
- .format(controller_channel,element_list[4],self.chan_width,element_list[5]))
+ .format(controller_channel, element_list[4], self.chan_width, element_list[5]))
else:
logg.info("AP WARNING: channel {} expected {} chan_width {} expected {}"
- .format(element_list[4],controller_channel,element_list[5],self.chan_width))
+ .format(element_list[4], controller_channel, element_list[5], self.chan_width))
break
-
- logg.info("configure ap {} channel {} chan_width {}".format(self.ap,self.channel,self.chan_width))
+
+ logg.info("configure ap {} channel {} chan_width {}".format(self.ap, self.channel, self.chan_width))
# Verify channel and channel width.
+
+
################################################################################
#
# End of Controller Class : controller interface
@@ -843,65 +976,65 @@ class CreateCtlr():
#
################################################################################
class L3VariableTime(Realm):
- def __init__(self,
- args,
- _scheme,
- _port,
- _series,
- _ctlr,
- _prompt,
- _user,
- _passwd,
- _ap,
- _ap_slot,
- _band,
- _chan_5ghz,
- _chan_24ghz,
- _chan_width,
- _ap_mode,
- _tx_power,
- _client_density,
- _cap_ctl_out,
- _ap_dict,
- endp_type,
- tos,
- side_b,
- radio_name_list,
- number_of_stations_per_radio_list,
- ssid_list,
- ssid_password_list,
- ssid_security_list,
- wifimode_list,
- station_lists,
- name_prefix,
- debug_on,
- outfile,
- results,
- test_keys,
- test_config,
- reset_port_enable_list,
- reset_port_time_min_list,
- reset_port_time_max_list,
- csv_started=False,
- side_a_tx_min_bps=560000,
- side_a_tx_max_bps=0, # setting to 0 will match min
- side_a_min_pdu=1518,
- side_a_max_pdu=0,
- side_b_tx_min_bps=560000,
- side_b_tx_max_bps=0, # setting to 0 will match min
- side_b_min_pdu=1518,
- side_b_max_pdu=0,
- number_template="00",
- test_duration="256s",
- polling_interval="60s",
- lfclient_host="localhost",
- lfclient_port=8080,
- debug=False,
- wait_timeout=120,
- _exit_on_error=False,
- _exit_on_fail=False,
- _proxy_str=None,
- _capture_signal_list=[]):
+ def __init__(self,
+ args,
+ _scheme,
+ _port,
+ _series,
+ _ctlr,
+ _prompt,
+ _user,
+ _passwd,
+ _ap,
+ _ap_slot,
+ _band,
+ _chan_5ghz,
+ _chan_24ghz,
+ _chan_width,
+ _ap_mode,
+ _tx_power,
+ _client_density,
+ _cap_ctl_out,
+ _ap_dict,
+ endp_type,
+ tos,
+ side_b,
+ radio_name_list,
+ number_of_stations_per_radio_list,
+ ssid_list,
+ ssid_password_list,
+ ssid_security_list,
+ wifimode_list,
+ station_lists,
+ name_prefix,
+ debug_on,
+ outfile,
+ results,
+ test_keys,
+ test_config,
+ reset_port_enable_list,
+ reset_port_time_min_list,
+ reset_port_time_max_list,
+ csv_started=False,
+ side_a_tx_min_bps=560000,
+ side_a_tx_max_bps=0, # setting to 0 will match min
+ side_a_min_pdu=1518,
+ side_a_max_pdu=0,
+ side_b_tx_min_bps=560000,
+ side_b_tx_max_bps=0, # setting to 0 will match min
+ side_b_min_pdu=1518,
+ side_b_max_pdu=0,
+ number_template="00",
+ test_duration="256s",
+ polling_interval="60s",
+ lfclient_host="localhost",
+ lfclient_port=8080,
+ debug=False,
+ wait_timeout=120,
+ _exit_on_error=False,
+ _exit_on_fail=False,
+ _proxy_str=None,
+ _capture_signal_list=None):
super().__init__(lfclient_host=lfclient_host,
lfclient_port=lfclient_port,
debug_=debug,
@@ -909,17 +1042,19 @@ class L3VariableTime(Realm):
_exit_on_fail=_exit_on_fail,
_proxy_str=_proxy_str,
_capture_signal_list=_capture_signal_list)
+ if _capture_signal_list is None:
+ _capture_signal_list = []
self.scheme = _scheme
- self.port = _port
+ self.port = _port
self.series = _series
- self.ctlr = _ctlr
+ self.ctlr = _ctlr
self.prompt = _prompt
- self.user = _user
+ self.user = _user
self.passwd = _passwd
- self.ap = _ap
+ self.ap = _ap
self.ap_slot = _ap_slot
- self.band = _band
- self.chan_5ghz = _chan_5ghz
+ self.band = _band
+ self.chan_5ghz = _chan_5ghz
self.chan_24ghz = _chan_24ghz
self.chan_width = _chan_width
self.ap_mode = _ap_mode
@@ -932,7 +1067,7 @@ class L3VariableTime(Realm):
self.side_b = side_b
self.ssid_list = ssid_list
self.ssid_password_list = ssid_password_list
- self.station_lists = station_lists
+ self.station_lists = station_lists
self.ssid_security_list = ssid_security_list
self.wifimode_list = wifimode_list
self.reset_port_enable_list = reset_port_enable_list
@@ -942,8 +1077,8 @@ class L3VariableTime(Realm):
self.name_prefix = name_prefix
self.test_duration = test_duration
self.radio_name_list = radio_name_list
- self.number_of_stations_per_radio_list = number_of_stations_per_radio_list
- #self.local_realm = realm.Realm(lfclient_host=self.host, lfclient_port=self.port, debug_=debug_on)
+ self.number_of_stations_per_radio_list = number_of_stations_per_radio_list
+ # self.local_realm = realm.Realm(lfclient_host=self.host, lfclient_port=self.port, debug_=debug_on)
self.polling_interval_seconds = self.duration_time_to_seconds(polling_interval)
self.cx_profile = self.new_l3_cx_profile()
self.multicast_profile = self.new_multicast_profile()
@@ -970,44 +1105,48 @@ class L3VariableTime(Realm):
self.test_keys = test_keys
self.test_config = test_config
- self.test_config_dict = dict(map(lambda x: x.split('=='), str(self.test_config).replace('[','').replace(']','').replace("'","").split()))
+ self.test_config_dict = dict(map(lambda x: x.split('=='),
+ str(self.test_config).replace('[', '').replace(']', '').replace("'",
+ "").split()))
# Full spread-sheet data
if self.outfile is not None:
- self.csv_file_details = open(self.outfile, "a+")
+ self.csv_file_details = open(self.outfile, "a+")
self.csv_writer = csv.writer(self.csv_file_details, delimiter=",")
-
+
if self.results is not None:
- self.csv_results = open(self.results, "a+")
+ self.csv_results = open(self.results, "a+")
self.csv_results_writer = csv.writer(self.csv_results, delimiter=",")
- for (radio_, ssid_, ssid_password_, ssid_security_, wifimode_,\
- reset_port_enable_, reset_port_time_min_, reset_port_time_max_) \
- in zip(radio_name_list, ssid_list, ssid_password_list, ssid_security_list, wifimode_list,\
- reset_port_enable_list, reset_port_time_min_list, reset_port_time_max_list):
+ for (radio_, ssid_, ssid_password_, ssid_security_, wifimode_,
+ reset_port_enable_, reset_port_time_min_, reset_port_time_max_) \
+ in zip(radio_name_list, ssid_list, ssid_password_list, ssid_security_list, wifimode_list,
+ reset_port_enable_list, reset_port_time_min_list, reset_port_time_max_list):
self.station_profile = self.new_station_profile()
self.station_profile.lfclient_url = self.lfclient_url
self.station_profile.ssid = ssid_
self.station_profile.ssid_pass = ssid_password_
self.station_profile.security = ssid_security_
- self.station_profile.mode = wifimode_
+ self.station_profile.mode = wifimode_
self.station_profile.number_template = self.number_template
- self.station_profile.mode = wifimode_
- self.station_profile.set_reset_extra(reset_port_enable=reset_port_enable_,\
- test_duration=self.duration_time_to_seconds(self.test_duration),\
- reset_port_min_time=self.duration_time_to_seconds(reset_port_time_min_),\
- reset_port_max_time=self.duration_time_to_seconds(reset_port_time_max_))
+ self.station_profile.mode = wifimode_
+ self.station_profile.set_reset_extra(reset_port_enable=reset_port_enable_,
+ test_duration=self.duration_time_to_seconds(self.test_duration),
+ reset_port_min_time=self.duration_time_to_seconds(
+ reset_port_time_min_),
+ reset_port_max_time=self.duration_time_to_seconds(
+ reset_port_time_max_))
self.station_profiles.append(self.station_profile)
-
+
self.multicast_profile.host = self.lfclient_host
self.cx_profile.host = self.lfclient_host
self.cx_profile.port = self.lfclient_port
self.cx_profile.name_prefix = self.name_prefix
- self.cx_profile.side_a_min_bps = self.side_a_tx_min_bps # Note: side_a_tx_min_bps is side_a_min_bps in py-json profiles
- self.cx_profile.side_a_max_bps = self.side_a_tx_min_bps
+ self.cx_profile.side_a_min_bps = self.side_a_tx_min_bps # Note: side_a_tx_min_bps is side_a_min_bps in py-json profiles
+ self.cx_profile.side_a_max_bps = self.side_a_tx_min_bps
self.cx_profile.side_a_min_pdu = self.side_a_min_pdu
self.cx_profile.side_a_max_pdu = self.side_a_max_pdu
- self.cx_profile.side_b_min_bps = self.side_b_tx_min_bps # Note: side_b_tx_min_bps is side_b_min_bps in py-json profiles
+ self.cx_profile.side_b_min_bps = self.side_b_tx_min_bps # Note: side_b_tx_min_bps is side_b_min_bps in py-json profiles
self.cx_profile.side_b_max_bps = self.side_b_tx_min_bps
self.cx_profile.side_b_min_pdu = self.side_b_min_pdu
self.cx_profile.side_b_max_pdu = self.side_b_max_pdu
@@ -1029,26 +1168,26 @@ class L3VariableTime(Realm):
our_endps[e] = e
for endp_name in endp_list['endpoint']:
if endp_name != 'uri' and endp_name != 'handler':
- for item, value in endp_name.items():
+ for item, endp_value in endp_name.items():
if item in our_endps:
- endps.append(value)
+ endps.append(endp_value)
print("endpoint: ", item, " value:\n")
- pprint(value)
-
- for value_name, value in value.items():
+ pprint(endp_value)
+
+ for value_name, value in endp_value.items():
if value_name == 'rx bytes':
endp_rx_map[item] = value
if value_name == 'rx drop %':
endp_rx_drop_map[item] = value
if value_name == 'rx rate':
# This hack breaks for mcast or if someone names endpoints weirdly.
- #print("item: ", item, " rx-bps: ", value_rx_bps)
+ # print("item: ", item, " rx-bps: ", value_rx_bps)
if item.endswith("-A"):
total_dl += int(value)
else:
total_ul += int(value)
- #print("total-dl: ", total_dl, " total-ul: ", total_ul, "\n")
+ # print("total-dl: ", total_dl, " total-ul: ", total_ul, "\n")
return endp_rx_map, endp_rx_drop_map, endps, total_dl, total_ul
def time_stamp(self):
@@ -1064,13 +1203,15 @@ class L3VariableTime(Realm):
csv_rx_delta_dict = {}
test_id = ""
- for key in [key for key in old_list if "mtx" in key]: del old_list[key]
- for key in [key for key in new_list if "mtx" in key]: del new_list[key]
+ for key in [key for key in old_list if "mtx" in key]:
+ del old_list[key]
+ for key in [key for key in new_list if "mtx" in key]:
+ del new_list[key]
- filtered_values = [v for _, v in new_list.items() if v !=0]
+ filtered_values = [v for _, v in new_list.items() if v != 0]
# Evaluate upload or download
new_evaluate_list = new_list.copy()
- print("new_evaluate_list before",new_evaluate_list)
+ print("new_evaluate_list before", new_evaluate_list)
# look at ul and dl
old_evaluate_list = old_list.copy()
@@ -1078,40 +1219,41 @@ class L3VariableTime(Realm):
for item, value in old_evaluate_list.items():
# check only upload or download - expected passes corresponds to traffic only in observed direction
if "upload" in self.test_config_dict.values() and item.endswith("-B") \
- or "download" in self.test_config_dict.values() and item.endswith("-A"):
- expected_passes +=1
+ or "download" in self.test_config_dict.values() and item.endswith("-A"):
+ expected_passes += 1
print("ITEM: {} VALUE: {}".format(item, value))
if new_evaluate_list[item] > old_evaluate_list[item]:
passes += 1
- #if self.debug: logg.info(item, new_evaluate_list[item], old_evaluate_list[item], " Difference: ", new_evaluate_list[item] - old_evaluate_list[item])
- print(item, new_evaluate_list[item], old_evaluate_list[item], " Difference: ", new_evaluate_list[item] - old_evaluate_list[item])
+ # if self.debug: logg.info(item, new_evaluate_list[item], old_evaluate_list[item], " Difference: ", new_evaluate_list[item] - old_evaluate_list[item])
+ print(item, new_evaluate_list[item], old_evaluate_list[item], " Difference: ",
+ new_evaluate_list[item] - old_evaluate_list[item])
else:
if "upload" in self.test_config_dict.values() and item.endswith("-B") \
- or "download" in self.test_config_dict.values() and item.endswith("-A"):
+ or "download" in self.test_config_dict.values() and item.endswith("-A"):
# only a failure if expecting traffic in that direction
print("Failed to increase rx bytes: ", item, new_evaluate_list[item], old_evaluate_list[item])
if not self.csv_started:
# stations that end in -A are dl (download, download), stations that end in -B are ul (upload, upload)
if item.endswith("-A"):
- csv_rx_headers.append(item+'-dl-rx-bytes')
+ csv_rx_headers.append(item + '-dl-rx-bytes')
else:
- csv_rx_headers.append(item+'-ul-rx-bytes')
- csv_rx_delta_dict.update({item:(new_evaluate_list[item] - old_evaluate_list[item])})
-
+ csv_rx_headers.append(item + '-ul-rx-bytes')
+ csv_rx_delta_dict.update({item: (new_evaluate_list[item] - old_evaluate_list[item])})
+
if not self.csv_started:
csv_header = self.csv_generate_column_details_headers()
csv_header += csv_rx_headers
logg.info(csv_header)
self.csv_add_column_headers(csv_header)
csv_results = self.csv_generate_column_results_headers()
- #csv_results += csv_rx_headers
+ # csv_results += csv_rx_headers
self.csv_add_column_headers_results(csv_results)
self.csv_started = True
# need to generate list of all the values
- filtered_values = [v for _, v in csv_rx_delta_dict.items() if v !=0]
+ filtered_values = [v for _, v in csv_rx_delta_dict.items() if v != 0]
# if need the average use average_rx_delta
- #average_rx_delta= sum(filtered_values) / len(filtered_values) if len(filtered_values) != 0 else 0
+ # average_rx_delta= sum(filtered_values) / len(filtered_values) if len(filtered_values) != 0 else 0
# write out the configuraiton for the test
for key in self.test_keys:
@@ -1122,7 +1264,7 @@ class L3VariableTime(Realm):
csv_rx_row_data.extend([self.epoch_time, self.time_stamp()])
csv_result_row_data.extend([self.epoch_time, self.time_stamp()])
- #Generate TestID
+ # Generate TestID
for key in self.test_keys:
test_id = test_id + "_" + self.test_config_dict[key]
@@ -1137,22 +1279,23 @@ class L3VariableTime(Realm):
csv_rx_row_data.append(self.side_b_tx_min_bps)
# Recorde the Total Transmit rate for all stations
- rx_bytes = sum(filtered_values) #total
+ rx_bytes = sum(filtered_values) # total
csv_rx_row_data.append(rx_bytes)
# The total_dl_bps and total_up_bps is for the interval
csv_rx_row_data.append(total_dl_bps)
csv_rx_row_data.append(total_ul_bps)
- #csv_result_row_data.append(rx_bytes)
+ # csv_result_row_data.append(rx_bytes)
print("csv_rx_row_data {}".format(csv_rx_row_data))
- #TODO: may want to pass in the information that needs to be in the csv file into the class
-
+ # TODO: may want to pass in the information that needs to be in the csv file into the class
+
for item, value in old_evaluate_list.items():
- expected_passes +=1
+ expected_passes += 1
if new_evaluate_list[item] > old_evaluate_list[item]:
passes += 1
- print(item, new_evaluate_list[item], old_evaluate_list[item], " Difference: ", new_evaluate_list[item] - old_evaluate_list[item])
+ print(item, new_evaluate_list[item], old_evaluate_list[item], " Difference: ",
+ new_evaluate_list[item] - old_evaluate_list[item])
else:
print("Failed to increase rx data: ", item, new_evaluate_list[item], old_evaluate_list[item])
if not self.csv_started:
@@ -1161,36 +1304,46 @@ class L3VariableTime(Realm):
csv_rx_row_data.append(new_list[item] - old_list[item])
# data from each station for each iteration
- self.csv_add_row(csv_rx_row_data,self.csv_writer,self.csv_file_details)
+ self.csv_add_row(csv_rx_row_data, self.csv_writer, self.csv_file_details)
if passes == expected_passes:
return True, rx_bytes, csv_result_row_data
else:
return False, rx_bytes, csv_result_row_data
else:
- print("Old-list length: %i new: %i does not match in compare-vals."%(len(old_list), len(new_list)))
- print("old-list:",old_list)
- print("new-list:",new_list)
- return False, None, None
+ print("Old-list length: %i new: %i does not match in compare-vals." % (len(old_list), len(new_list)))
+ print("old-list:", old_list)
+ print("new-list:", new_list)
+ return False, None, None
def reset_port_check(self):
for station_profile in self.station_profiles:
if station_profile.reset_port_extra_data['reset_port_enable']:
- if station_profile.reset_port_extra_data['reset_port_timer_started'] == False:
- logg.info("reset_port_time_min: {}".format(station_profile.reset_port_extra_data['reset_port_time_min']))
- logg.info("reset_port_time_max: {}".format(station_profile.reset_port_extra_data['reset_port_time_max']))
+ if not station_profile.reset_port_extra_data['reset_port_timer_started']:
+ logg.info(
+ "reset_port_time_min: {}".format(station_profile.reset_port_extra_data['reset_port_time_min']))
+ logg.info(
+ "reset_port_time_max: {}".format(station_profile.reset_port_extra_data['reset_port_time_max']))
station_profile.reset_port_extra_data['seconds_till_reset'] = \
- random.randint(station_profile.reset_port_extra_data['reset_port_time_min'],\
- station_profile.reset_port_extra_data['reset_port_time_max'])
+ random.randint(station_profile.reset_port_extra_data['reset_port_time_min'],
+ station_profile.reset_port_extra_data['reset_port_time_max'])
station_profile.reset_port_extra_data['reset_port_timer_started'] = True
- logg.info("on radio {} seconds_till_reset {}".format(station_profile.add_sta_data['radio'],station_profile.reset_port_extra_data['seconds_till_reset']))
+ logg.info("on radio {} seconds_till_reset {}".format(station_profile.add_sta_data['radio'],
+ station_profile.reset_port_extra_data[
+ 'seconds_till_reset']))
else:
- station_profile.reset_port_extra_data['seconds_till_reset'] = station_profile.reset_port_extra_data['seconds_till_reset'] - 1
- if self.debug: logg.info("radio: {} countdown seconds_till_reset {}".format(station_profile.add_sta_data['radio'] ,station_profile.reset_port_extra_data['seconds_till_reset']))
- if ((station_profile.reset_port_extra_data['seconds_till_reset'] <= 0)):
+ station_profile.reset_port_extra_data['seconds_till_reset'] = station_profile.reset_port_extra_data[
+ 'seconds_till_reset'] - 1
+ if self.debug:
+ logg.info(
+ "radio: {} countdown seconds_till_reset {}".format(station_profile.add_sta_data['radio'],
+ station_profile.reset_port_extra_data[
+ 'seconds_till_reset']))
+ if station_profile.reset_port_extra_data['seconds_till_reset'] <= 0:
station_profile.reset_port_extra_data['reset_port_timer_started'] = False
- port_to_reset = random.randint(0,len(station_profile.station_names)-1)
- logg.info("reset on radio {} station: {}".format(station_profile.add_sta_data['radio'],station_profile.station_names[port_to_reset]))
+ port_to_reset = random.randint(0, len(station_profile.station_names) - 1)
+ logg.info("reset on radio {} station: {}".format(station_profile.add_sta_data['radio'],
+ station_profile.station_names[port_to_reset]))
self.reset_port(station_profile.station_names[port_to_reset])
def pre_cleanup(self):
@@ -1204,12 +1357,12 @@ class L3VariableTime(Realm):
# Verify Stations are Gone
count = 0
- while (count < 10):
+ while count < 10:
more = False
for station_list in self.station_lists:
for sta in station_list:
rv = self.rm_port(sta, check_exists=True)
- if (rv):
+ if rv:
more = True
if not more:
break
@@ -1223,24 +1376,28 @@ class L3VariableTime(Realm):
station_profile.set_number_template(station_profile.number_template)
logg.info("Creating stations")
- station_profile.create(radio=self.radio_name_list[index], sta_names_=self.station_lists[index], debug=self.debug, sleep_time=0)
+ station_profile.create(radio=self.radio_name_list[index], sta_names_=self.station_lists[index],
+ debug=self.debug, sleep_time=0)
index += 1
for _tos in self.tos:
- logg.info("Creating connections for endpoint type: {} TOS: {} stations_names {}".format(self.endp_type, _tos, station_profile.station_names))
- self.cx_profile.create(endp_type=self.endp_type, side_a=station_profile.station_names, side_b=self.side_b, sleep_time=0, tos=_tos)
- self._pass("PASS: Stations build finished")
-
+ logg.info(
+ "Creating connections for endpoint type: {} TOS: {} stations_names {}".format(self.endp_type, _tos,
+ station_profile.station_names))
+ self.cx_profile.create(endp_type=self.endp_type, side_a=station_profile.station_names,
+ side_b=self.side_b, sleep_time=0, tos=_tos)
+ self._pass("PASS: Stations build finished")
+
def start(self, print_pass=False, print_fail=False):
best_rx_bytes = 0
rx_bytes = 0
csv_rx_row_data = " "
Result = False
logg.info("Bringing up stations")
- self.admin_up(self.side_b)
+ self.admin_up(self.side_b)
for station_profile in self.station_profiles:
for sta in station_profile.station_names:
- logg.info("Bringing up station %s"%(sta))
+ logg.info("Bringing up station %s" % sta)
self.admin_up(sta)
temp_stations_list = []
@@ -1251,7 +1408,7 @@ class L3VariableTime(Realm):
logg.info("ip's acquired")
else:
logg.info("Stations Failed to get IP's , consider increasing -wto','--wait_timeout' from the command line ")
- exit(1) # Exit if cannot receive IP's
+ exit(1) # Exit if cannot receive IP's
time.sleep(30)
logg.info("Starting layer-3 traffic (if any configured)")
self.cx_profile.start_cx()
@@ -1264,7 +1421,7 @@ class L3VariableTime(Realm):
end_time = self.parse_time(self.test_duration) + cur_time
- logg.info("Monitoring throughput for duration: %s"%(self.test_duration))
+ logg.info("Monitoring throughput for duration: %s" % self.test_duration)
passes = 0
expected_passes = 0
@@ -1276,17 +1433,18 @@ class L3VariableTime(Realm):
cur_time = datetime.datetime.now()
self.reset_port_check()
time.sleep(1)
-
+
self.epoch_time = int(time.time())
# the total_dl_bps and total_up_bps is for all stations
- new_rx_values, rx_drop_percent, endps, total_dl_bps, total_ul_bps = self.__get_rx_values()
+ new_rx_values, rx_drop_percent, endps, total_dl_bps, total_ul_bps = self.__get_rx_values()
print("main loop, total-dl: ", total_dl_bps, " total-ul: ", total_ul_bps)
expected_passes += 1
# __compare_vals - does the calculations
- Result, rx_bytes, csv_rx_row_data = self.__compare_vals(old_rx_values, new_rx_values, total_dl_bps, total_ul_bps)
+ Result, rx_bytes, csv_rx_row_data = self.__compare_vals(old_rx_values, new_rx_values, total_dl_bps,
+ total_ul_bps)
# save the best rate for the interval
if rx_bytes > best_rx_bytes:
best_rx_bytes = rx_bytes
@@ -1294,7 +1452,8 @@ class L3VariableTime(Realm):
if Result:
passes += 1
else:
- fail_msg = "FAIL: TIME: {} EPOCH: {} Not all stations increased traffic".format(cur_time, self.epoch_time)
+ fail_msg = "FAIL: TIME: {} EPOCH: {} Not all stations increased traffic".format(cur_time,
+ self.epoch_time)
self._fail(fail_msg, print_fail)
old_rx_values = new_rx_values
@@ -1306,7 +1465,7 @@ class L3VariableTime(Realm):
csv_rx_row_data.append(best_rx_bytes)
csv_rx_row_data.append(total_dl_bps)
csv_rx_row_data.append(total_ul_bps)
- self.csv_add_row(csv_rx_row_data,self.csv_results_writer,self.csv_results)
+ self.csv_add_row(csv_rx_row_data, self.csv_results_writer, self.csv_results)
if passes == expected_passes:
self._pass("PASS: All tests passed", print_pass)
@@ -1322,52 +1481,59 @@ class L3VariableTime(Realm):
self.multicast_profile.cleanup()
for station_profile in self.station_profiles:
station_profile.cleanup()
-
+
# for details csv file
def csv_generate_column_details_headers(self):
# test_keys used to generate the test_id
- csv_rx_headers = self.test_keys.copy()
- csv_rx_headers.extend
+ csv_rx_headers = self.test_keys.copy()
# test_keys are the controller configuration
- csv_rx_headers.extend(['epoch_time','time','test_id','test_duration','intv_sec','A_to_B_tx_bps_ul','B_to_A_tx_bps_dl','rx_bytes_intv_best','all_sta_dl_bps','all_sta_ul_bps'])
+ csv_rx_headers.extend(
+ ['epoch_time', 'time', 'test_id', 'test_duration', 'intv_sec', 'A_to_B_tx_bps_ul', 'B_to_A_tx_bps_dl',
+ 'rx_bytes_intv_best', 'all_sta_dl_bps', 'all_sta_ul_bps'])
return csv_rx_headers
def csv_generate_column_results_headers(self):
# test_keys used to generate test_id
- csv_rx_headers = self.test_keys.copy()
- csv_rx_headers.extend
- #test_keys are the controller configuration
- csv_rx_headers.extend(['epoch_time','time','test_id','test_duration','intv_sec','A_to_B_tx_bps_ul','B_to_A_tx_bps_dl','rx_bytes_intv_best','all_sta_dl_bps','all_sta_ul_bps'])
+ csv_rx_headers = self.test_keys.copy()
+ # test_keys are the controller configuration
+ csv_rx_headers.extend(
+ ['epoch_time', 'time', 'test_id', 'test_duration', 'intv_sec', 'A_to_B_tx_bps_ul', 'B_to_A_tx_bps_dl',
+ 'rx_bytes_intv_best', 'all_sta_dl_bps', 'all_sta_ul_bps'])
return csv_rx_headers
- def csv_add_column_headers(self,headers):
+ def csv_add_column_headers(self, headers):
if self.csv_file_details is not None:
self.csv_writer.writerow(headers)
self.csv_file_details.flush()
- def csv_add_column_headers_results(self,headers):
+ def csv_add_column_headers_results(self, headers):
if self.csv_results is not None:
self.csv_results_writer.writerow(headers)
- self.csv_results.flush()
+ self.csv_results.flush()
- def csv_validate_list(self, csv_list, length):
+ @staticmethod
+ def csv_validate_list(csv_list, length):
if len(csv_list) < length:
- csv_list = csv_list + [('no data','no data')] * (length - len(csv_list))
+ csv_list = csv_list + [('no data', 'no data')] * (length - len(csv_list))
return csv_list
- def csv_add_row(self,row,writer,csv_file_details): # can make two calls eventually
+ @staticmethod
+ def csv_add_row(row, writer, csv_file_details): # can make two calls eventually
if csv_file_details is not None:
writer.writerow(row)
csv_file_details.flush()
+
def valid_endp_types(_endp_type):
etypes = _endp_type.split()
for endp_type in etypes:
- valid_endp_type=['lf_udp','lf_udp6','lf_tcp','lf_tcp6','mc_udp','mc_udp6']
+ valid_endp_type = ['lf_udp', 'lf_udp6', 'lf_tcp', 'lf_tcp6', 'mc_udp', 'mc_udp6']
if not (str(endp_type) in valid_endp_type):
print('invalid endp_type: %s. Valid types lf_udp, lf_udp6, lf_tcp, lf_tcp6, mc_udp, mc_udp6' % endp_type)
exit(1)
return _endp_type
+
+
################################################################################
#
# End of Traffic Generation Class
@@ -1381,18 +1547,17 @@ def valid_endp_types(_endp_type):
############################################################
def main():
global logg
- lfjson_host = "localhost"
lfjson_port = 8080
debug_on = False
parser = argparse.ArgumentParser(
prog='lf_controller_snp.py',
- #formatter_class=argparse.RawDescriptionHelpFormatter,
+ # formatter_class=argparse.RawDescriptionHelpFormatter,
formatter_class=argparse.RawTextHelpFormatter,
epilog='''\
Scaling and Performance
''',
-
+
description='''\
lf_controller_snp.py:
--------------------
@@ -1622,76 +1787,118 @@ LANforge GUI what is displayed in the Column and how to access the value with cl
#############################################
# Fixed Configurations Coded Into Script
#############################################
- parser.add_argument('-ct1' ,'--controller_test_1', help='--controller_test_1 LANforge static radio configuration',action="store_true")
- parser.add_argument('-ct2' ,'--controller_test_2', help='--controller_test_2 LANforge static radio configuration',action="store_true")
- parser.add_argument('-ct3' ,'--controller_test_3', help='--controller_test_3 LANforge static radio configuration',action="store_true")
+ parser.add_argument('-ct1', '--controller_test_1', help='--controller_test_1 LANforge static radio configuration',
+ action="store_true")
+ parser.add_argument('-ct2', '--controller_test_2', help='--controller_test_2 LANforge static radio configuration',
+ action="store_true")
+ parser.add_argument('-ct3', '--controller_test_3', help='--controller_test_3 LANforge static radio configuration',
+ action="store_true")
#############################################
# Script Controller Configurations
#############################################
- parser.add_argument('-cca' ,'--controller_aps', help='--controller_aps List of APs to test default: APA453.0E7B.CF9C',default="APA453.0E7B.CF9C")
- parser.add_argument('-ccf' ,'--controller_bands', help='--controller_bands default: a',default="a")
- parser.add_argument('-cwm' ,'--controller_wifimodes', help='List of of wifi mode to test default: auto',default="auto")
+ parser.add_argument('-cca', '--controller_aps',
+ help='--controller_aps List of APs to test default: APA453.0E7B.CF9C',
+ default="APA453.0E7B.CF9C")
+ parser.add_argument('-ccf', '--controller_bands', help='--controller_bands default: a', default="a")
+ parser.add_argument('-cwm', '--controller_wifimodes', help='List of of wifi mode to test default: auto',
+ default="auto")
- parser.add_argument('-cc5','--controller_chan_5ghzs', help='--controller_chan_5ghzs <36 40 ...> default 36',default="36")
- parser.add_argument('-cc2','--controller_chan_24ghzs', help='--controller_chan_24ghzs <1 2 ...> default 1',default="1")
- parser.add_argument('-ccw','--controller_chan_widths', help='--controller_chan_widths <20 40 80 160> default: \"20\"',default="20")
- parser.add_argument('-cam','--controller_ap_modes', help='--controller_ap_modes |