You're Invited:Meet the Socket Team at BlackHat and DEF CON in Las Vegas, Aug 4-6.RSVP
Socket
Book a DemoInstallSign in
Socket

xiaobaiauto2

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

xiaobaiauto2

xiaobaiauto2是对自动化框架的第三次更新,功能覆盖UI自动化与API自动化意在帮助对自动化有更多需求且过多时间写代码的人群,让大家的时间花在业务的实现上

1.0.1
pipPyPI
Maintainers
1

Downloads Downloads Downloads Downloads

简介

xiaobaiauto2是一套自动化框架,功能覆盖UI自动化与API自动化 意在帮助对自动化有更多需求且过多时间写代码的人群,让大家的时间 花在业务的实现上,本库已放弃!!!推荐使用xiaobaisaf

架构

Image text

开始使用

安装

pip install xiaobaiauto2

pip install xiaobaiauto2[all] # 安装全部依赖

项目目录

test
|
|--__init__.py
|
|--WebTest 
|   |
|   |--conftest.py
|   |--test_WebUI.py
|
|--APPTest
|   |
|   |--conftest.py
|   |--test_Manzhai_APP_Case1.py
|   |--test_Manzhai_APP_Case2.py
|
|--APITest
|   |
|   |--test_cases.py
|   |--yewua.py

关键词

序号CMDkey
1打开网页URL
2点击CLICK
3输入SENDKEY
4刷新REFRESH
5后退BACK
6关闭CLOSE
7退出QUIT
8标签TAG
9属性ATTR
10URLCURL
11标题ITLE
12内嵌页FRAME
13标签页[序号(1开始)]WINDOW
14JS_确定ALERT0
15JS_取消ALERT1
16JS_输入框ALERT2
17JS_文本ALERT3
18停止WAIT
19脚本SCRIPT
20添加cookieADDCOOKIE
21滑屏SWIPE
22截屏DSCREENSHOT
23元素截图ESCREENSHOT
24识别验证码FINDTEXT
25坐标LOCATION
26网页源码PAGESOURCE

调用模板修改脚本

参考test目录下面的脚本

@pytest.mark.xiaobai_web
def test_Case1(browser):
    web_action(browser, cmd=cmd.打开网页, loc='', data='http://www.baidu.com')
    web_action(browser, cmd=cmd.输入, loc='//*[@id="kw"]', data='小白科技')
    web_action(browser, cmd=cmd.点击, loc='//*[@id="su"]')
    web_action(browser, cmd=cmd.wait, data=3)
    web_action(browser, cmd=cmd.标题, contains_assert='小白')

关键词的使用,看上面示例亦可(xiaobaiauto2>0.1.5.0)

  • 1 导入cmd类

     from xiaobaiauto2.xiaobaiauto2 import cmd
         
    
  • 2 cmd类调用属性

     cmd.关键词
    

若感觉关键词不足以使用,可以直接使用原生方法,示例如下

browser.find_element_by_id('id属性值').click()

代码执行之前,若您需要发送邮件,请将test_first方法中的email的参数值进行自行修改即可

备注
  • 若APP测试需要获取toast信息可以写一个方法添加到自己的项目中,代码样例如下:
    def find_toast(self, message, timeout, poll_frequency):
         new_message = f"//*[@text=\'{message}\']"
         element = WebDriverWait(self.driver, timeout, poll_frequency).until(
             EC.presence_of_element_located((By.XPATH, new_message)))
         return element.text
    

使用

1、命令行运行脚本

pytest --html=report.html --self-contained-html
or
pytest --html=report.html --self-contained-html -m xiaobai_web
or
pytest --html=report.html --self-contained-html -o log_cli=true -o log_cli_level=INFO

2、定时任务界面运行脚本(CMD命令)

xiaobaiauto2Timer

Image text

3.1、xiaobaiauto2Api将raw数据转换成python代码(版本>0.1.3.1可用)

