from core.experience import Experience, ExperienceParameter import os class HTTPS(Experience): NAME = "https" SERVER_LOG = "https_server.log" CLIENT_LOG = "https_client.log" WGET_BIN = "wget" PING_OUTPUT = "ping.log" def __init__(self, experience_parameter, topo, topo_config): super(HTTPS, self).__init__(experience_parameter, topo, topo_config) self.loadParam() self.ping() super(HTTPS, self).classic_run() def ping(self): self.topo.command_to(self.topo_config.client, "rm " + \ HTTPS.PING_OUTPUT ) count = self.experience_parameter.get(ExperienceParameter.PINGCOUNT) for i in range(0, self.topo_config.getClientInterfaceCount()): cmd = self.pingCommand(self.topo_config.getClientIP(i), self.topo_config.getServerIP(), n = count) self.topo.command_to(self.topo_config.client, cmd) def pingCommand(self, fromIP, toIP, n=5): s = "ping -c " + str(n) + " -I " + fromIP + " " + toIP + \ " >> " + HTTPS.PING_OUTPUT print(s) return s def loadParam(self): self.file = self.experience_parameter.get(ExperienceParameter.HTTPSFILE) self.random_size = self.experience_parameter.get(ExperienceParameter.HTTPSRANDOMSIZE) def prepare(self): super(HTTPS, self).prepare() self.topo.command_to(self.topo_config.client, "rm " + \ HTTPS.CLIENT_LOG ) self.topo.command_to(self.topo_config.server, "rm " + \ HTTPS.SERVER_LOG ) if self.file == "random": self.topo.command_to(self.topo_config.client, "dd if=/dev/urandom of=random bs=1K count=" + \ self.random_size) def getHTTPSServerCmd(self): s = "python {}/../utils/https_server.py {}/../utils/server.pem &> {}&".format(os.path.dirname(os.path.abspath(__file__)), os.path.dirname(os.path.abspath(__file__)), HTTPS.SERVER_LOG) print(s) return s def getHTTPSClientCmd(self): s = "(time " + HTTPS.WGET_BIN + " https://" + self.topo_config.getServerIP() + \ "/" + self.file + " --no-check-certificate) &>" + HTTPS.CLIENT_LOG print(s) return s def clean(self): super(HTTPS, self).clean() if self.file == "random": self.topo.command_to(self.topo_config.client, "rm random*") def run(self): cmd = self.getHTTPSServerCmd() self.topo.command_to(self.topo_config.server, "netstat -sn > netstat_server_before") self.topo.command_to(self.topo_config.server, cmd) print("Waiting for the server to run") self.topo.command_to(self.topo_config.client, "sleep 15") cmd = self.getHTTPSClientCmd() self.topo.command_to(self.topo_config.client, "netstat -sn > netstat_client_before") self.topo.command_to(self.topo_config.client, cmd) self.topo.command_to(self.topo_config.server, "netstat -sn > netstat_server_after") self.topo.command_to(self.topo_config.client, "netstat -sn > netstat_client_after") self.topo.command_to(self.topo_config.server, "pkill -f https_server.py") self.topo.command_to(self.topo_config.client, "sleep 2")