diff options
author | Lars-Dominik Braun <lars@6xq.net> | 2019-01-04 19:23:22 +0100 |
---|---|---|
committer | Lars-Dominik Braun <lars@6xq.net> | 2019-01-04 19:23:22 +0100 |
commit | cf83c608bf2fb4e9f458cc0ee31f87cc0948345d (patch) | |
tree | 7cdeea1aa39e41c68ad19644ec1486cb814df2ae | |
parent | 3fb47a7286a8153660bad8cf44a0662d8fd537ca (diff) | |
download | crocoite-cf83c608bf2fb4e9f458cc0ee31f87cc0948345d.tar.gz crocoite-cf83c608bf2fb4e9f458cc0ee31f87cc0948345d.tar.bz2 crocoite-cf83c608bf2fb4e9f458cc0ee31f87cc0948345d.zip |
behavior: Ignore onstop() failure
Fails if the page is reloaded/redirected. See issue #13.
-rw-r--r-- | crocoite/behavior.py | 18 |
1 files changed, 14 insertions, 4 deletions
diff --git a/crocoite/behavior.py b/crocoite/behavior.py index dff1439..2c94bb8 100644 --- a/crocoite/behavior.py +++ b/crocoite/behavior.py @@ -46,7 +46,7 @@ import yaml from .util import getFormattedViewportMetrics from . import html from .html import StripAttributeFilter, StripTagFilter, ChromeTreeWalker -from .devtools import Crashed +from .devtools import Crashed, TabException class Script: """ A JavaScript resource """ @@ -150,9 +150,19 @@ class JsOnload (Behavior): async def onstop (self): tab = self.loader.tab - assert self.context is not None - await tab.Runtime.callFunctionOn (functionDeclaration='function(){return this.stop();}', objectId=self.context) - await tab.Runtime.releaseObject (objectId=self.context) + try: + assert self.context is not None + await tab.Runtime.callFunctionOn (functionDeclaration='function(){return this.stop();}', + objectId=self.context) + await tab.Runtime.releaseObject (objectId=self.context) + except TabException as e: + # cannot do anything about that. Ignoring should be fine. + self.logger.error ('jsonload onstop failed', + uuid='1786726f-c8ec-4f79-8769-30954d4e32f5', + exception=e.args, + objectId=self.context, + context=self.__class__.__name__) + return yield # pragma: no cover |