python+selenium中的wait事件

本文介绍了Selenium中三种等待机制:WebDriverWait显性等待、implicitly_wait隐性等待及time.sleep()固定等待。详细解释了每种等待的应用场景,并通过示例代码展示了如何在Python脚本中实现这些等待机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

selenium中的wait事件

1. 显示用法(WebDriverWait)

WebDriverWait的使用
配合该类的until()和until_not()方法,就能够根据判断条件而进行灵活地等待了。
它主要的意思就是:
程序每隔xx秒看一眼,如果条件成立了,则执行下一步,否则继续等待,直到超过设置的最长时间,然后抛出TimeoutException。

代码演示:

from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support.wait import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC


browser = webdriver.Chrome()
wait = WebDriverWait(browser, 10) #等待的最大时间
url = 'http://www.baidu.com?tn=baiduhome'
browser.get(url)
try:
    # 获取输入框
    input = wait.until(
        #判断该元素是否加载完成
        EC.presence_of_element_located((By.CSS_SELECTOR, '#kw'))
    )
    # 输入查询关键字
    input.send_keys("python")

    # 获取搜索点击按钮
    submit = wait.until(
        #判断该元素是否可以点击
        EC.element_to_be_clickable((By.CSS_SELECTOR, '#su'))
    )
    submit.click()
 except TimeoutException:
    print('exception')

隐性等待和显性等待,在其他操作中,隐性等待起决定性作用,在WebDriverWait..中显性等待起主要作用,
注意的是:最长的等待时间取决于两者之间的大者,如果隐性等待时间 > 显性等待时间,则该句代码的最长等待时间等于隐性等待时间。

这里需要特别注意的是until或until_not中的可执行方法method参数,很多人传入了WebElement对象,如下:

WebDriverWait(driver, 10).until(driver.find_element_by_id(‘kw’)) # 错误

这里的参数我可以使用selenium提供的 expected_conditions 模块 下文有提到

2. 隐示用法(implicitly_wait)

implicitly_wait(xx)
隐形等待是设置了一个最长等待时间,如果在规定时间内网页加载完成,则执行下一步,否则一直等到时间截止,然后执行下一步。注意这里有一个弊端,那就是程序会一直等待整个页面加载完成,也就是一般情况下你看到浏览器标签栏那个小圈不再转,才会执行下一步,但有时候页面想要的元素早就在加载完成了,但是因为个别js之类的东西特别慢,我仍得等到页面全部完成才能执行下一步,我想等我要的元素出来之后就下一步怎么办?这时候我们就使用显示的wait方法

代码演示:

from selenium import webdriver


driver = webdriver.Chrome()
driver.implicitly_wait(30) # 隐性等待,最长等30秒
driver.get('http://www.baidu.com')
print driver.current_url
driver.quit()

这里需要注意:
隐性等待对整个driver的周期都起作用,所以只要设置一次即可

3.time.sleep()方法

这个比较简单,起到一个强制的作用,
就是不管怎么样,都会等到你设置的时长,才会往下执行

4.selenium提供的 expected_conditions 模块

expected_conditions 模块下的判断条件:

    selenium.webdriver.support.expected_conditions(模块)

    这两个条件类验证title,验证传入的参数title是否等于或包含于driver.title
    title_is
    title_contains

    这两个人条件验证元素是否出现,传入的参数都是元组类型的locator,如(By.ID, 'kw')
    顾名思义,一个只要一个符合条件的元素加载出来就通过;另一个必须所有符合条件的元素都加载出来才行
    presence_of_element_located
    presence_of_all_elements_located

    这三个条件验证元素是否可见,前两个传入参数是元组类型的locator,第三个传入WebElement
    第一个和第三个其实质是一样的
    visibility_of_element_located
    invisibility_of_element_located
    visibility_of

    这两个人条件判断某段文本是否出现在某元素中,一个判断元素的text,一个判断元素的value
    text_to_be_present_in_element
    text_to_be_present_in_element_value

    这个条件判断frame是否可切入,可传入locator元组或者直接传入定位方式:id、name、index或WebElement
    frame_to_be_available_and_switch_to_it

    这个条件判断是否有alert出现
    alert_is_present

    这个条件判断元素是否可点击,传入locator
    element_to_be_clickable

    这四个条件判断元素是否被选中,第一个条件传入WebElement对象,第二个传入locator元组
    第三个传入WebElement对象以及状态,相等返回True,否则返回False
    第四个传入locator以及状态,相等返回True,否则返回False
    element_to_be_selected
    element_located_to_be_selected
    element_selection_state_to_be
    element_located_selection_state_to_be

    最后一个条件判断一个元素是否仍在DOM中,传入WebElement对象,可以判断页面是否刷新了
    staleness_of
