继续开发新版,未完成

This commit is contained in:
g1879 2022-11-08 00:42:06 +08:00
parent 48c0428600
commit 026e5ad742
5 changed files with 75 additions and 21 deletions

View File

@ -322,7 +322,7 @@ return true;}"""
:param args: 参数按顺序在js文本中对应argument[0]argument[2]...
:return: 运行的结果
"""
return _run_script(self, script, as_expr, *args)
return _run_script(self, script, as_expr, args)
def ele(self,
loc_or_str: Union[Tuple[str, str], str],
@ -747,7 +747,7 @@ else{a.push(e.snapshotItem(i));}}"""
return js
def _run_script(page_or_ele, script: str, as_expr: bool = False, *args: Any) -> Any:
def _run_script(page_or_ele, script: str, as_expr: bool = False, args: tuple = None) -> Any:
"""运行javascript代码 \n
:param page_or_ele: 页面对象或元素对象
:param script: js文本
@ -769,6 +769,7 @@ def _run_script(page_or_ele, script: str, as_expr: bool = False, *args: Any) ->
awaitPromise=True,
userGesture=True)
else:
args = args or ()
if not is_js_func(script):
script = script if script.strip().startswith('return') else f'return {script}'
script = f'function(){{{script}}}'
@ -937,7 +938,7 @@ class ChromeSelect(object):
:param ele: select 元素对象
"""
if ele.tag != 'select':
raise TypeError(f"select方法只能在<select>元素使用,现在是:{ele.tag}")
raise TypeError("select方法只能在<select>元素使用")
self._ele = ele
@ -947,9 +948,9 @@ class ChromeSelect(object):
:param timeout: 超时时间不输入默认实用页面超时时间
:return: None
"""
i = 'index' if isinstance(text_or_index, int) else 'text'
para_type = 'index' if isinstance(text_or_index, int) else 'text'
timeout = timeout if timeout is not None else self._ele.page.timeout
return self._select(text_or_index, timeout=timeout)
return self._select(text_or_index, para_type, timeout=timeout)
@property
def is_multi(self) -> bool:
@ -979,9 +980,13 @@ class ChromeSelect(object):
def clear(self) -> None:
"""清除所有已选项"""
self.select_ele.deselect_all()
if not self.is_multi:
raise NotImplementedError("只能在多选菜单执行此操作。")
for opt in self.options:
if opt.is_selected():
opt.click(by_js=True)
def select_by_text(self, text: Union[str, list, tuple], timeout=None) -> bool:
def by_text(self, text: Union[str, list, tuple], timeout=None) -> bool:
"""此方法用于根据text值选择项。当元素是多选列表时可以接收list或tuple \n
:param text: text属性值传入list或tuple可选择多项
:param timeout: 超时时间不输入默认实用页面超时时间
@ -990,7 +995,7 @@ class ChromeSelect(object):
timeout = timeout if timeout is not None else self._ele.page.timeout
return self._select(text, 'text', False, timeout)
def select_by_value(self, value: Union[str, list, tuple], timeout=None) -> bool:
def by_value(self, value: Union[str, list, tuple], timeout=None) -> bool:
"""此方法用于根据value值选择项。当元素是多选列表时可以接收list或tuple \n
:param value: value属性值传入list或tuple可选择多项
:param timeout: 超时时间不输入默认实用页面超时时间
@ -999,7 +1004,7 @@ class ChromeSelect(object):
timeout = timeout if timeout is not None else self._ele.page.timeout
return self._select(value, 'value', False, timeout)
def select_by_index(self, index: Union[int, list, tuple], timeout=None) -> bool:
def by_index(self, index: Union[int, list, tuple], timeout=None) -> bool:
"""此方法用于根据index值选择项。当元素是多选列表时可以接收list或tuple \n
:param index: index属性值传入list或tuple可选择多项
:param timeout: 超时时间不输入默认实用页面超时时间
@ -1008,7 +1013,7 @@ class ChromeSelect(object):
timeout = timeout if timeout is not None else self._ele.page.timeout
return self._select(index, 'index', False, timeout)
def deselect_by_text(self, text: Union[str, list, tuple], timeout=None) -> bool:
def cancel_by_text(self, text: Union[str, list, tuple], timeout=None) -> bool:
"""此方法用于根据text值取消选择项。当元素是多选列表时可以接收list或tuple \n
:param text: text属性值传入list或tuple可取消多项
:param timeout: 超时时间不输入默认实用页面超时时间
@ -1017,7 +1022,7 @@ class ChromeSelect(object):
timeout = timeout if timeout is not None else self._ele.page.timeout
return self._select(text, 'text', True, timeout)
def deselect_by_value(self, value: Union[str, list, tuple], timeout=None) -> bool:
def cancel_by_value(self, value: Union[str, list, tuple], timeout=None) -> bool:
"""此方法用于根据value值取消选择项。当元素是多选列表时可以接收list或tuple \n
:param value: value属性值传入list或tuple可取消多项
:param timeout: 超时时间不输入默认实用页面超时时间
@ -1026,7 +1031,7 @@ class ChromeSelect(object):
timeout = timeout if timeout is not None else self._ele.page.timeout
return self._select(value, 'value', True, timeout)
def deselect_by_index(self, index: Union[int, list, tuple], timeout=None) -> bool:
def cancel_by_index(self, index: Union[int, list, tuple], timeout=None) -> bool:
"""此方法用于根据index值取消选择项。当元素是多选列表时可以接收list或tuple \n
:param index: value属性值传入list或tuple可取消多项
:param timeout: 超时时间不输入默认实用页面超时时间

