diff options
author | Markus Mohrhard <markus.mohrhard@googlemail.com> | 2018-02-18 01:06:13 +0100 |
---|---|---|
committer | Markus Mohrhard <markus.mohrhard@googlemail.com> | 2018-02-18 21:49:45 +0100 |
commit | fb4d5885f3c8d00ae528ddf57b2abaa4aabfbcf3 (patch) | |
tree | f87d37a5db0d32fbb59f74e6f2e07fa2e9e78987 /uitest | |
parent | 55f5afe532c61c6bc382f23e17dfeb6ed3985790 (diff) |
uitest: add timeout for blocking actions
Change-Id: I796d4ea0034ddae0427418f0d53a00c3dfa66871
Reviewed-on: https://gerrit.libreoffice.org/49939
Tested-by: Jenkins <ci@libreoffice.org>
Reviewed-by: Markus Mohrhard <markus.mohrhard@googlemail.com>
Diffstat (limited to 'uitest')
-rw-r--r-- | uitest/uitest/test.py | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/uitest/uitest/test.py b/uitest/uitest/test.py index 0318dfa64d81..f179807c5b0f 100644 --- a/uitest/uitest/test.py +++ b/uitest/uitest/test.py @@ -178,7 +178,7 @@ class UITest(object): time.sleep(DEFAULT_SLEEP) def execute_blocking_action(self, action, dialog_element=None, - args=(), dialog_handler=None): + args=(), dialog_handler=None, dialog_timeout=30): """Executes an action which blocks while a dialog is shown. Click a button or perform some other action on the dialog when it @@ -192,6 +192,8 @@ class UITest(object): args(tuple, optional): The arguments to be passed to `action` dialog_handler(callable, optional): Will be called when the dialog is shown, with the dialog object passed as a parameter. + timeout(optional): The maximum time the thread will wait for the + dialog actions to happen. None means wait forever. """ thread = threading.Thread(target=action, args=args) @@ -207,7 +209,9 @@ class UITest(object): xUIElement.executeAction("CLICK", tuple()) if dialog_handler: dialog_handler(xDlg) - thread.join() + thread.join(dialog_timeout) + if thread.isAlive(): + raise DialogNotClosedException() return time_ += DEFAULT_SLEEP |