1# Copyright (c) 2013 The Chromium OS Authors. All rights reserved. 2# Use of this source code is governed by a BSD-style license that can be 3# found in the LICENSE file. 4 5import gobject 6from dbus.mainloop.glib import DBusGMainLoop 7 8from autotest_lib.client.bin import test 9from autotest_lib.client.common_lib.cros import chrome, session_manager 10from autotest_lib.client.cros import asan 11 12 13class login_LoginSuccess(test.test): 14 """Sign in using Telemetry and validate system state.""" 15 version = 1 16 17 _SESSION_START_TIMEOUT = 10 18 _SESSION_STOP_TIMEOUT = 60 19 # TODO(afakhry): Remove this timeout increase for asan bots once we figure 20 # out why logging out is taking so long. See crbug.com/488291 21 if asan.running_on_asan(): 22 _SESSION_STOP_TIMEOUT *= 2 23 24 25 def initialize(self): 26 super(login_LoginSuccess, self).initialize() 27 28 bus_loop = DBusGMainLoop(set_as_default=True) 29 self._session_manager = session_manager.connect(bus_loop) 30 self._listener = session_manager.SessionSignalListener( 31 gobject.MainLoop()) 32 33 34 def run_once(self, stress_run=False, arc_mode=None): 35 """ 36 Runs the test. 37 38 @param stress_run: True if we are doing a stress run and want to 39 double the timeout. 40 @param arc_mode: This value is passed to Chrome and determines how 41 the ARC/Android instance should start. Possible values 42 are defined in common_lib/cros/arc_common.py. 43 44 """ 45 if stress_run: 46 self._SESSION_STOP_TIMEOUT *= 2 47 self._listener.listen_for_session_state_change('started') 48 with chrome.Chrome(arc_mode=arc_mode): 49 self._listener.wait_for_signals(desc='Session started.', 50 timeout=self._SESSION_START_TIMEOUT) 51 # To enable use as a 'helper test'. 52 self.job.set_state('client_success', True) 53 54 # Start listening to stop signal before logging out. 55 self._listener.listen_for_session_state_change('stopped') 56 57 self._listener.wait_for_signals(desc='Session stopped.', 58 timeout=self._SESSION_STOP_TIMEOUT) 59