Grammarinator 语法生成器使用介绍

本来不想写这篇文章的,但是目前网络上唯一能搜到的使用教程还被设置成了 vip 可看,那我非写不可了。

今天就写到这,我大概会详细研究一下这个工具,后续继续补充。

基本介绍

Grammarinator 是一个随机测试生成器/模糊测试器,它根据输入的 ANTLR v4 语法生成测试用例。

使用

下面以 py 为例,介绍 Grammarinator 的使用。

项目官方 reademe 文件中有的就不写了,这里主要是补充官方 readme 中没有的内容。
https://github.com/renatahodovan/grammarinator

创建测试生成器的命令行语法

测试生成器是 Grammarinator 使用 ANTLR v4 语法用 python 生成的测试生成器脚本。

bash 复制代码
grammarinator-process examples/grammars/HTMLLexer.g4 examples/grammars/HTMLParser.g4 \
  -o examples/fuzzer/

即命令为:

bash 复制代码
grammarinator-process Lexer.g4文件地址 Parser.g4文件地址 \
  -o 测试生成器脚本输出地址

克隆 grammarinator 项目后,在项目根目录执行 pip install grammarinator 安装 grammarinator 后,删除 examples/fuzzer/ 文件下的原始文件,运行下面脚本重新生成:

bash 复制代码
grammarinator-process examples/grammars/HTMLLexer.g4 examples/grammars/HTMLParser.g4 \
  -o examples/fuzzer/

成功运行后,可以看到 example 文件夹下生成了生成器 py 文件。

通过 grammarinator-generate 脚本执行测试器

生成模糊测试器并可选择性地进行自定义后,即可通过 grammarinator-generate 脚本执行该测试器。

bash 复制代码
grammarinator-generate HTMLGenerator.HTMLGenerator \
  -r htmlDocument -d 10 \
  -o examples/tests/test_%d.html -n 100 \
  -s HTMLGenerator.html_space_serializer \
  --sys-path examples/fuzzer/

注意,这里的 HTMLGenerator 是生成的 HTMLGenerator ,而实际工作中,应该使用自定义的 Generator ,因为,HTMLGenerator 是通过 .g4 文件全自动生成的。它只知道"结构",不知道"逻辑"。

运行完上述代码后即可在 tests 文件夹下看到生成的测试用例。

相关推荐
YAY_tyy2 天前
2025 最新版 Node.js 下载安装及环境配置教程
前端·node.js·教程·工具配置
xcLeigh3 天前
Python入门:Python3 正则表达式全面学习教程
python·学习·正则表达式·教程·python3
NPE~4 天前
[工具分享]Maccy —— 优雅的 macOS 剪贴板历史管理工具
macos·教程·工具·实用工具
小锋学长生活大爆炸11 天前
【教程】PicoClaw:在嵌入式设备上部署OpenClaw
docker·github·教程·工具·openclaw·picoclaw
70asunflower12 天前
软件开发全景指南:从概念构思到生产部署
数据库·oracle·教程
风痕天际12 天前
Godot扫雷游戏制作记录1——基础场景搭建
游戏·游戏引擎·godot·gdscript·教程
charlie11451419113 天前
RK3568跑Arch Linux全路程指南(以正点原子的RK3568开发板为例子)
linux·嵌入式·rootfs·教程·环境配置·嵌入式linux·工程实践
charlie11451419116 天前
RK3568跑Ubuntu 24.04全路程指南(以正点原子的RK3568开发板为例子)
linux·笔记·ubuntu·rootfs·教程·环境配置·rk3568
Java后端的Ai之路18 天前
【Python 教程16】-测试基础
开发语言·后端·python·教程
xcLeigh21 天前
Python 项目实战:用 Flask 实现 MySQL 数据库增删改查 API
数据库·python·mysql·flask·教程·python3