Chromium Code Reviews| Index: tools/telemetry/telemetry/core/webdriver/webdriver_browser_backend.py |
| diff --git a/tools/telemetry/telemetry/core/webdriver/webdriver_browser_backend.py b/tools/telemetry/telemetry/core/webdriver/webdriver_browser_backend.py |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..9221836ce17e9263ec67d421f8bb2644a14dee5a |
| --- /dev/null |
| +++ b/tools/telemetry/telemetry/core/webdriver/webdriver_browser_backend.py |
| @@ -0,0 +1,101 @@ |
| +# Copyright (c) 2013 The Chromium Authors. All rights reserved. |
| +# Use of this source code is governed by a BSD-style license that can be |
| +# found in the LICENSE file. |
| +from telemetry.core import util |
| +from telemetry.core.webdriver import webdriver_tab_list_backend |
| + |
| +class WebDriverBrowserBackend(object): |
| + """The webdriver-based backend for controlling a locally-executed browser |
| + instance, on Linux, Mac, and Windows. |
| + """ |
| + |
| + WEBPAGEREPLAY_HOST = '127.0.0.1' |
|
tonyg
2013/07/30 19:35:34
Is this unused? If not, can we share it with the s
chrisgao (Use stgao instead)
2013/07/31 19:05:41
Found chrome backend and webdriver backend share a
|
| + |
| + def __init__(self, webdriver, supports_extensions, options): |
| + self.browser_type = options.browser_type |
| + self.webdriver_based = True |
| + self._driver = webdriver |
| + self._supports_extensions = supports_extensions |
| + self.options = options |
| + self._browser = None |
| + self.webpagereplay_local_http_port = 80 |
| + self.webpagereplay_local_https_port = 443 |
| + self.webpagereplay_remote_http_port = self.webpagereplay_local_http_port |
| + self.webpagereplay_remote_https_port = self.webpagereplay_local_https_port |
| + self._tab_list_backend = \ |
| + webdriver_tab_list_backend.WebDriverTabListBackend(self) |
| + |
| + def SetBrowser(self, browser): |
| + self._browser = browser |
| + self._tab_list_backend.Init() |
| + |
| + @property |
| + def driver(self): |
| + return self._driver |
| + |
| + @property |
| + def browser(self): |
| + return self._browser |
| + |
| + @property |
| + def is_content_shell(self): |
| + return False |
| + |
| + @property |
| + def supports_extensions(self): |
| + return self._supports_extensions |
| + |
| + @property |
| + def tab_list_backend(self): |
| + return self._tab_list_backend |
| + |
| + @property |
| + def supports_tab_control(self): |
| + # Based on webdriver protocol API, only closing a tab is supported while |
| + # activating or creating a tab is not. Thus, tab control is not supported. |
| + return False |
| + |
| + @property |
| + def wpr_mode(self): |
| + return self.options.wpr_mode |
| + |
| + @property |
| + def supports_tracing(self): |
| + # Tracing is not available in IE/Firefox yet and not supported through |
| + # webdriver API. |
| + return False |
| + |
| + def StartTracing(self, _): |
| + raise NotImplementedError() |
| + |
| + def StopTracing(self): |
| + raise NotImplementedError() |
| + |
| + def GetTraceResultAndReset(self): |
| + raise NotImplementedError() |
| + |
| + def GetProcessName(self, _): |
| + # Leave implementation details to subclass as process name depends on the |
| + # type of browser. |
| + raise NotImplementedError() |
| + |
| + def GetRemotePort(self, _): |
| + return util.GetAvailableLocalPort() |
| + |
| + def Close(self): |
| + self._driver.quit() |
| + self._driver = None |
| + |
| + def CreateForwarder(self, *port_pairs): |
| + return util.DoNothingForwarder(*port_pairs) |
| + |
| + def IsBrowserRunning(self): |
| + # Assume the browser is running if not explicitly closed. |
| + return self._driver is not None |
| + |
| + def GetStandardOutput(self): |
| + # TODO: Double check whether there is a way for python client to get stdout. |
| + return '' |
| + |
| + def __del__(self): |
| + self.Close() |