本来不想写这篇文章的,但是目前网络上唯一能搜到的使用教程还被设置成了 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 文件夹下看到生成的测试用例。
