-# $Id$
+# Thierry Parmentelat <thierry.parmentelat@inria.fr>
+# Copyright (C) 2010 INRIA
+#
# this models a box that hosts qemu nodes
# could probably also be used for boxes that host plc instances
import os.path
import utils
from TestSsh import TestSsh
+# xxx this should probably inherit TestSsh
class TestBox:
def __init__(self,hostname,buildname,key=None):
def is_local(self):
return self.test_ssh.is_local()
- def tar_logs(self):
- if os.path.isdir("nodeslogs"):
- tar_command="tar cvf nodeslogs.tar nodeslogs/"
- self.run_in_buildname (tar_command)
- return True
- return False
-
- def run_in_buildname (self,command):
- utils.header("Running command %s on testbox %s"%(command,self.hostname()))
- return self.test_ssh.run_in_buildname (command)
+ def run_in_buildname (self,command,background=False):
+ message="On %s: running %s"%(self.hostname(),command)
+ if background: message += " &"
+ utils.header(message)
+ return self.test_ssh.run_in_buildname (command,background)
- # should use rsync instead
+ # xxx could/should use rsync instead
def copy (self,local_file,recursive=False):
return self.test_ssh.copy (local_file,recursive)
def clean_dir (self,dirname):
return self.test_ssh.clean_dir(dirname)
- def mkdir (self,direname):
- return self.test_ssh.mkdir(direname)
+ def mkdir (self,dirname):
+ return self.test_ssh.mkdir(dirname)
+
+ # we need at least one nodename, as template-qemu is not synced on remote testboxes
+ def qemu_kill_all(self,nodedir):
+ self.run_in_buildname("%s/qemu-kill-node"%nodedir)
+ return True
- def kill_all_qemus(self):
- self.run_in_buildname("killall qemu")
+ def qemu_list_all(self):
+ self.run_in_buildname("template-qemu/qemu-kill-node -l")
return True