Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(17)

Unified Diff: server/site_linux_router.py

Issue 1517016: Updated wifi tests to work with an OpenWrt router. (Closed)
Patch Set: Rev2 Created 10 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | server/site_wifitest.py » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: server/site_linux_router.py
diff --git a/server/site_linux_router.py b/server/site_linux_router.py
index 5af9c4cb1c63a91f3112699e1a057ccd88bd7db4..f3f5e38c953ff26f259d19a3b35c4b4f9f2a4c78 100644
--- a/server/site_linux_router.py
+++ b/server/site_linux_router.py
@@ -15,17 +15,32 @@ class LinuxRouter(object):
def __init__(self, host, params, defssid):
+ self.cmd_iw = "/usr/sbin/iw"
+ self.cmd_ip = "/usr/sbin/ip"
+ self.cmd_brctl = "/usr/sbin/brctl"
+ self.cmd_hostapd = "/usr/sbin/hostapd"
+
self.router = host
- # TODO(sleffler) default to 1st available wireless nic
- self.phydev = params['phydev']
- # TODO(sleffler) default to 1st available wired nic
- self.wiredif = params['wiredev']
+ # default to 1st available wireless nic
+ if "phydev" not in params:
+ output = self.router.run("%s list" % self.cmd_iw).stdout
+ wifitest = re.compile("Wiphy (.*)")
+ for line in output.splitlines():
+ m = wifitest.match(line)
+ if m:
+ self.phydev = m.group(1)
+ break
+ else:
+ raise Exception("No Wireless NIC detected on the device")
+ else:
+ self.phydev = params['phydev']
+
self.hostapd_conf = "/tmp/%s.conf" % self.phydev
+ self.hostapd_driver = "nl80211"
self.phytype = None
-
-
- def __isapmode(self):
- return self.phytype is None
+ self.bridgeif = params.get("bridgeif", "br-lan")
+ self.wlanif = "wlan0"
+ self.defssid = defssid;
def create(self, params):
@@ -36,84 +51,95 @@ class LinuxRouter(object):
# iw wants)
#
# map from bsd types to iw types
+ if params['type'] == "ap" or params['type'] == "hostap":
+ self.apmode = True
self.phytype = {
"sta" : "managed",
"monitor" : "monitor",
"adhoc" : "adhoc",
"ibss" : "ibss",
- "ap" : None, # NB: handled by hostapd
- "hostap" : None, # NB: handled by hostapd
+ "ap" : "managed", # NB: handled by hostapd
+ "hostap" : "managed", # NB: handled by hostapd
"mesh" : "mesh",
"wds" : "wds",
}[params['type']]
- if not __isapmode():
- phydev = params.get('phydev', self.phydev)
- self.router.run("iw phy %s interface add wlan0 type %s" %
- (phydev, self.phytype))
- self.wlanif = "wlan0" # XXX get wlanX device name back
-
- self.router.run("ifconfig bridge0 create addm %s addm %s" %
- (self.wlanif, self.wiredif))
- self.bridgeif = "bridge0"
+ phydev = params.get('phydev', self.phydev)
+ self.router.run("%s phy %s interface add %s type %s" %
+ (self.cmd_iw, phydev, self.wlanif, self.phytype))
def destroy(self, params):
""" Destroy a previously created device """
- if not __isapmode():
- self.router.run("iw dev %s del" % self.wlanif)
- self.router.run("ifconfig %s destroy" % self.bridgeif)
+ self.router.run("%s dev %s del" % (self.cmd_iw, self.wlanif))
def config(self, params):
""" Configure the AP per test requirements """
- if __isapmode():
+ if self.apmode:
# construct the hostapd.conf file and start hostapd
- hostapd_args = None
+ hostapd_args = ["interface=%s" % self.wlanif]
+ hostapd_args.append("bridge=%s" % self.bridgeif)
+ hostapd_args.append("driver=%s" %
+ params.get("hostapd_driver", self.hostapd_driver))
+ if 'ssid' not in params:
+ params['ssid'] = self.defssid
wmm = 0
htcaps = None
- for (k, v) in params.keys():
- if k == 'channel':
- # XXX map frequency to channe #?
- hostapd_args.append("channel=%s" % v)
+ for k, v in params.iteritems():
+ if k == 'ssid':
+ hostapd_args.append("ssid=%s" % v)
+ elif k == 'channel':
+ freq = int(v)
+ if freq >= 2412 and freq <= 2472:
+ chan = 1 + (freq - 2412) / 5
+ elif freq == 2484:
+ chan = 14
+ elif freq >= 4915 and freq <= 4980:
+ chan = 183 + (freq - 4915) / 5
+ elif freq >= 5035 and freq <= 5825:
+ chan = 7 + (freq - 5025) / 5
+ else:
+ chan = -1
+ hostapd_args.append("channel=%s" % chan)
elif k == 'country':
- hostapd_args.append("country_code=%s\n" % v)
+ hostapd_args.append("country_code=%s" % v)
elif k == 'dotd':
- hostapd_args.append("ieee80211d=1\n")
+ hostapd_args.append("ieee80211d=1")
elif k == '-dotd':
- hostapd_args.append("ieee80211d=0\n")
+ hostapd_args.append("ieee80211d=0")
elif k == 'mode':
if v == '11a':
- hostapd_args.append("hw_mode=a\n")
+ hostapd_args.append("hw_mode=a")
elif v == '11g':
- hostapd_args.append("hw_mode=g\n")
+ hostapd_args.append("hw_mode=g")
elif v == '11b':
- hostapd_args.append("hw_mode=b\n")
+ hostapd_args.append("hw_mode=b")
elif v == '11n':
- hostapd_args.append("ieee80211n=1\n")
+ hostapd_args.append("ieee80211n=1")
elif k == 'bintval':
- hostapd_args.append("beacon_int=%s\n" % v)
+ hostapd_args.append("beacon_int=%s" % v)
elif k == 'dtimperiod':
- hostapd_args.append("dtim_period=%s\n" % v)
+ hostapd_args.append("dtim_period=%s" % v)
elif k == 'rtsthreshold':
- hostapd_args.append("rts_threshold=%s\n" % v)
+ hostapd_args.append("rts_threshold=%s" % v)
elif k == 'fragthreshold':
- hostapd_args.append("fragm_threshold=%s\n" % v)
+ hostapd_args.append("fragm_threshold=%s" % v)
elif k == 'shortpreamble':
- hostapd_args.append("preamble=1\n")
+ hostapd_args.append("preamble=1")
elif k == 'authmode':
if v == 'open':
- hostapd_args.append("auth_algs=1\n")
+ hostapd_args.append("auth_algs=1")
elif v == 'shared':
- hostapd_args.append("auth_algs=2\n")
+ hostapd_args.append("auth_algs=2")
elif k == 'hidessid':
- hostapd_args.append("ignore_broadcast_ssid=1\n")
+ hostapd_args.append("ignore_broadcast_ssid=1")
elif k == 'wme':
wmm = 1;
elif k == '-wme':
wmm = 0;
elif k == 'deftxkey':
- hostapd_args.append("wep_default_key=%s\n" % v)
+ hostapd_args.append("wep_default_key=%s" % v)
elif k == 'ht20':
htcaps.append("")
wmm = 1;
@@ -124,31 +150,27 @@ class LinuxRouter(object):
elif k == 'shortgi':
htcaps.append("[SHORT-GI-20][SHORT-GI-40]")
else:
- hostapd_args.append("%s=%s\n" % (k, v))
+ hostapd_args.append("%s=%s" % (k, v))
if htcaps is not None:
- hostapd_args.append("ieee80211n=1\nht_capab=%s\n" % htcaps)
- hostapd_args.append("wmm_enable=%d\n" % wmm)
-
- self.router.run("cat <'EOF' >%s\n\
- interface=%s\n\
- bridge=%s\n\
- driver=nl80211\n\
- %s\n\
- EOF\n" % \
- (self.hostapd_conf, self.phydev, self.bridgeif, hostapd_args))
- self.router.run("hostapd -B %s" % self.hostapd_conf)
+ hostapd_args.append("ieee80211n=1")
+ hostapd_args.append("ht_capab=%s" % htcaps)
+ hostapd_args.append("wmm_enabled=%d" % wmm)
+
+ self.router.run("cat <<EOF >%s\n%s\nEOF\n" %
+ (self.hostapd_conf, "\n".join(hostapd_args)))
+ self.router.run("%s -B %s" %
+ (self.cmd_hostapd, self.hostapd_conf))
+
# else:
# # use iw to manually configure interface
- # finally bring the bridge up
- self.router.run("ifconfig %s up" % self.bridgeif)
def deconfig(self, params):
""" De-configure the AP (typically marks wlanif down) """
- self.router.run("ifconfig %s down" % self.wlanif)
+ self.router.run("%s link set %s down" % (self.cmd_ip, self.wlanif))
if self.hostapd_conf is not None:
self.router.run("pkill hostapd >/dev/null 2>&1")
self.router.run("rm -f %s" % self.hostapd_conf)
« no previous file with comments | « no previous file | server/site_wifitest.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698