mirror of
https://github.com/Telecominfraproject/wlan-lanforge-scripts.git
synced 2025-11-01 03:07:56 +00:00
Merge branch 'master' of https://github.com/greearb/lanforge-scripts
This commit is contained in:
@@ -7,16 +7,14 @@ if sys.version_info[0] != 3:
|
||||
print("This script requires Python 3")
|
||||
exit()
|
||||
|
||||
import email.message
|
||||
import http.client
|
||||
|
||||
import urllib.request
|
||||
import urllib.error
|
||||
from urllib import error
|
||||
import urllib.parse
|
||||
import json
|
||||
import LANforge
|
||||
from LANforge import LFUtils
|
||||
|
||||
|
||||
class LFRequest:
|
||||
Default_Base_URL = "http://localhost:8080"
|
||||
No_Data = {'No Data':0}
|
||||
@@ -45,14 +43,14 @@ class LFRequest:
|
||||
request.headers['Content-type'] = 'application/x-www-form-urlencoded'
|
||||
resp = ''
|
||||
try:
|
||||
resp = urllib.request.urlopen(request);
|
||||
resp = urllib.request.urlopen(request)
|
||||
responses.append(resp)
|
||||
return responses[0]
|
||||
except urllib.error.HTTPError as error:
|
||||
if (show_error):
|
||||
print("----- formPost() HTTPError: --------------------------------------------")
|
||||
print("%s: %s; URL: %s"%(error.code, error.reason, request.get_full_url()))
|
||||
LFUtils.debug_printer.pprint(error.headers())
|
||||
LFUtils.debug_printer.pprint(error.headers)
|
||||
#print("Error: ", sys.exc_info()[0])
|
||||
#print("Request URL:", request.get_full_url())
|
||||
print("Request Content-type:", request.get_header('Content-type'))
|
||||
@@ -84,11 +82,11 @@ class LFRequest:
|
||||
|
||||
request.headers['Content-type'] = 'application/json'
|
||||
try:
|
||||
resp = urllib.request.urlopen(request);
|
||||
resp = urllib.request.urlopen(request)
|
||||
responses.append(resp)
|
||||
return responses[0]
|
||||
except urllib.error.HTTPError as error:
|
||||
if (show_error):
|
||||
if show_error:
|
||||
print("----- jsonPost() HTTPError: --------------------------------------------")
|
||||
print("<%s> HTTP %s: %s"%(request.get_full_url(), error.code, error.reason, ))
|
||||
|
||||
@@ -99,24 +97,23 @@ class LFRequest:
|
||||
print("Request Data:")
|
||||
LFUtils.debug_printer.pprint(request.data)
|
||||
|
||||
if (error.headers):
|
||||
if error.headers:
|
||||
# the HTTPError is of type HTTPMessage a subclass of email.message
|
||||
# print(type(error.keys()))
|
||||
for headername in sorted(error.headers.keys()):
|
||||
print ("Response %s: %s "%(headername, error.headers.get(headername)))
|
||||
|
||||
if (len(responses) > 0):
|
||||
if len(responses) > 0:
|
||||
print("----- Response: --------------------------------------------------------")
|
||||
LFUtils.debug_printer.pprint(responses[0].reason)
|
||||
print("------------------------------------------------------------------------")
|
||||
except urllib.error.URLError as uerror:
|
||||
if (show_error):
|
||||
if show_error:
|
||||
print("----- jsonPost() URLError: ---------------------------------------------")
|
||||
print("Reason: %s; URL: %s"%(uerror.reason, request.get_full_url()))
|
||||
print("------------------------------------------------------------------------")
|
||||
return None
|
||||
|
||||
|
||||
def get(self, show_error=True):
|
||||
myrequest = urllib.request.Request(url=self.requested_url, headers=self.default_headers)
|
||||
myresponses = []
|
||||
@@ -124,10 +121,10 @@ class LFRequest:
|
||||
myresponses.append(urllib.request.urlopen(myrequest))
|
||||
return myresponses[0]
|
||||
except urllib.error.HTTPError as error:
|
||||
if (show_error):
|
||||
if show_error:
|
||||
print("----- get() HTTPError: --------------------------------------------")
|
||||
print("<%s> HTTP %s: %s"%(myrequest.get_full_url(), error.code, error.reason, ))
|
||||
if (error.code != 404):
|
||||
if error.code != 404:
|
||||
print("Error: ", sys.exc_info()[0])
|
||||
print("Request URL:", myrequest.get_full_url())
|
||||
print("Request Content-type:", myrequest.get_header('Content-type'))
|
||||
@@ -135,24 +132,23 @@ class LFRequest:
|
||||
print("Request Data:")
|
||||
LFUtils.debug_printer.pprint(myrequest.data)
|
||||
|
||||
if (error.headers):
|
||||
if error.headers:
|
||||
# the HTTPError is of type HTTPMessage a subclass of email.message
|
||||
# print(type(error.keys()))
|
||||
for headername in sorted(error.headers.keys()):
|
||||
print ("Response %s: %s "%(headername, error.headers.get(headername)))
|
||||
|
||||
if (len(myresponses) > 0):
|
||||
if len(myresponses) > 0:
|
||||
print("----- Response: --------------------------------------------------------")
|
||||
LFUtils.debug_printer.pprint(myresponses[0].reason)
|
||||
print("------------------------------------------------------------------------")
|
||||
except urllib.error.URLError as uerror:
|
||||
if (show_error):
|
||||
if show_error:
|
||||
print("----- get() URLError: ---------------------------------------------")
|
||||
print("Reason: %s; URL: %s"%(uerror.reason, myrequest.get_full_url()))
|
||||
print("------------------------------------------------------------------------")
|
||||
return None
|
||||
|
||||
|
||||
def getAsJson(self, show_error=True):
|
||||
responses = []
|
||||
responses.append(self.get(show_error))
|
||||
|
||||
52
py-json/LANforge/lfcli_base.py
Normal file
52
py-json/LANforge/lfcli_base.py
Normal file
@@ -0,0 +1,52 @@
|
||||
#!env /usr/bin/python
|
||||
|
||||
# Extend this class to use common set of debug and request features for your script
|
||||
from pprint import pprint
|
||||
import LANforge.LFUtils
|
||||
from LANforge.LFUtils import *
|
||||
|
||||
|
||||
class LFCliBase:
|
||||
# do not use `super(LFCLiBase,self).__init__(self, host, port, _debugOn)
|
||||
# that is py2 era syntax and will force self into the host variable, making you
|
||||
# very confused.
|
||||
def __init__(self, _lfjson_host, _lfjson_port, _debug=False):
|
||||
self.lfjson_host = _lfjson_host
|
||||
self.lfjson_port = _lfjson_port
|
||||
self.debugOn = _debug
|
||||
self.mgr_url = "http://%s:%s/" % (self.lfjson_host, self.lfjson_port)
|
||||
|
||||
def jsonPost(self, _req_url, _data):
|
||||
lf_r = LFRequest.LFRequest(self.mgr_url + _req_url)
|
||||
_data['suppress_preexec_cli'] = True
|
||||
_data['suppress_preexec_method'] = True
|
||||
lf_r.addPostData(_data)
|
||||
if (self.debugOn):
|
||||
LANforge.LFUtils.debug_printer.pprint(_data)
|
||||
json_response = lf_r.jsonPost(self.debugOn)
|
||||
# Debugging
|
||||
# if (json_response != None):
|
||||
# print("jsonReq: response: ")
|
||||
# LFUtils.debug_printer.pprint(vars(json_response))
|
||||
return json_response
|
||||
|
||||
def jsonGet(self, _req_url):
|
||||
lf_r = LFRequest.LFRequest(self.mgr_url + _req_url)
|
||||
json_response = lf_r.getAsJson(self.debugOn)
|
||||
return json_response
|
||||
|
||||
def checkConnect(self):
|
||||
print(f"Checking for LANforge GUI connection: {self.mgr_url}")
|
||||
response = self.jsonGet("/")
|
||||
duration = 0
|
||||
while (response is None) and (duration < 300):
|
||||
print(f"LANforge GUI connection not found sleeping 5 seconds, tried: {self.mgr_url}")
|
||||
duration += 2
|
||||
time.sleep(2)
|
||||
response = self.jsonGet("")
|
||||
|
||||
if duration >= 300:
|
||||
print("Could not connect to LANforge GUI")
|
||||
sys.exit(1)
|
||||
|
||||
# ~class
|
||||
@@ -5,223 +5,158 @@
|
||||
# to the requested BSSID if bssid is specified as an argument.
|
||||
# The script will clean up the station and connections at the end of the test.
|
||||
|
||||
import os
|
||||
import time
|
||||
import sys
|
||||
import argparse
|
||||
|
||||
if 'py-json' not in sys.path:
|
||||
sys.path.append('../py-json')
|
||||
|
||||
import subprocess
|
||||
import json
|
||||
import pprint
|
||||
from LANforge import LFRequest
|
||||
# from LANforge import LFRequest
|
||||
from LANforge import LFUtils
|
||||
# from LANforge import LFCliBase
|
||||
from LANforge.lfcli_base import LFCliBase
|
||||
from LANforge.LFUtils import *
|
||||
from pprint import pprint
|
||||
|
||||
import create_genlink as genl
|
||||
|
||||
debugOn = True
|
||||
if sys.version_info[0] != 3:
|
||||
print("This script requires Python 3")
|
||||
exit(1)
|
||||
|
||||
dest = "localhost";
|
||||
port = "8080";
|
||||
dut_ssid = "MyAP"
|
||||
dut_passwd = "NA"
|
||||
dut_bssid = ""
|
||||
user = ""
|
||||
passwd = ""
|
||||
sta_mode = "0" # See add_sta LANforge CLI users guide entry
|
||||
radio = "wiphy0"
|
||||
resource = "1"
|
||||
upstream_resource = "1"
|
||||
upstream_port = "eth2"
|
||||
sta_name = "sta001"
|
||||
|
||||
parser = argparse.ArgumentParser(description="LANforge Unit Test: Connect Station to AP\nExample:\n./sta_connect.py --dest 192.168.100.209 --dut_ssid OpenWrt-2 --dut_bssid 24:F5:A2:08:21:6C")
|
||||
parser.add_argument("-d", "--dest", type=str, help="address of the LANforge GUI machine (localhost is default)")
|
||||
parser.add_argument("-o", "--port", type=int, help="IP Port the LANforge GUI is listening on (8080 is default)")
|
||||
parser.add_argument("-u", "--user", type=str, help="TBD: credential login/username")
|
||||
parser.add_argument("-p", "--passwd", type=str, help="TBD: credential password")
|
||||
parser.add_argument("--resource", type=str, help="LANforge Station resource ID to use, default is 1")
|
||||
parser.add_argument("--upstream_resource", type=str, help="LANforge Ethernet port resource ID to use, default is 1")
|
||||
parser.add_argument("--upstream_port", type=str, help="LANforge Ethernet port name, default is eth2")
|
||||
parser.add_argument("--radio", type=str, help="LANforge radio to use, default is wiphy0")
|
||||
parser.add_argument("--sta_mode", type=str, help="LANforge station-mode setting (see add_sta LANforge CLI documentation, default is 0 (auto))")
|
||||
parser.add_argument("--dut_ssid", type=str, help="DUT SSID")
|
||||
parser.add_argument("--dut_passwd", type=str, help="DUT PSK password. Do not set for OPEN auth")
|
||||
parser.add_argument("--dut_bssid", type=str, help="DUT BSSID to which we expect to connect.")
|
||||
class StaConnect(LFCliBase):
|
||||
def __init__(self, host, port, _dut_ssid="MyAP", _dut_passwd="NA", _dut_bssid="",
|
||||
_user="", _passwd="", _sta_mode="0", _radio="wiphy0",
|
||||
_resource=1, _upstream_resource=1, _upstream_port="eth2",
|
||||
_sta_name="sta001", _debugOn=False):
|
||||
# do not use `super(LFCLiBase,self).__init__(self, host, port, _debugOn)
|
||||
# that is py2 era syntax and will force self into the host variable, making you
|
||||
# very confused.
|
||||
super().__init__(host, port, _debugOn)
|
||||
|
||||
args = None
|
||||
self.dut_ssid = _dut_ssid
|
||||
self.dut_passwd = _dut_passwd
|
||||
self.dut_bssid = _dut_bssid
|
||||
self.user = _user
|
||||
self.passwd = _passwd
|
||||
self.sta_mode = _sta_mode # See add_sta LANforge CLI users guide entry
|
||||
self.radio = _radio
|
||||
self.resource = _resource
|
||||
self.upstream_resource = _upstream_resource
|
||||
self.upstream_port = _upstream_port
|
||||
self.sta_name = _sta_name
|
||||
self.sta_url = None # defer construction
|
||||
self.upstream_url = None # defer construction
|
||||
|
||||
args = parser.parse_args()
|
||||
if (args.dest != None):
|
||||
dest = args.dest
|
||||
if (args.port != None):
|
||||
port = args.port
|
||||
if (args.user != None):
|
||||
user = args.user
|
||||
if (args.passwd != None):
|
||||
passwd = args.passwd
|
||||
if (args.sta_mode != None):
|
||||
sta_mode = args.sta_mode
|
||||
if (args.upstream_resource != None):
|
||||
upstream_resource = args.upstream_resource
|
||||
if (args.upstream_port != None):
|
||||
upstream_port = args.upstream_port
|
||||
if (args.radio != None):
|
||||
radio = args.radio
|
||||
if (args.resource != None):
|
||||
resource = args.resource
|
||||
if (args.dut_passwd != None):
|
||||
dut_passwd = args.dut_passwd
|
||||
if (args.dut_bssid != None):
|
||||
dut_bssid = args.dut_bssid
|
||||
if (args.dut_ssid != None):
|
||||
dut_ssid = args.dut_ssid
|
||||
def getStaUrl(self):
|
||||
if self.sta_url is None:
|
||||
self.sta_url = f"port/1/{self.resource}/{self.sta_name}"
|
||||
return self.sta_url
|
||||
|
||||
mgrURL = "http://%s:%s/"%(dest, port)
|
||||
radio_url = "port/1/%s/%s"%(resource, radio)
|
||||
sta_url = "port/1/%s/%s"%(resource, sta_name)
|
||||
upstream_url = "port/1/%s/%s"%(upstream_resource, upstream_port)
|
||||
def getUpstreamUrl(self):
|
||||
if self.upstream_url is None:
|
||||
self.upstream_url = f"port/1/{self.upstream_resource}/{self.upstream_port}"
|
||||
return self.upstream_url
|
||||
|
||||
def jsonReq(mgrURL, reqURL, data, exitWhenCalled=False):
|
||||
lf_r = LFRequest.LFRequest(mgrURL + reqURL)
|
||||
# Compare pre-test values to post-test values
|
||||
@staticmethod
|
||||
def compareVals(name, postVal):
|
||||
# print(f"Comparing {name}")
|
||||
if postVal > 0:
|
||||
print("PASSED: %s %s" % (name, postVal))
|
||||
else:
|
||||
print("FAILED: %s did not report traffic: %s" % (name, postVal))
|
||||
|
||||
data['suppress_preexec_cli'] = True
|
||||
data['suppress_preexec_method'] = True
|
||||
|
||||
lf_r.addPostData(data)
|
||||
|
||||
json_response = lf_r.jsonPost(True)
|
||||
# Debugging
|
||||
#if (json_response != None):
|
||||
# print("jsonReq: response: ")
|
||||
# LFUtils.debug_printer.pprint(vars(json_response))
|
||||
if exitWhenCalled:
|
||||
print("jsonReq: bye")
|
||||
sys.exit(1)
|
||||
|
||||
def getJsonInfo(mgrURL, reqURL, debug=False):
|
||||
lf_r = LFRequest.LFRequest(mgrURL + reqURL)
|
||||
json_response = lf_r.getAsJson(debug)
|
||||
return json_response
|
||||
#print(name)
|
||||
#j_printer = pprint.PrettyPrinter(indent=2)
|
||||
#j_printer.pprint(json_response)
|
||||
#for record in json_response[key]:
|
||||
# j_printer.pprint(record)
|
||||
|
||||
|
||||
print("Checking for LANforge GUI connection: %s"%(mgrURL))
|
||||
response = getJsonInfo(mgrURL, radio_url);
|
||||
duration = 0
|
||||
while ((response == None) and (duration < 300)):
|
||||
print("LANforge GUI connection not found sleeping 5 seconds, tried: %s"%(mgrURL))
|
||||
duration += 2
|
||||
time.sleep(2)
|
||||
response = getJsonInfo(mgrURL, radio_url)
|
||||
|
||||
if duration >= 300:
|
||||
print("Could not connect to LANforge GUI")
|
||||
sys.exit(1)
|
||||
def run(self):
|
||||
self.checkConnect()
|
||||
eth1IP = self.jsonGet(self.getUpstreamUrl())
|
||||
if eth1IP['interface']['ip'] == "0.0.0.0":
|
||||
print(f"Warning: {self.getUpstreamUrl()} lacks ip address")
|
||||
|
||||
url = self.getStaUrl()
|
||||
response = super().jsonGet(url)
|
||||
if response is not None:
|
||||
if response["interface"] is not None:
|
||||
print("removing old station")
|
||||
LFUtils.removePort(self.resource, self.sta_name, self.mgr_url)
|
||||
LFUtils.waitUntilPortsDisappear(self.resource, self.mgr_url, [self.sta_name])
|
||||
|
||||
# Create stations and turn dhcp on
|
||||
print("Creating station and turning on dhcp")
|
||||
|
||||
url = sta_url
|
||||
debugOn = True
|
||||
response = getJsonInfo(mgrURL, url)
|
||||
if (response is not None):
|
||||
if (response["interface"] is not None):
|
||||
print("removing old station")
|
||||
LFUtils.removePort(resource, sta_name, mgrURL)
|
||||
time.sleep(5)
|
||||
|
||||
# See add_sta in LANforge CLI user guide
|
||||
print("Creating station %s and turning on dhcp..." % self.sta_name)
|
||||
url = "cli-json/add_sta"
|
||||
flags = 0x10000
|
||||
if "" != self.dut_passwd:
|
||||
flags += 0x400
|
||||
data = {
|
||||
"shelf": 1,
|
||||
"resource":resource,
|
||||
"radio":radio,
|
||||
"sta_name":sta_name,
|
||||
"ssid":dut_ssid,
|
||||
"key":dut_passwd,
|
||||
"mode":sta_mode,
|
||||
"resource": self.resource,
|
||||
"radio": self.radio,
|
||||
"sta_name": self.sta_name,
|
||||
"ssid": self.dut_ssid,
|
||||
"key": self.dut_passwd,
|
||||
"mode": self.sta_mode,
|
||||
"mac": "xx:xx:xx:xx:*:xx",
|
||||
"flags":0x10000 # verbose, open
|
||||
"flags": flags # verbose, wpa2
|
||||
}
|
||||
print("adding new station")
|
||||
jsonReq(mgrURL, url, data)
|
||||
print("Adding new station %s " % self.sta_name)
|
||||
super().jsonPost(url, data)
|
||||
|
||||
reqURL = "cli-json/set_port"
|
||||
data = {
|
||||
"shelf": 1,
|
||||
"resource":resource,
|
||||
"port":sta_name,
|
||||
"resource": self.resource,
|
||||
"port": self.sta_name,
|
||||
"current_flags": 0x80000000, # use DHCP, not down
|
||||
"interest": 0x4002 # set dhcp, current flags
|
||||
}
|
||||
print("configuring port")
|
||||
jsonReq(mgrURL, reqURL, data)
|
||||
|
||||
time.sleep(5)
|
||||
|
||||
eth1IP = getJsonInfo(mgrURL, upstream_url)
|
||||
if eth1IP['interface']['ip'] == "0.0.0.0":
|
||||
print("Warning: %s lacks ip address"%(upstream_url))
|
||||
print("Configuring %s..." % self.sta_name)
|
||||
super().jsonPost(reqURL, data)
|
||||
|
||||
reqURL = "cli-json/nc_show_ports"
|
||||
data = {"shelf": 1,
|
||||
"resource":resource,
|
||||
"port":sta_name,
|
||||
"resource": self.resource,
|
||||
"port": self.sta_name,
|
||||
"probe_flags": 1}
|
||||
jsonReq(mgrURL, reqURL, data)
|
||||
super().jsonPost(reqURL, data)
|
||||
LFUtils.waitUntilPortsAdminUp(self.resource, self.mgr_url, [self.sta_name])
|
||||
|
||||
station_info = getJsonInfo(mgrURL, "%s?fields=port,ip,ap"%(sta_url))
|
||||
# station_info = self.jsonGet(self.mgr_url, "%s?fields=port,ip,ap" % (self.getStaUrl()))
|
||||
duration = 0
|
||||
maxTime = 300
|
||||
ip = "0.0.0.0"
|
||||
ap = ""
|
||||
while ((ip == "0.0.0.0") and (duration < maxTime)):
|
||||
|
||||
while (ip == "0.0.0.0") and (duration < maxTime):
|
||||
duration += 2
|
||||
time.sleep(2)
|
||||
|
||||
station_info = getJsonInfo(mgrURL, "%s?fields=port,ip,ap"%(sta_url))
|
||||
station_info = super().jsonGet(f"{self.getStaUrl()}?fields=port,ip,ap")
|
||||
|
||||
# LFUtils.debug_printer.pprint(station_info)
|
||||
if ((station_info is not None) and ("interface" in station_info)):
|
||||
if ("ip" in station_info["interface"]):
|
||||
if (station_info is not None) and ("interface" in station_info):
|
||||
if "ip" in station_info["interface"]:
|
||||
ip = station_info["interface"]["ip"]
|
||||
if ("ap" in station_info["interface"]):
|
||||
if "ap" in station_info["interface"]:
|
||||
ap = station_info["interface"]["ap"]
|
||||
|
||||
if ((ap == "Not-Associated") or (ap == "")):
|
||||
print("Station waiting to associate...")
|
||||
if (ap == "Not-Associated") or (ap == ""):
|
||||
print("Waiting for %s associate to AP [%s]..." % (self.sta_name, ap))
|
||||
else:
|
||||
if (ip == "0.0.0.0"):
|
||||
print("Station waiting for IP ...")
|
||||
if ip == "0.0.0.0":
|
||||
print("Waiting for %s to gain IP ..." % self.sta_name)
|
||||
|
||||
if ((ap != "") and (ap != "Not-Associated")):
|
||||
print("Connected to AP: %s"%(ap))
|
||||
if (dut_bssid != ""):
|
||||
if (dut_bssid.lower() == ap.lower()):
|
||||
print("PASSED: Connected to BSSID: %s"%(ap))
|
||||
if (ap != "") and (ap != "Not-Associated"):
|
||||
print(f"Connected to AP: {ap}")
|
||||
if self.dut_bssid != "":
|
||||
if self.dut_bssid.lower() == ap.lower():
|
||||
print(f"PASSED: Connected to BSSID: {ap}")
|
||||
else:
|
||||
print("FAILED: Connected to wrong BSSID, requested: %s Actual: %s"%(dut_bssid, ap))
|
||||
print("FAILED: Connected to wrong BSSID, requested: %s Actual: %s" % (self.dut_bssid, ap))
|
||||
else:
|
||||
print("FAILED: Did not connect to AP");
|
||||
print("FAILED: Did not connect to AP")
|
||||
sys.exit(3)
|
||||
|
||||
if (ip is "0.0.0.0"):
|
||||
print("FAILED: %s did not get an ip. Ending test"%(sta_name))
|
||||
if ip == "0.0.0.0":
|
||||
print(f"FAILED: {self.sta_name} did not get an ip. Ending test")
|
||||
print("Cleaning up...")
|
||||
removePort(resource, sta_name, mgrURL)
|
||||
removePort(self.resource, self.sta_name, self.mgr_url)
|
||||
sys.exit(1)
|
||||
else:
|
||||
print("PASSED: Connected to AP: %s With IP: %s" % (ap, ip))
|
||||
@@ -232,25 +167,25 @@ reqURL = "cli-json/add_endp"
|
||||
data = {
|
||||
"alias": "testUDP-A",
|
||||
"shelf": 1,
|
||||
"resource":resource,
|
||||
"port":sta_name,
|
||||
"resource": self.resource,
|
||||
"port": self.sta_name,
|
||||
"type": "lf_udp",
|
||||
"ip_port": "-1",
|
||||
"min_rate": 1000000
|
||||
}
|
||||
jsonReq(mgrURL, reqURL, data)
|
||||
super().jsonPost(reqURL, data)
|
||||
|
||||
reqURL = "cli-json/add_endp"
|
||||
data = {
|
||||
"alias": "testUDP-B",
|
||||
"shelf": 1,
|
||||
"resource":upstream_resource,
|
||||
"port":upstream_port,
|
||||
"resource": self.upstream_resource,
|
||||
"port": self.upstream_port,
|
||||
"type": "lf_udp",
|
||||
"ip_port": "-1",
|
||||
"min_rate": 1000000
|
||||
}
|
||||
jsonReq(mgrURL, reqURL, data)
|
||||
super().jsonPost(reqURL, data)
|
||||
|
||||
# Create CX
|
||||
reqURL = "cli-json/add_cx"
|
||||
@@ -260,32 +195,32 @@ data = {
|
||||
"tx_endp": "testUDP-A",
|
||||
"rx_endp": "testUDP-B",
|
||||
}
|
||||
jsonReq(mgrURL, reqURL, data)
|
||||
super().jsonPost(reqURL, data)
|
||||
|
||||
# Create TCP endpoints
|
||||
reqURL = "cli-json/add_endp"
|
||||
data = {
|
||||
"alias": "testTCP-A",
|
||||
"shelf": 1,
|
||||
"resource":resource,
|
||||
"port":sta_name,
|
||||
"resource": self.resource,
|
||||
"port": self.sta_name,
|
||||
"type": "lf_tcp",
|
||||
"ip_port": "0",
|
||||
"min_rate": 1000000
|
||||
}
|
||||
jsonReq(mgrURL, reqURL, data)
|
||||
super().jsonPost(reqURL, data)
|
||||
|
||||
reqURL = "cli-json/add_endp"
|
||||
data = {
|
||||
"alias": "testTCP-B",
|
||||
"shelf": 1,
|
||||
"resource":upstream_resource,
|
||||
"port":upstream_port,
|
||||
"resource": self.upstream_resource,
|
||||
"port": self.upstream_port,
|
||||
"type": "lf_tcp",
|
||||
"ip_port": "-1",
|
||||
"min_rate": 1000000
|
||||
}
|
||||
jsonReq(mgrURL, reqURL, data)
|
||||
super().jsonPost(reqURL, data)
|
||||
|
||||
# Create CX
|
||||
reqURL = "cli-json/add_cx"
|
||||
@@ -295,7 +230,7 @@ data = {
|
||||
"tx_endp": "testTCP-A",
|
||||
"rx_endp": "testTCP-B",
|
||||
}
|
||||
jsonReq(mgrURL, reqURL, data)
|
||||
super().jsonPost(reqURL, data)
|
||||
|
||||
cxNames = ["testTCP", "testUDP"]
|
||||
endpNames = ["testTCP-A", "testTCP-B",
|
||||
@@ -310,7 +245,7 @@ for name in range(len(cxNames)):
|
||||
"cx_name": cxNames[name],
|
||||
"cx_state": "RUNNING"
|
||||
}
|
||||
jsonReq(mgrURL, reqURL, data)
|
||||
super().jsonPost(reqURL, data)
|
||||
|
||||
# Refresh stats
|
||||
print("\nRefresh CX stats")
|
||||
@@ -320,7 +255,7 @@ for name in range(len(cxNames)):
|
||||
"test_mgr": "ALL",
|
||||
"cross_connect": cxNames[name]
|
||||
}
|
||||
jsonReq(mgrURL, reqURL, data)
|
||||
super().jsonPost(reqURL, data)
|
||||
|
||||
# print("Sleeping for 15 seconds")
|
||||
time.sleep(15)
|
||||
@@ -334,7 +269,7 @@ for name in range(len(cxNames)):
|
||||
"cx_name": cxNames[name],
|
||||
"cx_state": "STOPPED"
|
||||
}
|
||||
jsonReq(mgrURL, reqURL, data)
|
||||
super().jsonPost(reqURL, data)
|
||||
|
||||
# Refresh stats
|
||||
print("\nRefresh CX stats")
|
||||
@@ -344,7 +279,7 @@ for name in range(len(cxNames)):
|
||||
"test_mgr": "ALL",
|
||||
"cross_connect": cxNames[name]
|
||||
}
|
||||
jsonReq(mgrURL, reqURL, data)
|
||||
super().jsonPost(reqURL, data)
|
||||
|
||||
# print("Sleeping for 5 seconds")
|
||||
time.sleep(5)
|
||||
@@ -352,19 +287,19 @@ time.sleep(5)
|
||||
# get data for endpoints JSON
|
||||
print("Collecting Data")
|
||||
try:
|
||||
ptestTCPA = getJsonInfo(mgrURL, "endp/testTCP-A?fields=tx+bytes,rx+bytes")
|
||||
ptestTCPA = super().jsonGet("endp/testTCP-A?fields=tx+bytes,rx+bytes")
|
||||
ptestTCPATX = ptestTCPA['endpoint']['tx bytes']
|
||||
ptestTCPARX = ptestTCPA['endpoint']['rx bytes']
|
||||
|
||||
ptestTCPB = getJsonInfo(mgrURL, "endp/testTCP-B?fields=tx+bytes,rx+bytes")
|
||||
ptestTCPB = super().jsonGet("endp/testTCP-B?fields=tx+bytes,rx+bytes")
|
||||
ptestTCPBTX = ptestTCPB['endpoint']['tx bytes']
|
||||
ptestTCPBRX = ptestTCPB['endpoint']['rx bytes']
|
||||
|
||||
ptestUDPA = getJsonInfo(mgrURL, "endp/testUDP-A?fields=tx+bytes,rx+bytes")
|
||||
ptestUDPA = super().jsonGet("endp/testUDP-A?fields=tx+bytes,rx+bytes")
|
||||
ptestUDPATX = ptestUDPA['endpoint']['tx bytes']
|
||||
ptestUDPARX = ptestUDPA['endpoint']['rx bytes']
|
||||
|
||||
ptestUDPB = getJsonInfo(mgrURL, "endp/testUDP-B?fields=tx+bytes,rx+bytes")
|
||||
ptestUDPB = super().jsonGet("endp/testUDP-B?fields=tx+bytes,rx+bytes")
|
||||
ptestUDPBTX = ptestUDPB['endpoint']['tx bytes']
|
||||
ptestUDPBRX = ptestUDPB['endpoint']['rx bytes']
|
||||
except Exception as e:
|
||||
@@ -374,43 +309,98 @@ except Exception as e:
|
||||
reqURL = "cli-json/rm_vlan"
|
||||
data = {
|
||||
"shelf": 1,
|
||||
"resource":resource,
|
||||
"port":sta_name
|
||||
"resource": self.resource,
|
||||
"port": self.sta_name
|
||||
}
|
||||
|
||||
jsonReq(mgrURL, reqURL, data)
|
||||
self.jsonPost(reqURL, data)
|
||||
|
||||
removeCX(mgrURL, cxNames)
|
||||
removeEndps(mgrURL, endpNames)
|
||||
removeCX(self.mgr_url, cxNames)
|
||||
removeEndps(self.mgr_url, endpNames)
|
||||
sys.exit(1)
|
||||
|
||||
#compare pre-test values to post-test values
|
||||
|
||||
def compareVals(name, postVal):
|
||||
#print(f"Comparing {name}")
|
||||
if postVal > 0:
|
||||
print("PASSED: %s %s"%(name, postVal))
|
||||
else:
|
||||
print("FAILED: %s did not report traffic: %s"%(name, postVal))
|
||||
|
||||
print("\n")
|
||||
compareVals("testTCP-A TX", ptestTCPATX)
|
||||
compareVals("testTCP-A RX", ptestTCPARX)
|
||||
self.compareVals("testTCP-A TX", ptestTCPATX)
|
||||
self.compareVals("testTCP-A RX", ptestTCPARX)
|
||||
|
||||
compareVals("testTCP-B TX", ptestTCPBTX)
|
||||
compareVals("testTCP-B RX", ptestTCPBRX)
|
||||
self.compareVals("testTCP-B TX", ptestTCPBTX)
|
||||
self.compareVals("testTCP-B RX", ptestTCPBRX)
|
||||
|
||||
compareVals("testUDP-A TX", ptestUDPATX)
|
||||
compareVals("testUDP-A RX", ptestUDPARX)
|
||||
self.compareVals("testUDP-A TX", ptestUDPATX)
|
||||
self.compareVals("testUDP-A RX", ptestUDPARX)
|
||||
|
||||
compareVals("testUDP-B TX", ptestUDPBTX)
|
||||
compareVals("testUDP-B RX", ptestUDPBRX)
|
||||
self.compareVals("testUDP-B TX", ptestUDPBTX)
|
||||
self.compareVals("testUDP-B RX", ptestUDPBRX)
|
||||
print("\n")
|
||||
|
||||
|
||||
|
||||
# remove all endpoints and cxs
|
||||
LFUtils.removePort(resource, sta_name, mgrURL)
|
||||
LFUtils.removePort(self.resource, self.sta_name, self.mgr_url)
|
||||
|
||||
removeCX(mgrURL, cxNames)
|
||||
removeEndps(mgrURL, endpNames)
|
||||
removeCX(self.mgr_url, cxNames)
|
||||
removeEndps(self.mgr_url, endpNames)
|
||||
|
||||
# ~class
|
||||
|
||||
|
||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
|
||||
|
||||
def main():
|
||||
lfjson_host = "localhost"
|
||||
lfjson_port = 8080
|
||||
parser = argparse.ArgumentParser(
|
||||
description="""LANforge Unit Test: Connect Station to AP
|
||||
Example:
|
||||
./sta_connect.py --dest 192.168.100.209 --dut_ssid OpenWrt-2 --dut_bssid 24:F5:A2:08:21:6C
|
||||
""")
|
||||
parser.add_argument("-d", "--dest", type=str, help="address of the LANforge GUI machine (localhost is default)")
|
||||
parser.add_argument("-o", "--port", type=int, help="IP Port the LANforge GUI is listening on (8080 is default)")
|
||||
parser.add_argument("-u", "--user", type=str, help="TBD: credential login/username")
|
||||
parser.add_argument("-p", "--passwd", type=str, help="TBD: credential password")
|
||||
parser.add_argument("--resource", type=str, help="LANforge Station resource ID to use, default is 1")
|
||||
parser.add_argument("--upstream_resource", type=str, help="LANforge Ethernet port resource ID to use, default is 1")
|
||||
parser.add_argument("--upstream_port", type=str, help="LANforge Ethernet port name, default is eth2")
|
||||
parser.add_argument("--radio", type=str, help="LANforge radio to use, default is wiphy0")
|
||||
parser.add_argument("--sta_mode", type=str,
|
||||
help="LANforge station-mode setting (see add_sta LANforge CLI documentation, default is 0 (auto))")
|
||||
parser.add_argument("--dut_ssid", type=str, help="DUT SSID")
|
||||
parser.add_argument("--dut_passwd", type=str, help="DUT PSK password. Do not set for OPEN auth")
|
||||
parser.add_argument("--dut_bssid", type=str, help="DUT BSSID to which we expect to connect.")
|
||||
|
||||
args = parser.parse_args()
|
||||
if args.dest is not None:
|
||||
lfjson_host = args.dest
|
||||
if args.port is not None:
|
||||
lfjson_port = args.port
|
||||
|
||||
staConnect = StaConnect(lfjson_host, lfjson_port)
|
||||
|
||||
if args.user is not None:
|
||||
staConnect.user = args.user
|
||||
if args.passwd is not None:
|
||||
staConnect.passwd = args.passwd
|
||||
if args.sta_mode is not None:
|
||||
staConnect.sta_mode = args.sta_mode
|
||||
if args.upstream_resource is not None:
|
||||
staConnect.upstream_resource = args.upstream_resource
|
||||
if args.upstream_port is not None:
|
||||
staConnect.upstream_port = args.upstream_port
|
||||
if args.radio is not None:
|
||||
staConnect.radio = args.radio
|
||||
if args.resource is not None:
|
||||
staConnect.resource = args.resource
|
||||
if args.dut_passwd is not None:
|
||||
staConnect.dut_passwd = args.dut_passwd
|
||||
if args.dut_bssid is not None:
|
||||
staConnect.dut_bssid = args.dut_bssid
|
||||
if args.dut_ssid is not None:
|
||||
staConnect.dut_ssid = args.dut_ssid
|
||||
|
||||
staConnect.run()
|
||||
|
||||
|
||||
# - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
||||
|
||||
Reference in New Issue
Block a user