View File

@ -25,6 +25,11 @@ class ChromePage(BasePage):
super().__init__(timeout)
self._connect_debugger(Tab_or_Options, tab_handle)
def _ready(self):
self._alert = Alert()
self.driver.Page.javascriptDialogOpening = self._on_alert_open
self.driver.Page.javascriptDialogClosed = self._on_alert_close
def _connect_debugger(self, Tab_or_Options: Union[Tab, DriverOptions] = None, tab_handle: str = None):
if isinstance(Tab_or_Options, Tab):
self._driver = Tab_or_Options
@ -41,6 +46,7 @@ class ChromePage(BasePage):
self._driver.start()
self._driver.DOM.enable()
self._driver.Page.enable()
root = self._driver.DOM.getDocument()
self.root = ChromeElement(self, node_id=root['root']['nodeId'])
@ -123,7 +129,7 @@ class ChromePage(BasePage):
:param args: 参数按顺序在js文本中对应argument[0]argument[2]...
:return: 运行的结果
"""
return _run_script(self, script, as_expr, *args)
return _run_script(self, script, as_expr, args)
def get(self,
url: str,
@ -497,6 +503,47 @@ class ChromePage(BasePage):
return is_ok
def _on_alert_close(self, **kwargs):
self._alert.activated = False
self._alert.text = None
self._alert.type = None
self._alert.defaultPrompt = None
def _on_alert_open(self, **kwargs):
self._alert.activated = True
self._alert.text = kwargs['message']
self._alert.type = kwargs['message']
self._alert.defaultPrompt = kwargs.get('defaultPrompt', None)
def handle_alert(self, accept: bool = True, send: str = None, timeout: float = None) -> Union[str, None]:
"""处理提示框 \n
:param accept: True表示确认False表示取消其它值不会按按钮但依然返回文本值
:param send: 处理prompt提示框时可输入文本
:param timeout: 等待提示框出现的超时时间
:return: 提示框内容文本未等到提示框则返回None
"""
timeout = timeout or self.timeout
t1 = perf_counter()
while not self._alert.activated and perf_counter() - t1 < timeout:
sleep(.1)
if not self._alert.activated:
return None
res_text = self._alert.text
if self._alert.type == 'prompt':
self.driver.Page.handleJavaScriptDialog(accept=accept, promptText=send)
else:
self.driver.Page.handleJavaScriptDialog(accept=accept)
return res_text
class Alert(object):
def __init__(self):
self.activated = False
self.text = None
self.type = None
self.defaultPrompt = None
def _get_tabs(handles: list, num_or_handles: Union[int, str, list, tuple, set]) -> set:
"""返回指定标签页handle组成的set \n

View File

@ -1,11 +1,11 @@
[paths]
chromedriver_path =
chromedriver_path = D:\coding\Chrome92\chromedriver.exe
tmp_path =
[chrome_options]
debugger_address = 127.0.0.1:9222
binary_location = chromium-browser
arguments = ['--no-sandbox', '--disable-gpu', '--ignore-certificate-errors', '--disable-infobars', '--disable-popup-blocking']
binary_location = D:\coding\Chrome92\chrome.exe
arguments = ['--no-sandbox', '--disable-gpu', '--ignore-certificate-errors', '--disable-infobars', '--disable-popup-blocking', '--user-data-dir=D:\\coding\\Chrome92\\user_data']
extensions = []
experimental_options = {'prefs': {'profile.default_content_settings.popups': 0, 'profile.default_content_setting_values': {'notifications': 2}, 'plugins.plugins_list': [{'enabled': False, 'name': 'Chrome PDF Viewer'}]}, 'useAutomationExtension': False, 'excludeSwitches': ['enable-automation']}
timeouts = {'implicit': 10.0, 'pageLoad': 30.0, 'script': 30.0}

View File

@ -512,9 +512,9 @@ class DriverPage(BasePage):
"""
return glob(f'{download_path}{sep}*.crdownload')
def process_alert(self, ok: bool = True, send: str = None, timeout: float = None) -> Union[str, None]:
def handle_alert(self, accept: bool = True, send: str = None, timeout: float = None) -> Union[str, None]:
"""处理提示框 \n
:param ok: True表示确认False表示取消其它值不会按按钮但依然返回文本值
:param accept: True表示确认False表示取消其它值不会按按钮但依然返回文本值
:param send: 处理prompt提示框时可输入文本
:param timeout: 等待提示框出现的超时时间
:return: 提示框内容文本未等到提示框则返回None
@ -540,9 +540,9 @@ class DriverPage(BasePage):
if send is not None:
alert.send_keys(send)
if ok is True:
if accept is True:
alert.accept()
elif ok is False:
elif accept is False:
alert.dismiss()
return res_text

View File

@ -42,7 +42,7 @@ class WebPage(SessionPage, ChromePage, BasePage):
self._response = None
if self._mode == 'd':
self.driver
self._ready()
# if self._mode == 'd':
# try:
@ -199,6 +199,8 @@ class WebPage(SessionPage, ChromePage, BasePage):
# s模式转d模式
if self._mode == 'd':
if not self._has_driver:
self._ready()
self._has_driver = True
self._url = None if not self._has_driver else super(SessionPage, self).url