mirror of
https://github.com/Telecominfraproject/wlan-lanforge-scripts.git
synced 2025-11-03 12:18:00 +00:00
- test_wanlink.py may now run with optional transfer-rate arguments:
* as together endpoints: --rate, the value of wanlink transfer rate of both endpoints in bits/sec. * as separate endpoints: --rate_A and/or --rate_B which default to the value of --rate. * the default value of --rate is 1000000 (1Gbps) Signed-off-by: Erin Grimes <erin.grimes@candelatech.com>
This commit is contained in:
@@ -17,7 +17,7 @@ from LANforge import LFUtils
|
|||||||
from LANforge.LFUtils import NA
|
from LANforge.LFUtils import NA
|
||||||
|
|
||||||
j_printer = pprint.PrettyPrinter(indent=2)
|
j_printer = pprint.PrettyPrinter(indent=2)
|
||||||
# typically you're using resource 1 in stand alone realm
|
# todo: this needs to change
|
||||||
resource_id = 1
|
resource_id = 1
|
||||||
|
|
||||||
def main(base_url="http://localhost:8080", args={}):
|
def main(base_url="http://localhost:8080", args={}):
|
||||||
@@ -69,13 +69,12 @@ def main(base_url="http://localhost:8080", args={}):
|
|||||||
# create wanlink 1a
|
# create wanlink 1a
|
||||||
lf_r = LFRequest.LFRequest(base_url+"/cli-json/add_wl_endp")
|
lf_r = LFRequest.LFRequest(base_url+"/cli-json/add_wl_endp")
|
||||||
lf_r.addPostData({
|
lf_r.addPostData({
|
||||||
'alias': 'wl_eg1-A',
|
'alias': 'wl_eg1-A',
|
||||||
'shelf': 1,
|
'shelf': 1,
|
||||||
'resource': '1',
|
'resource': '1',
|
||||||
'port': port_a,
|
'port': port_a,
|
||||||
'latency': args['latency_A'],
|
'latency': args['latency_A'],
|
||||||
'max_rate': '128000',
|
'max_rate': args['rate_A']
|
||||||
'description': 'cookbook-example'
|
|
||||||
})
|
})
|
||||||
lf_r.jsonPost()
|
lf_r.jsonPost()
|
||||||
sleep(0.05)
|
sleep(0.05)
|
||||||
@@ -83,13 +82,12 @@ def main(base_url="http://localhost:8080", args={}):
|
|||||||
# create wanlink 1b
|
# create wanlink 1b
|
||||||
lf_r = LFRequest.LFRequest(base_url+"/cli-json/add_wl_endp")
|
lf_r = LFRequest.LFRequest(base_url+"/cli-json/add_wl_endp")
|
||||||
lf_r.addPostData({
|
lf_r.addPostData({
|
||||||
'alias': 'wl_eg1-B',
|
'alias': 'wl_eg1-B',
|
||||||
'shelf': 1,
|
'shelf': 1,
|
||||||
'resource': '1',
|
'resource': '1',
|
||||||
'port': port_b,
|
'port': port_b,
|
||||||
'latency': args['latency_B'],
|
'latency': args['latency_B'],
|
||||||
'max_rate': '256000',
|
'max_rate': args['rate_B']
|
||||||
'description': 'cookbook-example'
|
|
||||||
})
|
})
|
||||||
lf_r.jsonPost()
|
lf_r.jsonPost()
|
||||||
sleep(0.05)
|
sleep(0.05)
|
||||||
|
|||||||
@@ -21,14 +21,14 @@ class LANtoWAN(Realm):
|
|||||||
self.args = args
|
self.args = args
|
||||||
self.lan_port="eth2"
|
self.lan_port="eth2"
|
||||||
self.wan_port="eth3"
|
self.wan_port="eth3"
|
||||||
self.prefix='sta'
|
# self.prefix='sta'
|
||||||
self.number_template="00000"
|
# self.number_template="00000"
|
||||||
self.radio="wiphy0"
|
self.radio="wiphy0"
|
||||||
self.sta_list = []
|
# self.sta_list = []
|
||||||
self.side_a_min_rate=0
|
# self.side_a_min_rate=0
|
||||||
self.side_a_max_rate=56
|
# self.side_a_max_rate=56
|
||||||
self.side_b_min_rate=0
|
# self.side_b_min_rate=0
|
||||||
self.side_b_max_rate=56
|
# self.side_b_max_rate=56
|
||||||
self._debug_on=False
|
self._debug_on=False
|
||||||
self._exit_on_error=False
|
self._exit_on_error=False
|
||||||
self._exit_on_fail=False
|
self._exit_on_fail=False
|
||||||
@@ -65,7 +65,7 @@ class LANtoWAN(Realm):
|
|||||||
"resource": resource,
|
"resource": resource,
|
||||||
"port": "rd0a",
|
"port": "rd0a",
|
||||||
"latency": self.args['latency_A'],
|
"latency": self.args['latency_A'],
|
||||||
"max_rate": max_rate
|
"max_rate": self.args['rate_A']
|
||||||
}
|
}
|
||||||
self.json_post(url, data)
|
self.json_post(url, data)
|
||||||
|
|
||||||
@@ -76,7 +76,7 @@ class LANtoWAN(Realm):
|
|||||||
"resource": resource,
|
"resource": resource,
|
||||||
"port": "rd1a",
|
"port": "rd1a",
|
||||||
"latency": self.args['latency_B'],
|
"latency": self.args['latency_B'],
|
||||||
"max_rate": max_rate
|
"max_rate": self.args['rate_B']
|
||||||
}
|
}
|
||||||
self.json_post(url, data)
|
self.json_post(url, data)
|
||||||
create_wanlink.main('http://'+self.args['host']+':8080', self.args)
|
create_wanlink.main('http://'+self.args['host']+':8080', self.args)
|
||||||
@@ -100,11 +100,14 @@ def main():
|
|||||||
if optional_args is not None:
|
if optional_args is not None:
|
||||||
# optional_args.add_argument('--lanport', help='Select the port you want for lanport', default='wiphy0')
|
# optional_args.add_argument('--lanport', help='Select the port you want for lanport', default='wiphy0')
|
||||||
# optional_args.add_argument('--wanport', help='Select the port you want for wanport', default='wiphy1'
|
# optional_args.add_argument('--wanport', help='Select the port you want for wanport', default='wiphy1'
|
||||||
|
optional_args.add_argument('--rate', help='The maximum rate of transfer at both endpoints (bits/s)', default=1000000)
|
||||||
|
optional_args.add_argument('--rate_A', help='The max rate of transfer at endpoint A (bits/s)', default=None)
|
||||||
|
optional_args.add_argument('--rate_B', help='The maximum rate of transfer (bits/s)', default=None)
|
||||||
optional_args.add_argument('--latency', help='The delay of both ports', default=20)
|
optional_args.add_argument('--latency', help='The delay of both ports', default=20)
|
||||||
optional_args.add_argument('--latency_A', help='The delay of port A', default=None)
|
optional_args.add_argument('--latency_A', help='The delay of port A', default=None)
|
||||||
optional_args.add_argument('--latency_B', help='The delay of port B', default=None)
|
optional_args.add_argument('--latency_B', help='The delay of port B', default=None)
|
||||||
# todo: bandwidth
|
# todo: packet loss A and B
|
||||||
# todo: packet loss
|
# todo: jitter A and B
|
||||||
for group in parser._action_groups:
|
for group in parser._action_groups:
|
||||||
if group.title == "optional arguments":
|
if group.title == "optional arguments":
|
||||||
optional_args=group
|
optional_args=group
|
||||||
@@ -118,7 +121,10 @@ def main():
|
|||||||
"password": parseargs.passwd,
|
"password": parseargs.passwd,
|
||||||
"latency": parseargs.latency,
|
"latency": parseargs.latency,
|
||||||
"latency_A": (parseargs.latency_A if parseargs.latency_A is not None else parseargs.latency),
|
"latency_A": (parseargs.latency_A if parseargs.latency_A is not None else parseargs.latency),
|
||||||
"latency_B": (parseargs.latency_B if parseargs.latency_B is not None else parseargs.latency)
|
"latency_B": (parseargs.latency_B if parseargs.latency_B is not None else parseargs.latency),
|
||||||
|
"rate": (parseargs.rate),
|
||||||
|
"rate_A": (parseargs.rate_A if parseargs.rate_A is not None else parseargs.rate),
|
||||||
|
"rate_B": (parseargs.rate_B if parseargs.rate_B is not None else parseargs.rate)
|
||||||
}
|
}
|
||||||
ltw=LANtoWAN(args)
|
ltw=LANtoWAN(args)
|
||||||
ltw.create_wanlinks()
|
ltw.create_wanlinks()
|
||||||
|
|||||||
Reference in New Issue
Block a user