☀️ 机器学习零代码单元测试平台
零代码、全方位、自动化 测试 方法/函数 的正确性、可用性和性能
机器学习零代码单元测试平台,零代码、全方位、自动化 测试 方法/函数 的正确性、可用性和性能。
用户包含 腾讯 IEG 互动娱乐事业群、腾讯 WXG 微信事业群、快手广告、某市值 4000亿+ 500 强巨头 等。
已被 互联网教育智能技术及应用国家工程实验室 收录。 TommyLemon/APIAuto#19
相比 JUnit, JTest, Mockito, Mockk 等一堆 Compiling testing 工具:
1.其它工具需要每个方法都写一大堆测试代码,需要开发成本、需要解决测试代码的 bug、业务代码更改后需要同步修改测试代码等;
UnitAuto 不需要写任何代码,直接读取方法的属性,自动注入参数,拿到返回值和类成员变量,机器学习自动化校验。
2.UnitAuto 这种 Runtime testing 工具无需 Mock 环境(Application, Context 等),
https://testwo.cn1.quickconnect.cn/vs/sharing/iiP8VK1C#!aG9tZV92aWRlby0xMQ==
被测项目不需要写任何单元测试代码(逻辑代码、注解代码等全都不要),
UnitAuto 会自动生成测试参数,并执行方法,拿到返回值等进行校验。
泛型、接口等自动模拟,异步执行方法自动记录回调过程,都是零代码。
UnitAuto-Admin 是类似 APIAuto 的机器学习零代码测试工具(查看、上传、执行、测试 后端项目中的方法等),
UnitAuto Java 后端 Server 在线 测试
APIJSON Java 后端 Server 在线 测试
UnitAuto Android 客户端 App 直接 下载 (第一次可能失败,返回报错 JSON,一般重试一次就可以)
APIJSON Android 客户端 App 直接 下载 (第一次可能失败,返回报错 JSON,一般重试一次就可以)
UnitAuto-机器学习自动化单元测试平台简介
https://www.bilibili.com/video/BV1Tk4y1R7Yo
UnitAuto-异步回调方法的零代码单元测试
其它 https://search.bilibili.com/all?keyword=UnitAuto
放到你 启动 Application 所在项目的 libs 目录,然后 Eclipse Add to Build Path 或 Idea Add as Library
https://github.com/TommyLemon/UnitAuto/tree/master/UnitAuto-Java-Demo/libs
如果不打 jar/war 包,则可以跳过这个步骤。
依赖方式同步骤 1。
https://github.com/TommyLemon/UnitAuto/tree/master/UnitAuto-Java-Demo/libs
依赖后需要在 Application static 代码块 中初始化
static { UnitAutoApp.init(); }
Controller 提供两个 POST application/json 格式的 HTTP API,分别是
/method/list 动态扫描方法,可以单纯接收入参并转发到 MethodUtil.listMethod(String request)
/method/invoke 动态执行方法,可以单纯接收入参并转发到 MethodUtil.invokeMethod(String request, Object instance, Listener<JSONObject> listener)
拦截 MethodUtil 类中的 INSTANCE_GETTER, JSON_CALLBACK, CLASS_LOADER_CALLBACK 等 interface 的回调方法,
可以支持获取 Context 等环境相关类的实例、转 JSON 对象时过滤特定类、其它自定义逻辑处理,参考 DemoApplication
把 UnitAuto-Apk 导入到你项目 app moudule 所在目录,settings.gradle 中
dependencies { api project(':UnitAuto-Apk') }
在 Application onCreate 方法 中初始化
@Override public void onCreate() { super.onCreate(); UnitAutoApp.init(this); }
在 AndroidManifest.xml 中注册 UnitAutoActivity
<manifest ... > <application ... > <activity android:name="unitauto.apk.UnitAutoActivity" android:launchMode="singleInstance"> </activity> </application> </manifest>
可在你项目的任何界面新增一个按钮或其它形式的入口,仅 DEBUG 模式下展示
<Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:onClick="onClickUnit" android:text="UnitAutoActivity" android:textAllCaps="false" />
点击这个入口跳转到 UnitAutoActivity
public void onClickUnit(View v) { startActivity(UnitAutoActivity.createIntent(this)); }
参考 MainActivity
在 Application onCreate 方法 中配置,参考 Java 后端 Server 中 4.配置环境相关类及自定义处理逻辑
可以直接下载源码解压后用浏览器打开 UnitAuto-Admin/index.html,建议用 Chrome 或 火狐 (Safari、Edge、IE 等可能有兼容问题)。
也可以直接访问官网的环境 http://apijson.cn/unit 或 http://apijson.cn:8081
点右上角设置项 "项目服务器地址 URL",把输入框内基地址改为你主机的地址(例如 http://192.168.0.102:8080 )
右上角登录的默认管理员账号为 13000082001 密码为 123456,
然后点右上角设置项 "查看、同步方法文档",确保被测项目已启动,然后一键导入项目中的方法。
如果测试 Android/iOS App,需要保证 手机/平板 与 使用 UnitAuto-Admin 网页的电脑 连接同一个局域网,
如果使用 Android/iOS 模拟器,则一定都是在同一个局域网,并且可以用 http://localhost:端口 进行访问。
自动管理测试用例 这个功能 需要部署 APIJSONBoot ,见
可以使用以下几种方式:
2.调用 /delegate 代理接口来录制请求的方法、参数、响应等信息 3.打开分享链接来自动填充 方法 URI、参数 JSON、请求头、参数注入配置、设置项 等 4.在界面手动填写 方法 URI、参数 JSON 等再点击上传/分享按钮可点击分享按钮生成分享链接,用浏览器打开即可自动填充。
UnitAuto-Admin 登录后点击 设置项 [查看、同步方法文档],等返回方法属性 JSON 后点 [上传] 按钮
对应发送 HTTP 请求
POST /method/list
{ "query": 2, // 0-数据,1-总数,2-全部 "mock": true, "package": "unitauto.test", "class": "TestUtil", "method": "divide", "types": null }
详细说明见 MethodUtil.listMethod 的注释
https://github.com/TommyLemon/UnitAuto/blob/master/UnitAuto-Java/src/main/java/unitauto/MethodUtil.java#L287-L300
同步方法
unitauto.test.TestUtil.divide
{ "static": true, "methodArgs": [ { // 可省略来自动判断的 type : Boolean,Integer,BigDecimal,String,Object,JSONArray 这几种 JSON 类型 "type": "double", "value": 1 }, { // 支持各种类型,例如 unitauto.demo.domain.User, List<String>, annotation.Annotation[],未注册的要写完整全路径 "type": "double", "value": 2 } ] }
也可以简化为
{ "static": true, "methodArgs": [ "double:1", "double:2" // 如果是 JSON 类型,可以不写类型只写值,例如 true, 1, 3.14, "ok", {"a": 1}, [1, 2, 3] ] }
对应发送 HTTP 请求
POST /method/invoke
{ "package": "unitauto.test", "class": "TestUtil", "method": "divide", "static": true, "methodArgs": [ { "type": "double", "value": 1 }, { "type": "double", "value": 2 } ] }
对应调用 Java 方法
unitauto.test.TestUtil.divide(double, double)
public static double divide(double a, double b) { return a / b; }
异步回调方法
unitauto.test.TestUtil.computeAsync
{ "static": true, "methodArgs": [ "long:8", "long:2", { "type": "unitauto.test.TestUtil$Callback", "value": { "sort()": { // 可以简写为 "sort()": false "type": "Boolean", "return": false }, "setData(D)": { "callback": true } } } ] }
对应调用 Java 方法
unitauto.test.TestUtil.computeAsync(long, long, Callback)
public static Number computeAsync(long a, long b, Callback callback) { new Thread(new Runnable() { @Override public void run() { try { Thread.sleep(3000); } catch (Exception e) {} Boolean sort = callback.sort(); if (sort != null && sort && a > b) { callback.minusAsId(b, a); } else { callback.minusAsId(a, b); } callback.setData("Mock inner interface success!"); } }).start(); return callback.getId(); }
详细说明见 MethodUtil.invokeMethod 的注释
https://github.com/TommyLemon/UnitAuto/blob/master/UnitAuto-Java/src/main/java/unitauto/MethodUtil.java#L353-L424
Jenkins、蓝盾 等 CI/CD 等流水线不支持带 UI 测试,所以提供了这个模式,
通过调用 HTTP API 即可执行用例和查看进度,方便集成到 CI/CD 流水线。
先启动 HTTP 服务
如果运行报错 missing package xxx,说明缺少相关依赖,参考步骤 2 来执行
然后再启动 HTTP 服务。
启动成功后会有提示,点击链接或者复制到浏览器输入框打开即可。
如果托管服务是用 APIJSONBoot-MultiDataSource 部署的,
完成后 target 目录应该有 unitauto-java-demo.jar(springboot-maven-plugin 重新打包) 和 unitauto-java-demo.jar.original(maven 直接打包) 这样的两个 jar 包
2.使用 JaCoCo Agent 作为 Java Agent 来运行 jar 包java -javaagent:libs/jacocoagent.jar=destfile=../jacoco.exec,includes=*,output=tcpserver,port=6300,address=127.0.0.1 -jar target/unitauto-java-demo-2.9.0.jar3.点右侧 Maven > Plugins > jacoco > jacoco:dump > jacoco:report 或 运行以下命令 来导出覆盖率数据和生成查看报告的 HTML 网页
jacoco dump jacoco report
完成后 target 目录应该有 jacoco.exec(覆盖率数据) 和 site/jacoco 目录且里面有 index.html 网页入口文件、jacoco-resources 资源文件夹 等。
用 Chrome/Firefox 浏览器打开 index.html,可以看到覆盖率报告。
Chrome 90+ 对 CORS 请求禁止携带 Cookie 或 Chrome 80-89 强制 same-site Cookie 的策略导致
https://github.com/TommyLemon/UnitAuto/issues/11
右上角设置项与数据库实际配置不一致 等
Tencent/APIJSON#85
不能代理接口、不能展示文档、不能对断言结果纠错 等
TommyLemon/APIAuto#12
托管服务地址改为 http://47.98.196.224:8080
TommyLemon/APIAuto#13
https://www.jacoco.org/jacoco/trunk/doc/agent.html
https://www.jacoco.org/jacoco/trunk/doc/cli.html
还可以搜索并参考 "JaCoCo" 相关文章,例如:
我们是如何做go语言系统测试覆盖率收集的?
https://zhuanlan.zhihu.com/p/149890900
Gcov 查看代码覆盖率
https://zhuanlan.zhihu.com/p/410077415
Python单元测试框架覆盖率-Coverage
https://cloud.tencent.com/developer/article/1513269
https://cloud.tencent.com/developer/news/1309383
更多常见问题
https://github.com/TommyLemon/APIAuto/issues
如果有什么问题或建议可以 去 APIAuto 提 issue,交流技术,分享经验。
如果你解决了某些 bug,或者新增了一些功能,欢迎 提 PR 贡献代码,感激不尽。
APIJSON 🏆 腾讯实时 零代码、全功能、强安全 ORM 库 🚀 后端接口和文档零代码,前端(客户端) 定制返回 JSON 的数据和结构
APIAuto ☔ 敏捷开发最强大易用的接口工具,零代码测试与 AI 问答、生成代码与静态检查、生成文档与光标悬浮注释,腾讯、华为、SHEIN、传音、工行等使用
CVAuto 👁 零代码零标注 CV AI 自动化测试平台 🚀 免除大量人工画框和打标签等,直接快速测试 CV 计算机视觉 AI 图像识别算法
SQLAuto 智能零代码自动化测试 SQL 数据库工具,任意增删改查、任意 SQL 模板变量、一键批量生成参数组合、快速构造大量测试数据
UIGO 📱 零代码快准稳 UI 智能录制回放平台 🚀 3 像素内自动精准定位,2 毫秒内自动精准等待,用户包含腾讯,微信团队邀请分享
apijson-doc APIJSON 官方文档,提供排版清晰、搜索方便的文档内容展示,包括设计规范、图文教程等
APIJSONdocs APIJSON 英文文档,提供排版清晰的文档内容展示,包括详细介绍、设计规范、使用方式等
apijson.org APIJSON 官方网站,提供 APIJSON 的 功能简介、登记用户、作者与贡献者、相关链接 等
APIJSON.NET C# 版 APIJSON ,支持 MySQL, PostgreSQL, SQL Server, Oracle, SQLite
apijson-go Go 版 APIJSON , 基于Go(>=1.18) + GoFrame2, 支持查询、单表增删改、权限管理等
apijson-go Go 版 APIJSON ,支持单表查询、数组查询、多表一对一关联查询、多表一对多关联查询 等
apijson-hyperf PHP 版 APIJSON,基于 Hyperf 支持 MySQL
APIJSON-php PHP 版 APIJSON,基于 ThinkPHP,支持 MySQL, PostgreSQL, SQL Server, Oracle 等
apijson-php PHP 版 APIJSON,基于 ThinkPHP,支持 MySQL, PostgreSQL, SQL Server, Oracle 等
apijson-node 字节跳动工程师开源的 Node.ts 版 APIJSON,提供 nestjs 和 typeorm 的 Demo 及后台管理
uliweb-apijson Python 版 APIJSON,支持 MySQL, PostgreSQL, SQL Server, Oracle, SQLite 等
apijson-practice BAT 技术专家开源的 APIJSON 参数校验注解 Library 及相关 Demo
Android-ZBLibrary Android MVP 快速开发框架,Demo 全面,注释详细,使用简单,代码严谨
https://github.com/TommyLemon/UnitAuto/commits/master
创作不易、坚持更难,右上角点亮 ⭐ Star 支持下本项目吧,谢谢 ^_^
https://gitee.com/TommyLemon/UnitAuto
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4