|  | #!/usr/bin/env python | 
|  | # Copyright 2015 The Chromium Authors. All rights reserved. | 
|  | # Use of this source code is governed by a BSD-style license that can be | 
|  | # found in the LICENSE file. | 
|  |  | 
|  | """A simple host test module. | 
|  |  | 
|  | This module runs on the host machine and is responsible for creating 2 | 
|  | client machines, waiting for them, and running RPC calls on them. | 
|  | """ | 
|  |  | 
|  | # Map the legion directory so we can import the host controller. | 
|  | import sys | 
|  | sys.path.append('../../') | 
|  |  | 
|  | import logging | 
|  | import time | 
|  |  | 
|  | import host_controller | 
|  |  | 
|  |  | 
|  | class ExampleController(host_controller.HostController): | 
|  | """A simple example controller for a test.""" | 
|  |  | 
|  | def __init__(self): | 
|  | super(ExampleController, self).__init__() | 
|  | self.client1 = None | 
|  | self.client2 = None | 
|  |  | 
|  | def CreateClient(self): | 
|  | """Create a client object and set the proper values.""" | 
|  | client = self.NewClient( | 
|  | isolate_file='client_test.isolate', | 
|  | config_vars={'multi_machine': '1'}, | 
|  | dimensions={'os': 'legion-linux'}, priority=200, | 
|  | idle_timeout_secs=90, connection_timeout_secs=90, | 
|  | verbosity=logging.INFO) | 
|  | client.Create() | 
|  | return client | 
|  |  | 
|  | def SetUp(self): | 
|  | """Create the client machines and wait until they connect. | 
|  |  | 
|  | In this call the actual creation of the client machines is done in parallel | 
|  | by the system. The WaitForConnect calls are performed in series but will | 
|  | return as soon as the clients connect. | 
|  | """ | 
|  | self.client1 = self.CreateClient() | 
|  | self.client2 = self.CreateClient() | 
|  | self.client1.WaitForConnection() | 
|  | self.client2.WaitForConnection() | 
|  |  | 
|  | def Task(self): | 
|  | """Main method to run the task code.""" | 
|  | self.CallEcho(self.client1) | 
|  | self.CallEcho(self.client2) | 
|  | self.CallClientTest(self.client1) | 
|  | self.CallClientTest(self.client2) | 
|  |  | 
|  | def CallEcho(self, client): | 
|  | """Call rpc.Echo on a client.""" | 
|  | logging.info('Calling Echo on %s', client.name) | 
|  | logging.info(client.rpc.Echo(client.name)) | 
|  |  | 
|  | def CallClientTest(self, client): | 
|  | """Call client_test.py name on a client.""" | 
|  | logging.info('Calling Subprocess to run "./client_test.py %s"', client.name) | 
|  | proc = client.rpc.subprocess.Popen(['./client_test.py', client.name]) | 
|  | client.rpc.subprocess.Wait(proc) | 
|  | retcode = client.rpc.subprocess.GetReturncode(proc) | 
|  | stdout = client.rpc.subprocess.ReadStdout(proc) | 
|  | stderr = client.rpc.subprocess.ReadStderr(proc) | 
|  | logging.info('retcode: %s, stdout: %s, stderr: %s', retcode, stdout, stderr) | 
|  |  | 
|  |  | 
|  | if __name__ == '__main__': | 
|  | ExampleController().RunController() |