<think>我们正在回答用户关于如何在PyCharm中使用PythonSelenium和pytest进行测试自动化的问题。根据引用,我们了解到需要搭建一个测试框架,其中:-编程语言:Python3-框架:pytest-方法:Selenium(用于Web自动化)步骤:1.环境准备:安装Python、PyCharm、Selenium和pytest。2.创建项目并配置环境。3.编写测试用例。4.运行测试并生成报告。详细步骤:1.环境准备:-安装Python3:从官网下载并安装。-安装PyCharm:下载并安装。-在PyCharm中创建新项目,并配置Python解释器。-安装必要的包:在PyCharm的终端中执行以下命令:```bashpipinstallseleniumpytestpytest-html```其中,pytest-html用于生成HTML测试报告。2.配置项目:-在项目中创建测试目录(例如:tests)。-在测试目录中创建测试文件,文件名以`test_`开头或`_test.py`结尾(例如:test_login.py)。3.编写测试用例:-使用pytest的测试函数格式,函数名以`test_`开头。-在测试函数中,使用Selenium编写Web自动化脚本。示例测试用例(test_login.py):```pythonfromseleniumimportwebdriverimportpytest@pytest.fixture(scope="function")defbrowser():#初始化浏览器driver=webdriver.Chrome()yielddriver#测试结束后关闭浏览器driver.quit()deftest_login(browser):browser.get("https://example.com/login")username=browser.find_element_by_id("username")password=browser.find_element_by_id("password")submit=browser.find_element_by_id("submit")username.send_keys("testuser")password.send_keys("password")submit.click()#验证登录成功welcome_message=browser.find_element_by_id("welcome-message")assert"Welcome"inwelcome_message.text```4.运行测试:-在PyCharm中,可以直接右键点击测试文件选择运行(选择以pytest方式运行)。-或者,在终端中使用命令:```bashpytesttests/test_login.py--html=report.html```这将运行测试并生成一个名为report.html的测试报告。5.持续集成(可选):-可以配置CI工具(如Jenkins、GitHubActions)来定期运行测试。注意事项:-确保安装了对应浏览器的WebDriver(如ChromeDriver),并将其放在系统路径中,或者在代码中指定路径。-使用pytest的fixture(如上面的browser)可以方便地管理测试资源。根据引用[3],pytest会默认搜寻所有文件名为`test_*.py`或者`*_test.py`的文件,因此按照此规则命名文件即可被自动发现。引用[4]提到可以使用Allure生成更美观的测试报告,安装Allure并配置:-安装Allure:https://docs.qameta.io/allure/-安装pytest的Allure插件:`pipinstallallure-pytest`-运行测试并生成Allure报告:```bashpytest--alluredir=allure-resultsallureserveallure-results```以上就是在PyCharm中使用PythonSelenium和pytest进行测试自动化的基本步骤。生成相关问题:1.如何配置ChromeDriver以与Selenium一起使用?2.在pytest中如何使用参数化测试?3.如何将自动化测试集成到持续集成(CI)流程中?</think>### 在PyCharm中使用Python+Selenium+pytest实现测试自动化 #### 环境配置步骤: 1. **安装必要组件** - 在PyCharm终端执行: ```bash pip install selenium pytest pytest-html webdriver-manager ``` - `webdriver-manager`自动管理浏览器驱动[^3] 2. **项目结构配置** ```markdown project/ ├── tests/ │ ├── test_login.py # 测试用例文件 │ └── conftest.py # 全局fixture ├── pages/ │ └── login_page.py # 页面对象模型 └── requirements.txt # 依赖清单 ``` 3. **创建基础框架** **conftest.py** (浏览器初始化): ```python import pytest from selenium import webdriver from webdriver_manager.chrome import ChromeDriverManager @pytest.fixture(scope="function") def browser(): driver = webdriver.Chrome(ChromeDriverManager().install()) driver.implicitly_wait(10) yield driver driver.quit() ``` **pages/login_page.py** (页面对象): ```python class LoginPage: def __init__(self, driver): self.driver = driver self.username_field = ("id", "username") self.password_field = ("id", "password") def login(self, username, password): self.driver.find_element(*self.username_field).send_keys(username) self.driver.find_element(*self.password_field).send_keys(password) self.driver.find_element("id", "submit").click() ``` **tests/test_login.py** (测试用例): ```python from pages.login_page import LoginPage def test_valid_login(browser): browser.get("https://example.com/login") login_page = LoginPage(browser) login_page.login("admin", "securepass") assert "Dashboard" in browser.title ``` #### 执行测试 1. **PyCharm运行配置** - 右键测试目录 → `Run pytest in tests` - 或终端执行: ```bash pytest tests/ --html=report.html ``` 2. **增强功能** - 参数化测试: ```python @pytest.mark.parametrize("user,pwd", [("user1","pwd1"), ("user2","pwd2")]) def test_login_combinations(browser, user, pwd): # 测试逻辑 ``` - Allure报告: ```bash pytest --alluredir=allure-results allure serve allure-results ``` #### 常见问题解决 1. **浏览器驱动问题** - 使用`webdriver-manager`自动下载驱动[^3] - 或手动指定路径: ```python driver = webdriver.Chrome(executable_path="path/to/chromedriver") ``` 2. **元素定位失败** - 添加显式等待: ```python from selenium.webdriver.support.ui import WebDriverWait WebDriverWait(driver, 10).until( EC.visibility_of_element_located((By.ID, "element_id")) ) ``` 3. **测试报告优化** - 安装`pytest-html`生成HTML报告 - 使用`allure-pytest`生成可视化报告[^4] > **最佳实践**:遵循页面对象模式(POM)分离测试逻辑与页面操作,使用`conftest.py`管理共享fixture,保持测试原子性[^2]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值