xiaobaiauto2Api -h    # 帮助文档提示
xiaobaiauto2Api -f *.txt -s *.py
xiaobaiauto2Api -f *.txt -x 2
xiaobaiauto2Api -f *.saz -x 2
xiaobaiauto2Api -f *.har -x 2
xiaobaiauto2Api -f *.har -x 3
xiaobaiauto2Api -d D:\example

3.2、xiaobaiauto2 >= 0.1.4.5 支持c参数

xiaobaiauto2Api -c 1 -f 1.har,2.har
xiaobaiauto2Api -c 1 -f 1.har,2.har -d E:\example
xiaobaiauto2Api -c 1 -f 1.har,2.har -d E:\example -s 1_2_compare
xiaobaiauto2Api -c 1 -f 1.har.2.har -d E:\example -x 3   # 生成*.jmx(含提取器、参数化)[>=0.1.7.2]

3.3、xiaobaiauto2 >= 0.1.5.5 支持t参数

xiaobaiauto2Api -t api        // 生成api测试模板
xiaobaiauto2Api -t web        // 生成web测试模板
xiaobaiauto2Api -t app        // 生成app测试模板

3.4、xiaobaiauto2 >= 0.1.6.3 支持i与v参数(请看3.6) 不指定版本默认安装最新版哦

xiaobaiauto2Api -i jdk -v 8                     // 安装jdk8
xiaobaiauto2Api -i jmeter -v 5.3                // 安装jmeter5.3
xiaobaiauto2Api -i chromedriver -v 88           // 安装chromedriver的88版本
xiaobaiauto2Api -i allure -d "D:\Program Files" // 安装allure(会有些慢哦)

3.5、xiaobaiauto2 >= 0.1.6.5 支持mock模拟接口

from xiaobaiauto2.xiaobaiauto2 import mock, MockServer

@mock(uri='/login', response={"errcode": 200, "msg": "登录成功", "data": {"token": "123456"}})
@mock(uri='/register', response={"errcode": 200, "msg": "注册成功", "data": {}})
@MockServer(uri='/index', response={"errcode": 200, "msg": "首页成功", "data": {}})
def run(): pass

if __name__ == '__main__':
    run(port=7777)
  • 导入mock方法

    from xiaobaiauto2.xiaobaiauto2 import mock, MockServer
    
  • 定义mock接口,mock与MockServer无区别,uri为接口路径,response为接口返回值,run为被装饰的函数名称可自定义

    @mock(uri='/login', response={"errcode": 200, "msg": "登录成功", "data": {"token": "123456"}})
    @mock(uri='/register', response={"errcode": 200, "msg": "注册成功", "data": {}})
    @MockServer(uri='/index', response={"errcode": 200, "msg": "首页成功", "data": {}})
    def run(): pass
    
  • 启动mock接口服务, run为上面被装饰的方法名,port为监听的端口(默认6666)

    if __name__ == '__main__':
        run(port=7777)
    
  • jmeter尝试?

    api1: http://127.0.0.1:7777/login
    api2: http://127.0.0.1:7777/register
    api3: http://127.0.0.1:7777/index
    

3.6、xiaobaiauto2 >= 0.1.6.6 支持软件自动安装与环境配置

  • 默认环境为用户环境,配置的是用户环境变量,若要配置系统环境变量,请使用管理员运行即可
    xiaobaiauto2Api -i jdk -v 8 -d D:\
    xiaobaiauto2Api -i jmeter -v 5.3 -d D:\
    xiaobaiauto2Api -i chromedriver -v 88
    xiaobaiauto2Api -i jenkins -d D:\tomcat\webapps
    xiaobaiauto2Api -i git
    xiaobaiauto2Api -i node -v 15 -d D:\
    

