Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
SeleniumHQ
GitHub Repository: SeleniumHQ/Selenium
Path: blob/trunk/py/selenium/webdriver/edge/service.py
1864 views
1
# Licensed to the Software Freedom Conservancy (SFC) under one
2
# or more contributor license agreements. See the NOTICE file
3
# distributed with this work for additional information
4
# regarding copyright ownership. The SFC licenses this file
5
# to you under the Apache License, Version 2.0 (the
6
# "License"); you may not use this file except in compliance
7
# with the License. You may obtain a copy of the License at
8
#
9
# http://www.apache.org/licenses/LICENSE-2.0
10
#
11
# Unless required by applicable law or agreed to in writing,
12
# software distributed under the License is distributed on an
13
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14
# KIND, either express or implied. See the License for the
15
# specific language governing permissions and limitations
16
# under the License.
17
18
from collections.abc import Mapping, Sequence
19
from typing import Optional
20
21
from selenium.types import SubprocessStdAlias
22
from selenium.webdriver.chromium import service
23
24
25
class Service(service.ChromiumService):
26
"""A Service class that is responsible for the starting and stopping of
27
`msedgedriver`.
28
29
:param executable_path: install path of the msedgedriver executable, defaults to `msedgedriver`.
30
:param port: Port for the service to run on, defaults to 0 where the operating system will decide.
31
:param log_output: (Optional) int representation of STDOUT/DEVNULL, any IO instance or String path to file.
32
:param service_args: (Optional) Sequence of args to be passed to the subprocess when launching the executable.
33
:param env: (Optional) Mapping of environment variables for the new process, defaults to `os.environ`.
34
:param driver_path_env_key: (Optional) Environment variable to use to get the path to the driver executable.
35
"""
36
37
def __init__(
38
self,
39
executable_path: Optional[str] = None,
40
port: int = 0,
41
log_output: Optional[SubprocessStdAlias] = None,
42
service_args: Optional[Sequence[str]] = None,
43
env: Optional[Mapping[str, str]] = None,
44
driver_path_env_key: Optional[str] = None,
45
**kwargs,
46
) -> None:
47
self._service_args = list(service_args or [])
48
driver_path_env_key = driver_path_env_key or "SE_EDGEDRIVER"
49
50
super().__init__(
51
executable_path=executable_path,
52
port=port,
53
service_args=service_args,
54
log_output=log_output,
55
env=env,
56
driver_path_env_key=driver_path_env_key,
57
**kwargs,
58
)
59
60
@property
61
def service_args(self) -> Sequence[str]:
62
return self._service_args
63
64
@service_args.setter
65
def service_args(self, value: Sequence[str]):
66
if isinstance(value, str) or not isinstance(value, Sequence):
67
raise TypeError("service_args must be a sequence")
68
self._service_args = list(value)
69
70