Metadata-Version: 2.1 Name: webdriver-manager Version: 3.8.5 Summary: Library provides the way to automatically manage drivers for different browsers Home-page: https://github.com/SergeyPirogov/webdriver_manager Author: Sergey Pirogov Author-email: automationremarks@gmail.com Keywords: testing,selenium,driver,test automation Classifier: License :: OSI Approved :: Apache Software License Classifier: Intended Audience :: Information Technology Classifier: Intended Audience :: Developers Classifier: Programming Language :: Python :: 3.7 Classifier: Programming Language :: Python :: 3.8 Classifier: Programming Language :: Python :: 3.9 Classifier: Programming Language :: Python :: 3.10 Classifier: Topic :: Software Development :: Libraries :: Python Modules Classifier: Operating System :: Microsoft :: Windows Classifier: Operating System :: POSIX Classifier: Operating System :: Unix Classifier: Operating System :: MacOS Requires-Python: >=3.7 Description-Content-Type: text/markdown License-File: LICENSE Requires-Dist: requests Requires-Dist: python-dotenv Requires-Dist: tqdm Requires-Dist: packaging # Webdriver Manager for Python [![Tests](https://github.com/SergeyPirogov/webdriver_manager/actions/workflows/test.yml/badge.svg)](https://github.com/SergeyPirogov/webdriver_manager/actions/workflows/test.yml) [![PyPI](https://img.shields.io/pypi/v/webdriver_manager.svg)](https://pypi.org/project/webdriver-manager) [![Supported Python Versions](https://img.shields.io/pypi/pyversions/webdriver_manager.svg)](https://pypi.org/project/webdriver-manager/) [![codecov](https://codecov.io/gh/SergeyPirogov/webdriver_manager/branch/master/graph/badge.svg)](https://codecov.io/gh/SergeyPirogov/webdriver_manager) [Patreon](https://www.patreon.com/automation_remarks) The main idea is to simplify management of binary drivers for different browsers. For now support: - [ChromeDriver](#use-with-chrome) - [GeckoDriver](#use-with-firefox) - [IEDriver](#use-with-ie) - [OperaDriver](#use-with-opera) - [EdgeChromiumDriver](#use-with-edge) Compatible with Selenium 4.x and below. Before: You need to download the chromedriver binary, unzip it somewhere on your PC and set the path to this driver like this: ```python from selenium import webdriver driver = webdriver.Chrome('/home/user/drivers/chromedriver') ``` It’s boring!!! Moreover, every time a new version of the driver is released, you need to repeat all these steps again and again. With webdriver manager, you just need to do two simple steps: #### Install manager: ```bash pip install webdriver-manager ``` #### Use with Chrome ```python # selenium 3 from selenium import webdriver from webdriver_manager.chrome import ChromeDriverManager driver = webdriver.Chrome(ChromeDriverManager().install()) ``` ```python # selenium 4 from selenium import webdriver from selenium.webdriver.chrome.service import Service as ChromeService from webdriver_manager.chrome import ChromeDriverManager driver = webdriver.Chrome(service=ChromeService(ChromeDriverManager().install())) ``` #### Use with Chromium ```python # selenium 3 from selenium import webdriver from webdriver_manager.chrome import ChromeDriverManager from webdriver_manager.core.utils import ChromeType driver = webdriver.Chrome(ChromeDriverManager(chrome_type=ChromeType.CHROMIUM).install()) ``` ```python # selenium 4 from selenium import webdriver from selenium.webdriver.chrome.service import Service as ChromiumService from webdriver_manager.chrome import ChromeDriverManager from webdriver_manager.core.utils import ChromeType driver = webdriver.Chrome(service=ChromiumService(ChromeDriverManager(chrome_type=ChromeType.CHROMIUM).install())) ``` #### Use with Brave ```python # selenium 3 from selenium import webdriver from webdriver_manager.chrome import ChromeDriverManager from webdriver_manager.core.utils import ChromeType driver = webdriver.Chrome(ChromeDriverManager(chrome_type=ChromeType.BRAVE).install()) ``` ```python # selenium 4 from selenium import webdriver from selenium.webdriver.chrome.service import Service as BraveService from webdriver_manager.chrome import ChromeDriverManager from webdriver_manager.core.utils import ChromeType driver = webdriver.Chrome(service=BraveService(ChromeDriverManager(chrome_type=ChromeType.BRAVE).install())) ``` #### Use with Firefox ```python # selenium 3 from selenium import webdriver from webdriver_manager.firefox import GeckoDriverManager driver = webdriver.Firefox(executable_path=GeckoDriverManager().install()) ``` ```python # selenium 4 from selenium import webdriver from selenium.webdriver.firefox.service import Service as FirefoxService from webdriver_manager.firefox import GeckoDriverManager driver = webdriver.Firefox(service=FirefoxService(GeckoDriverManager().install())) ``` #### Use with IE ```python # selenium 3 from selenium import webdriver from webdriver_manager.microsoft import IEDriverManager driver = webdriver.Ie(IEDriverManager().install()) ``` ```python # selenium 4 from selenium import webdriver from selenium.webdriver.ie.service import Service as IEService from webdriver_manager.microsoft import IEDriverManager driver = webdriver.Ie(service=IEService(IEDriverManager().install())) ``` #### Use with Edge ```python # selenium 3 from selenium import webdriver from webdriver_manager.microsoft import EdgeChromiumDriverManager driver = webdriver.Edge(EdgeChromiumDriverManager().install()) ``` ```python # selenium 4 from selenium import webdriver from selenium.webdriver.edge.service import Service as EdgeService from webdriver_manager.microsoft import EdgeChromiumDriverManager driver = webdriver.Edge(service=EdgeService(EdgeChromiumDriverManager().install())) ``` #### Use with Opera ```python # selenium 3 & 4 from selenium import webdriver from webdriver_manager.opera import OperaDriverManager driver = webdriver.Opera(executable_path=OperaDriverManager().install()) ``` If the Opera browser is installed in a location other than `C:/Program Files` or `C:/Program Files (x86)` on windows and `/usr/bin/opera` for all unix variants and mac, then use the below code, ```python from selenium import webdriver from webdriver_manager.opera import OperaDriverManager options = webdriver.ChromeOptions() options.add_argument('allow-elevated-browser') options.binary_location = "C:\\Users\\USERNAME\\FOLDERLOCATION\\Opera\\VERSION\\opera.exe" driver = webdriver.Opera(executable_path=OperaDriverManager().install(), options=options) ``` #### Get browser version from path To get the version of the browser from the executable of the browser itself: ```python from webdriver_manager.core.utils import read_version_from_cmd, PATTERN version = read_version_from_cmd("/usr/bin/firefox-bin --version", PATTERN["firefox"]) driver_binary = FirefoxDriverManager(version=version).install() ``` ## Configuration **webdriver_manager** has several configuration variables you can be interested in. Any variable can be set using either .env file or via python directly ### `GH_TOKEN` **webdriver_manager** downloading some webdrivers from their official GitHub repositories but GitHub has [limitations](https://docs.github.com/en/rest/overview/resources-in-the-rest-api#rate-limiting) like 60 requests per hour for unauthenticated users. In case not to face an error related to github credentials, you need to [create](https://help.github.com/articles/creating-an-access-token-for-command-line-use) github token and place it into your environment: (\*) Example: ```bash export GH_TOKEN = "asdasdasdasd" ``` (\*) access_token required to work with GitHub API [more info](https://help.github.com/articles/creating-an-access-token-for-command-line-use/). There is also possibility to set same variable via ENV VARIABLES, example: ```python import os os.environ['GH_TOKEN'] = "asdasdasdasd" ``` ### `WDM_LOG` Turn off webdriver-manager logs use: ```python import logging import os os.environ['WDM_LOG'] = str(logging.NOTSET) ``` ### `WDM_LOCAL` By default, all driver binaries are saved to user.home/.wdm folder. You can override this setting and save binaries to project.root/.wdm. ```python import os os.environ['WDM_LOCAL'] = '1' ``` ### `WDM_SSL_VERIFY` SSL verification can be disabled for downloading webdriver binaries in case when you have troubles with SSL Certificates or SSL Certificate Chain. Just set the environment variable `WDM_SSL_VERIFY` to `"0"`. ```python import os os.environ['WDM_SSL_VERIFY'] = '0' ``` ### `path` Set the directory where you want to download and save the webdriver. You can use relative and absolute paths. ```python from webdriver_manager.chrome import ChromeDriverManager ChromeDriverManager(path = r".\\Drivers").install() ``` ### `version` Specify the version of webdriver you need. And webdriver-manager will download it from sources for your os. ```python from webdriver_manager.chrome import ChromeDriverManager ChromeDriverManager(version="2.26").install() ``` ### `cache_valid_range` Driver cache by default is valid for 1 day. You are able to change this value using constructor parameter: ```python from webdriver_manager.chrome import ChromeDriverManager ChromeDriverManager("2.26", cache_valid_range=1).install() ``` --- ### Custom Logger If you need to use a custom logger, you can create a logger and set it with `set_logger()`. ```python import logging from webdriver_manager.core.logger import set_logger logger = logging.getLogger("custom_logger") logger.setLevel(logging.DEBUG) logger.addHandler(logging.StreamHandler()) logger.addHandler(logging.FileHandler("custom.log")) set_logger(logger) ``` --- ### Custom HTTP Client If you need to add custom HTTP logic like session or proxy you can define your custom HttpClient implementation. ```python import os import requests from requests import Response from webdriver_manager.chrome import ChromeDriverManager from webdriver_manager.core.download_manager import WDMDownloadManager from webdriver_manager.core.http import HttpClient from webdriver_manager.core.logger import log class CustomHttpClient(HttpClient): def get(self, url, params=None, **kwargs) -> Response: """ Add you own logic here like session or proxy etc. """ log("The call will be done with custom HTTP client") return requests.get(url, params, **kwargs) def test_can_get_chrome_driver_with_custom_http_client(): http_client = CustomHttpClient() download_manager = WDMDownloadManager(http_client) path = ChromeDriverManager(download_manager=download_manager).install() assert os.path.exists(path) ``` --- This will make your test automation more elegant and robust! Cheers