3.7、xiaobaiauto2 >= 0.1.8.3 支持软件自动安装与环境配置

  • 管理系统代理服务器(查看、设置、关闭、验证)
    xiaobaiauto2Proxy -h                        # 查看帮助文档
    xiaobaiauto2Proxy                           # 查看系统代理是否开启
    xiaobaiauto2Proxy -e 0 -p 127.0.0.1:8080    # 开启系统代理
    xiaobaiauto2Proxy -e 1                      # 关闭系统代理
    xiaobaiauto2Proxy -c 1                      # 验证系统代理是否可用
    

3.8、xiaobaiauto2 >= 0.2 支持adb命令,提前打开APP

  • 单设备监控APP的点击,点击的路径自动生成XPath表达式
    xiaobaiauto2App
    
  • 多设备单机监控APP的点击,点击的路径自动生成XPath表达式
    xiaobaiauto2App -d 127.0.0.1:62001    // 指定设备号进行监控
    xiaobaiauto2App -i 1                  // 指定序号为1的设备进行监控
    

其他帮助

更新日志

版本功能
0.0.1添加邮件发送,用例排序,chrome提示框禁止等等
0.1.0.1添加自动执行任务功能及UI界面
0.1.1fix缺陷,cmd执行xiaobaiauto2Timer
0.1.2fix缺陷
0.1.3新增验证码识别,支持 *.png *.jpg *.jpeg ,新增部分关键词(暂已关闭)
0.1.3.1fix缺陷
0.1.4.0新增xiaobaiauto2Api命令行工具,可以将raw请求数据转换成python代码
0.1.4.1fix缺陷
0.1.4.2优化与新增Fiddler的saz文件支持
0.1.4.3优化代码
0.1.4.4优化与新增charles的har文件支持,支持批量脚本转换
0.1.4.5优化与新增比较两个har文件并转为Python代码
0.1.4.6fix并支持fiddler导出的har文件转为Python代码
0.1.5.0fix并优化api_action
0.1.5.1优化xiaobaiauto2Api与web_action支持cmd调用关键词
0.1.5.2新增apiTestCase装饰器
0.1.5.3修复xiaobaiauto2Api部分bug
0.1.5.4fix
0.1.5.5add 选项-t template 参考xiaobaiauto2Api -h
0.1.5.6fix
0.1.5.7fix
0.1.6.0add 参数化符{变量}系统自动识别并替换为预设值
0.1.6.1fix
0.1.6.2fix
0.1.6.3add -i, -v 新增命令行安装软件支持mac系统
0.1.6.4fix
0.1.6.5add mock模拟接口
0.1.6.6优化 -i -v 支持jdk jmeter chromdriver jenkins git node
0.1.7.0fix
0.1.7.1fix -i 新增支持allure与svn
0.1.7.2fix -x 新增支持转为jmeter(*.jmx)脚本
0.1.7.3fix
0.1.7.5fix
0.1.7.6优化jmx数据格式
0.1.7.7优化
0.1.8.0优化jmx数据格式
0.1.8.1优化jmx的参数化实现
0.1.8.2优化jmx的实现
0.1.8.3新增xiaobaiauto2Proxy系统代理管理模块
0.1.8.5优化jmx的实现
0.1.8.6优化jmx的实现
0.1.8.7优化jmx的实现
0.1.8.8优化xiaobaiauto2App
0.1.9优化xiaobaiauto2App
0.1.9.1优化mac的环境变量设置
0.1.9.2fix
0.1.9.3fix
0.1.9.5fix
0.1.9.6新增xiaobaiauto2安装软件tomcat
0.1.9.7fix
0.1.9.8fix 支持下载fiddler与postman
0.1.9.9fix 模板的下载路径报错问题
0.2xiaobaiauto2App
0.2.1xiaobaiauto2Api下载软件支持多线程,线程数为本机CPU核数的3倍,暂不支持参数修改
1.0.0优化依赖库
1.0.1fix

Keywords

test auto automation xiaobai xiaobaiauto2 test framework

FAQs

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts