2014-08-24 22:51:19 +02:00
|
|
|
#!/usr/bin/python2
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
# Copyright (C) 2014 Philipp Rosenkranz <philipp.rosenkranz@fu-berlin.de>
|
|
|
|
#
|
|
|
|
# This library is free software; you can redistribute it and/or
|
|
|
|
# modify it under the terms of the GNU Lesser General Public
|
|
|
|
# License as published by the Free Software Foundation; either
|
|
|
|
# version 2.1 of the License, or (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This library is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
# Lesser General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU Lesser General Public
|
|
|
|
# License along with this library; if not, write to the Free Software
|
|
|
|
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
|
|
|
# 02110-1301 USA
|
|
|
|
|
|
|
|
|
|
|
|
import os, re, datetime
|
|
|
|
from subprocess import call, Popen, PIPE
|
|
|
|
|
|
|
|
|
|
|
|
class Testbed():
|
|
|
|
log_dir_name = 'log'
|
2015-05-09 09:00:36 +02:00
|
|
|
|
2014-08-24 22:51:19 +02:00
|
|
|
def __init__(self):
|
|
|
|
pass
|
2015-05-09 09:00:36 +02:00
|
|
|
|
2014-08-24 22:51:19 +02:00
|
|
|
def initCleanWithFlash(self):
|
|
|
|
self.stop()
|
|
|
|
self.cleanLogs()
|
|
|
|
self.flashNodes()
|
|
|
|
self.start()
|
2015-05-09 09:00:36 +02:00
|
|
|
|
2014-08-24 22:51:19 +02:00
|
|
|
def initClean(self):
|
|
|
|
self.cleanLogs()
|
|
|
|
self.start()
|
2015-05-09 09:00:36 +02:00
|
|
|
|
2014-08-24 22:51:19 +02:00
|
|
|
def flashNodes(self):
|
2015-05-09 09:00:36 +02:00
|
|
|
raise NotImplementedError("Inherit from Testbed and implement flashNodes")
|
|
|
|
|
2014-08-24 22:51:19 +02:00
|
|
|
def cleanLogs(self):
|
2015-05-09 09:00:36 +02:00
|
|
|
raise NotImplementedError("Inherit from Testbed and implement flashNodes")
|
|
|
|
|
2014-08-24 22:51:19 +02:00
|
|
|
def archiveLogs(self, experiment = None):
|
2015-05-09 09:00:36 +02:00
|
|
|
raise NotImplementedError("Inherit from Testbed and implement flashNodes")
|
|
|
|
|
2014-08-24 22:51:19 +02:00
|
|
|
def start(self):
|
2015-05-09 09:00:36 +02:00
|
|
|
raise NotImplementedError("Inherit from Testbed and implement flashNodes")
|
|
|
|
|
2014-08-24 22:51:19 +02:00
|
|
|
def stop(self):
|
2015-05-09 09:00:36 +02:00
|
|
|
raise NotImplementedError("Inherit from Testbed and implement flashNodes")
|
|
|
|
|
2014-08-24 22:51:19 +02:00
|
|
|
def defaultArchivePostfix(self, experimentName = None):
|
|
|
|
if not experimentName:
|
|
|
|
experimentName = "unknown"
|
|
|
|
time = datetime.datetime.now().strftime("%Y-%m-%d_%H_%M_%S")
|
2015-05-09 09:00:36 +02:00
|
|
|
postfix = "-" + experimentName +"_" + time
|
|
|
|
return postfix
|
|
|
|
|
2014-08-24 22:51:19 +02:00
|
|
|
def printAndCall(self, cmdString):
|
2015-05-09 09:00:36 +02:00
|
|
|
print(cmdString)
|
|
|
|
call(cmdString, shell=True)
|
|
|
|
|
|
|
|
|
|
|
|
class DESTestbed(Testbed):
|
|
|
|
def __init__(self, serverHost = None, serverPort=None, userName = None, flasher = None,
|
2014-08-24 22:51:19 +02:00
|
|
|
hexfilePath = None, pyterm = None, logFilePath = None, hostFile = None):
|
|
|
|
self.serverHost = serverHost
|
|
|
|
self.serverPort = str(serverPort)
|
|
|
|
self.userName = userName
|
|
|
|
self.flasher = flasher
|
|
|
|
self.hexFilePath = hexfilePath
|
|
|
|
self.pyterm = pyterm
|
|
|
|
self.logFilePath = logFilePath
|
|
|
|
self.hostFile = hostFile
|
2015-05-09 09:00:36 +02:00
|
|
|
|
|
|
|
def flashNodes(self):
|
2014-08-24 22:51:19 +02:00
|
|
|
self.printAndCall("parallel-ssh -h %s -l %s 'python %s'" % (self.hostFile, self.userName, self.flasher))
|
2015-05-09 09:00:36 +02:00
|
|
|
|
|
|
|
def cleanLogs(self):
|
2014-08-24 22:51:19 +02:00
|
|
|
self.printAndCall("rm -rf %s/*.log" % (self.logFilePath))
|
2015-05-09 09:00:36 +02:00
|
|
|
|
|
|
|
def archiveLogs(self, postfix = None):
|
2014-08-24 22:51:19 +02:00
|
|
|
postfix = self.defaultArchivePostfix(postfix)
|
|
|
|
logDir = self.logFilePath.split("/")[-1]
|
|
|
|
self.printAndCall("cd %s/..; tar -cjf archived_logs%s.tar.bz2 %s/*.log" % (self.logFilePath, postfix, logDir))
|
2015-05-09 09:00:36 +02:00
|
|
|
|
|
|
|
def start(self):
|
2014-08-24 22:51:19 +02:00
|
|
|
self.printAndCall("parallel-ssh -h %s -l %s 'screen -S pyterm -d -m python %s -ln %s'" % (self.hostFile, self.userName, self.pyterm, self.log_dir_name))
|
2015-05-09 09:00:36 +02:00
|
|
|
|
|
|
|
def stop(self):
|
2014-08-24 22:51:19 +02:00
|
|
|
self.printAndCall("parallel-ssh -h %s -l %s 'screen -X -S pyterm quit'" % (self.hostFile, self.userName))
|
2015-05-09 09:00:36 +02:00
|
|
|
|
|
|
|
class LocalTestbed(Testbed):
|
2014-08-24 22:51:19 +02:00
|
|
|
def __init__(self, serverHost = None, serverPort=None, flasher = None, hexfilePath = None, pyterm = None, logFilePath = None):
|
|
|
|
self.serverHost = serverHost
|
|
|
|
self.serverPort = str(serverPort)
|
|
|
|
self.flasher = flasher
|
|
|
|
self.hexFilePath = hexfilePath
|
|
|
|
self.pyterm = pyterm
|
|
|
|
self.logFilePath = logFilePath
|
2015-05-09 09:00:36 +02:00
|
|
|
|
2014-08-24 22:51:19 +02:00
|
|
|
def findPorts(self):
|
2015-05-09 09:00:36 +02:00
|
|
|
devlist = os.listdir("/dev/")
|
|
|
|
regex = re.compile('^ttyUSB')
|
2014-08-24 22:51:19 +02:00
|
|
|
return sorted([port for port in devlist if regex.match(port)])
|
|
|
|
|
2015-05-09 09:00:36 +02:00
|
|
|
def flashNodes(self):
|
2014-08-24 22:51:19 +02:00
|
|
|
self.printAndCall("python %s %s" % (self.flasher, self.hexFilePath))
|
2015-05-09 09:00:36 +02:00
|
|
|
|
|
|
|
def cleanLogs(self):
|
2014-08-24 22:51:19 +02:00
|
|
|
self.printAndCall("rm -rf %s/*.log" % (self.logFilePath))
|
2015-05-09 09:00:36 +02:00
|
|
|
|
|
|
|
def archiveLogs(self, postfix = None):
|
2014-08-24 22:51:19 +02:00
|
|
|
postfix = self.defaultArchivePostfix(postfix)
|
|
|
|
logDir = self.logFilePath.split("/")[-1]
|
|
|
|
self.printAndCall("cd %s/..; tar -cjf archived_logs%s.tar.bz2 %s/*.log" % (self.logFilePath, postfix, logDir))
|
2015-05-09 09:00:36 +02:00
|
|
|
|
2014-08-24 22:51:19 +02:00
|
|
|
def start(self):
|
|
|
|
portList = self.findPorts()
|
2015-05-09 09:00:36 +02:00
|
|
|
for port in portList:
|
2014-08-24 22:51:19 +02:00
|
|
|
self.printAndCall("screen -S pyterm-%s -d -m python %s -H %s -rn %s -p /dev/%s -ln %s" % (port, self.pyterm, port, port, port, self.log_dir_name))
|
2015-05-09 09:00:36 +02:00
|
|
|
|
2014-08-24 22:51:19 +02:00
|
|
|
def stop(self):
|
|
|
|
portList = self.findPorts()
|
2015-05-09 09:00:36 +02:00
|
|
|
for port in portList:
|
2014-08-24 22:51:19 +02:00
|
|
|
self.printAndCall("screen -X -S pyterm-%s quit" % (port))
|
2015-05-09 09:00:36 +02:00
|
|
|
|
|
|
|
class DesVirtTestbed(Testbed):
|
2014-08-24 22:51:19 +02:00
|
|
|
def __init__(self, serverHost = None, serverPort=None, desvirtPath = None, topologyName = None, pyterm = None, logFilePath = None):
|
|
|
|
self.serverHost = serverHost
|
|
|
|
self.serverPort = str(serverPort)
|
|
|
|
self.desvirtPath = desvirtPath
|
|
|
|
self.topologyName = topologyName
|
|
|
|
self.pyterm = pyterm
|
|
|
|
self.logFilePath = logFilePath
|
|
|
|
self.namePortList = []
|
2015-05-09 09:00:36 +02:00
|
|
|
|
|
|
|
def findPorts(self):
|
2014-08-24 22:51:19 +02:00
|
|
|
return self.namePortList
|
2015-05-09 09:00:36 +02:00
|
|
|
|
2014-08-24 22:51:19 +02:00
|
|
|
def startDesVirtNetwork(self):
|
|
|
|
print "executing: " + "./vnet --start --name " + self.topologyName + " in: " + self.desvirtPath
|
|
|
|
call("sh -c \"./vnet --define --name " + self.topologyName + "\"", cwd=self.desvirtPath, shell=True)
|
|
|
|
stream = Popen("sh -c \"./vnet --start --name " + self.topologyName + "\"", cwd=self.desvirtPath, shell=True, stderr=PIPE).stderr
|
|
|
|
pats = r'.*riotnative.*\.elf (\S+) -t (\S+)'
|
|
|
|
pattern = re.compile(pats)
|
|
|
|
for line in stream:
|
|
|
|
match = pattern.match(line)
|
|
|
|
if(match):
|
|
|
|
tuple = match.groups()
|
|
|
|
self.namePortList.append((tuple[0], int(tuple[1])))
|
|
|
|
self.namePortList = sorted(self.namePortList)
|
|
|
|
for tuple in self.namePortList:
|
|
|
|
print "name: " + tuple[0] + " port: " + str(tuple[1])
|
2015-05-09 09:00:36 +02:00
|
|
|
|
2014-08-24 22:51:19 +02:00
|
|
|
def stopDesVirtNetwork(self):
|
2015-05-09 09:00:36 +02:00
|
|
|
call("sh -c \"./vnet --stop --name " + self.topologyName + "\"", cwd=self.desvirtPath, shell=True)
|
2014-08-24 22:51:19 +02:00
|
|
|
|
2015-05-09 09:00:36 +02:00
|
|
|
def flashNodes(self):
|
2014-08-24 22:51:19 +02:00
|
|
|
pass
|
2015-05-09 09:00:36 +02:00
|
|
|
|
|
|
|
def cleanLogs(self):
|
2014-08-24 22:51:19 +02:00
|
|
|
self.printAndCall("rm -rf %s/*.log" % (self.logFilePath))
|
2015-05-09 09:00:36 +02:00
|
|
|
|
|
|
|
def archiveLogs(self, postfix = None):
|
2014-08-24 22:51:19 +02:00
|
|
|
postfix = self.defaultArchivePostfix(postfix)
|
|
|
|
logDir = self.logFilePath.split("/")[-1]
|
|
|
|
self.printAndCall("cd %s/..; tar -cjf archived_logs%s.tar.bz2 %s/*.log" % (self.logFilePath, postfix, logDir))
|
2015-05-09 09:00:36 +02:00
|
|
|
|
2014-08-24 22:51:19 +02:00
|
|
|
def start(self):
|
2015-05-09 09:00:36 +02:00
|
|
|
for node in self.namePortList:
|
2014-08-24 22:51:19 +02:00
|
|
|
self.printAndCall("screen -S pyterm-%s -d -m python %s -H %s -rn %s -ts %s -ln %s" % (node[0], self.pyterm, node[0], node[0], node[1], self.log_dir_name))
|
2015-05-09 09:00:36 +02:00
|
|
|
|
2014-08-24 22:51:19 +02:00
|
|
|
def stop(self):
|
|
|
|
print "stop called"
|
2015-05-09 09:00:36 +02:00
|
|
|
for node in self.namePortList:
|
2014-08-24 22:51:19 +02:00
|
|
|
self.printAndCall("screen -X -S pyterm-%s quit" % (node[0]))
|
|
|
|
self.stopDesVirtNetwork()
|