Selenium WebUI自动化测试框架使用Python+Selenium+第三方库实现WebUI自动化测试框架。 简介项目目录AutoIt : 操作界面ui的第三方插件Config : 配置文件Data : 测试数据Drivers : 浏览器驱动Elements : 页面定位元素Log : 测试运行时生成日志存放的目录Report : 执行结束后生成报告存放的目录src : 项目源码TestCases : 存放测试用例集、测试用例生成的数据(用例中做数据比对时生成).flaskenv : FlaskWeb环境变量配置export_package_info.bat : 导出当前环境下所有第三方库信息package_info.txt : 当前环境下所有第三方库信息requirements.txt : 依赖第三方库明细automation.data : 自动化测试运行数据runtest.bat : 启动并执行案例(执行runtest.py )runtest.py : 启动脚本stoptest.bat : 停止案例执行(执行stoptest.py )stoptest.py : 停止脚本runserver.bat : 网页启动脚本(执行webserver.py )webserver.py : 网页启动脚本
如何运行- 这里我们用
TestCases\test_案例_1.py 用例举例该用例实现的是访问百度(www.baidu.com)并搜索Python,具体可以查看该py文件内test_1_百度搜索测试()方法 - 记得把案例都放到
TestCases 目录中,该目录存放所有自动化测试案例 - 然后启动web服务, 在web页面中管理用例以及执行构建
运行效果启动执行- 点击
runserver.bat 启动web服务
- 用户登录后进入编辑页面
将页面左侧案例目录 的用例拖拽到右侧执行计划 中,在执行计划 中管理用例的执行顺序,只有勾选才会执行,然后点击保存执行计划。(用例颗粒度已具体到方法层)
- 进入构建页面构建执行
案例编辑- 双击构建页面
案例目录 中的案例,自动跳转到编码页面,可以做轻量级案例编写工作
测试报告- 执行完毕报告展示
钉钉消息通知- 通过钉钉机器人通知群里面成员
邮件通知- 收到测试报告邮件
首页图表展示- 展示用户最近构建次数
后续增加更多图表展示
安装部署- 推荐使用Pyhon3.5.4及以上版本
- 使用命令
pip install -r requirements.txt 安装第三方库(requirements.txt 文件在项目目录下) - 选择本地浏览器对应版本的驱动放到
Drivers 目录(谷歌:chromedriver.exe, 火狐:geckodriver.exe) .flaskenv 文件,当部署生产环境时,需要将该文件中的配置FLASK_ENV=production FLASK_DEBUG=0 ,测试时可以将其设置为FLASK_ENV=development FLASK_DEBUG=1
使用介绍- 初始用户名和密码为
admin/admin ,可以直接登录使用。用户信息存在数据库WebUIAutoTest\src\web\app\app.db 的main.user 表中,其中密码采用的是from werkzeug.security import generate_password_hash 方法提供加密算法加密,密码设置为明文会无法校验通过。 - 如果使用注册功能注册新的账户,请先在
Config/config.ini 文件EMAIL 选择项中配置系统管理员的SMTP邮箱服务,之后在注册时会通过该邮箱发送注册信息。相关配置为(smtp_login_name , smtp_login_passwd , sender_address , smtp_server_address , smtp_port , smtp_ssl , smtp_tls ) - Web服务相关日志在
WebUIAutoTest\src\web\app\logs\webserver.log 中,可以查看相关报错日志信息自动化构建相关日志在WebUIAutoTest\Log 目录中,可以查看自动化运行过程中日志信息(自动化构建日志也可以通过Web页面中日志菜单查看)
扩展功能1. GUI操作2. 数据比对3. 数据驱动4. 并发执行5. 插件拓展案例功能支持用户添加插件拓展案例中可调用方法 插件所在目录为WebUIAutoTest\src\extension 目录下默认有一个data_util.py 文件,里面定义了一个类DataUtil ,方法func1 定义在该类中。这样我们就可以在案例中使用 "self.func1(*args, **kwargs)"格式调用插件中的方法 class Test_Demo(TestCaseMore): # 要继承TestCaseMore...def test_method_demo(self): logger.info("正在执行 Test_Demo.test_method_demo") ... self.func1(*args, **kwargs) # 调用插件中的方法 ...... 需要注意的是,如果插件中定义的方法或属性与TestCaseMore类及其父类方法或属性重名,则会有警告日志提示该方法或属性重名。 当然也可以在WebUIAutoTest\src\extension 添加自己的py文件作为插件,data_util.py 仅作为示例。
6. 支持定时任务配置- 支持用户配置定时任务(与Jenkins中的定时任务配置类似)
- 配置定时时间,在
src/web/app/celery.py 中配置,如下。通过字典数据格式可以配置多个定时任务,其中scheduel 项配置可参考文档celery.schedules.crontabcelery.conf.beat_schedule = { 'run-once-every-day': { # 执行tasks下的run_test函数 'task': 'src.web.app.tasks.run_test', # 每天指定时间执行一次 'schedule': crontab(minute='30', hour='0'), # 传递参数 # 'args': ('a',) },} - 启动定时服务脚本,分别
celery_worker_server_start.bat 和celery_beat_start.bat - 日志可以在
Log/celery_worker_server.log 和Log/celery_beat.log 中查看
应用架构图其他作者联系方式 相关项目 |
请发表评论