# webrunner **Repository Path**: z417_admin/webrunner ## Basic Information - **Project Name**: webrunner - **Description**: 以python,selenium,pytest为基础的web自动化框架 - **Primary Language**: Python - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 1 - **Created**: 2020-06-10 - **Last Updated**: 2024-11-08 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # WebRunner * 当下只支持Chrome和Chromium ## 简介 * 面向页面(支持,但非必须) * 页面元素 ← 映射 → python 对象 * 提供全局的 'driver' 对象 * 通过 `webrunner.common.tools.get_driver()` 获取全局 driver * 也可通过 `webrunner.common.tools.create_driver()`创建私有 driver * 扩展简单 * 对 `driver` 添加自定义功能 * 可无缝接入 `pytest` 框架支持的插件 * 环境变量理念 * 快速切换测试环境 * 快速切换测试配置 * 储存敏感数据 * 数据驱动模式 (DDT) * 支持对case的过滤功能 * 默认使用junit和pytest-html作为测试报告 * 易于集成Jenkin或其他CI工具 * 当前的缺陷 * 需要按照pytest框架约定的规则写测试函数(方法) ## 运行环境 * 基础 * Python >= 3.6.x * 注意: 在Python 3.8中有一个未知的错误 * selenium 3.141.0 [官方文档](https://selenium-python-zh.readthedocs.io/en/latest/index.html) * pytest 5.3.2 [官方文档](http://docs.pytest.org/en/latest/contents.html) * pytest-html 2.0.1 [官方文档](https://pypi.org/project/pytest-html/) * junit-xml [官方文档](https://pypi.org/project/junit-xml/) * 模板引擎 * Jinja2 2.10.3 [官方文档](https://jinja.palletsprojects.com/en/master/) * PyYAML 5.2 [官方文档](https://github.com/yaml/pyyaml) * 其他 * psutil 5.6.7 [官方文档](https://pypi.org/project/psutil/) * Click 7.0 [官方文档](https://pypi.org/project/click/) ## 目录结构 ```shell ├── demo // 例子 ├── doc // 使用文档 ├── webrunner // 主目录 │ ├── common // 基础工具包 │ ├── template // 模板文件存放路径(计划支持定制模板) │ ├── interface.py // 暴露给外部的接口 │ └── run.py // 程序主入口 ├── README.md // 就您现在阅读的 └── setup.py // 安装入口 ``` ## 安装指南 * 建议先[设置阿里云pip源,加速pip更新速度](https://www.cnblogs.com/ityunv/p/5909434.html) * 推荐在虚拟环境中安装使用 ```shell $ pip install virtualenv $ virtualenv wrunEnv $ cd wrunEnv/Script $ activate # deactivate (to terminal) ``` * 下载 WebRunner工程后安装 ```shell $ python setup.py install ``` * 如果某些依赖安装失败 (比如 pyyaml 安装失败) ```shell $ pip install -I pyyaml ``` * 提示:`pip uninstall pyyaml` 是卸载pywin32模块的命令,其余类推;缺失的、安装失败的模块,请直接使用pip管理 * 卸载webRunner ```shell $ pip uninstall webrunner ``` ## 快速开始 * 解决Chrome版本和chromedriver匹配的问题,请参见博文[获取Chrome版本并下载匹配的chromedriver](https://www.cnblogs.com/z417/p/13785734.html) ### 创建新的测试项目 * 设置基础目录结构 ```shell ├── driver │ └── chromedriver // 必需且要与Chrome版本匹配 └── report // 报告默认存放目录 ``` ### 新建`testDemo.py` ```python from webrunner.common.tools import get_driver # 返回全局唯一的webdriver实例 driver = get_driver() def test_demo(): driver.get('https://www.baidu.com') driver.sleep(3) driver.quit() ``` ### 在`python virtualenv`终端里输入 ```shell $ wrun rt testDemo.py ``` * 打开Chrome并最大化, 访问`百度`首页 * 生成`20200706_142333.html`和`20200706_142333.xml`存在report文件夹内 ### 使用`环境变量` * 新建`baidu.env`如下(支持以"=" 和 ":"分割,并且自动去除首尾空格) ```text BASE_URL = https://www.baidu.com ``` * 更新`testDemo.py`以使用 ```python from webrunner.common.tools import get_driver from webrunner.common.tools import get_env driver = get_driver() def test_demo(): driver.get(get_env('BASE_URL')) driver.sleep(3) driver.quit() ``` * 再次运行 ```shell $ wrun rt --dot-env baidu.env testDemo.py ``` ### 指定报告名和路径 ```shell $ wrun rt --dot-env google.env --report report/demoReport testDemo.py ``` ### 开启/关闭Chrome的`headless`模式 ```shell $ wrun rt -H on --dot-env google.env --report report/demoReport testDemo.py ``` * 默认是`off` ## 更多特性请参阅[doc](./doc) ## WeChat ![avatar][1vs] [1vs]: