# Copyright (c) 2013 The Chromium OS Authors. All rights reserved. # Use of this source code is governed by a BSD-style license that can be # found in the LICENSE file. import logging from autotest_lib.client.common_lib import error from autotest_lib.client.common_lib import utils from autotest_lib.server.cros import host_lock_manager from autotest_lib.server.cros import sonic_client_utils AUTHOR = "Chrome OS Team" NAME = "sonic_AppTest" PURPOSE = "Demonstrate the ability to start the chromecast app." CRITERIA = "This test will fail if the app fails to start." TIME = "SHORT" TEST_CATEGORY = "General" TEST_CLASS = "sonic" TEST_TYPE = "server" DOC = """ This is a sonic test that will cast a tab. Tab cast is achieved through desktopui_SonicExtension, which is a client test that handles all the extension manipulation necessary to talk to the sonic device. Note that the sonic host and the DUT need to be on the same subnet. Usage: test_that <ip of Cros DUT> --board=<boardname of DUT> --args="sonic_hostname=<ip of sonichost>" """ args_dict = utils.args_to_dict(args) def run(machine): extension_dir = args_dict.get('extension_dir') lock_manager = host_lock_manager.HostLockManager() # If the hostname of a sonic device to use with this test # is passed through --args, just try to lock it, otherwise # look for an unlocked host with the sonic label. The context # manager handles unlocking hosts locked through the lock_manager. with host_lock_manager.HostsLockedBy(lock_manager): sonic_hostname = args_dict.get('sonic_hostname') if sonic_hostname: lock_manager.lock([sonic_hostname]) else: sonic_hostname = sonic_client_utils.acquire_sonic(lock_manager) logging.info('Using sonic host: %s', sonic_hostname) cros_host = hosts.create_host(machine) sonic_host = hosts.create_host(sonic_hostname) job.run_test('sonic_AppTest', cros_host=cros_host, sonic_host=sonic_host, extension_dir=extension_dir, disable_sysinfo=True) parallel_simple(run, machines)