# Copyright 2014 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 gobject, logging from dbus.exceptions import DBusException from dbus.mainloop.glib import DBusGMainLoop from autotest_lib.client.bin import test, utils from autotest_lib.client.common_lib import error from autotest_lib.client.common_lib.cros import chrome, session_manager from autotest_lib.client.cros import constants class desktopui_ExitOnSupervisedUserCrash(test.test): """Sign in, indicate that a supervised user is being created, then crash.""" version = 1 _SESSION_STOP_TIMEOUT = 60 def initialize(self): super(desktopui_ExitOnSupervisedUserCrash, self).initialize() def run_once(self): listener = session_manager.SessionSignalListener(gobject.MainLoop()) with chrome.Chrome(): sm = session_manager.connect(DBusGMainLoop(set_as_default=True)) # Tell session_manager that we're going all the way through # creating a supervised user. sm.HandleSupervisedUserCreationStarting() sm.HandleSupervisedUserCreationFinished() # Crashing the browser should not end the session, as creating the # user is finished. utils.nuke_process_by_name(constants.BROWSER) # We should still be able to talk to the session_manager, # and it should indicate that we're still inside a user session. try: state = sm.RetrieveSessionState() except DBusException as e: raise error.TestError('Failed to retrieve session state: ', e) if state != 'started': raise error.TestFail('Session should not have ended: ', state) # Start listening to stop signal before the session gets killed. listener.listen_for_session_state_change('stopped') # Tell session_manager that a supervised user is being set up, # and kill it in the middle. Session should die. sm.HandleSupervisedUserCreationStarting() nuke_browser_error = None try: utils.nuke_process_by_name(constants.BROWSER) except error.AutoservPidAlreadyDeadError as e: nuke_browser_error = e logging.warning('Browser may have crashed untimely: ', e) try: listener.wait_for_signals(desc='Session stopped.', timeout=self._SESSION_STOP_TIMEOUT) except utils.TimeoutError as actual_problem: if nuke_browser_error is not None: actual_problem = nuke_browser_error raise error.TestFail(actual_problem)