compilers-tests

We are now on Lab3. Switch to branch L1 or L1-hard for Lab1. Switch to branch L2 for Lab2.

编译原理 Lab3 一键测试脚本。

使用方法:

第一次运行执行 ./run.sh path_to_parser_binarypath_to_parser_binary 为编译好的 parser 文件。 之后只需要执行 ./run.sh

测试原理

使用了欧先飞学长用C++写的ir解释器

做了几处小修改

  • 原版在遇到read函数时会打印提示信息(stdout),对了方便比对输出,该脚本将提示信息删除了
  • 在输入结束后,如果IR代码仍然需要read(这通常是由于分支跳转有问题导致的),则视为runtime error
  • irsim在运行时会统计运行的指令数。run.sh在全部运行完后会输出总共运行的指令数(不考虑失败样例)

会根据test.json里面的信息,将里面的输入作为ir代码解释执行的输入,然后比对ir代码的输出和test.json里面的输出是否吻合

添加测试文件

请添加 test.cmmtest.json 两个文件。其中

  • test.cmm 是源码文件
  • test.json 是答案描述文件,格式为
[
    [input1, output1, ret_val1],
    [input2, output2, ret_val2],
    ...
    [inputk, outputk, ret_valk]
]

input和output分别对应输入和输出,也为列表,且列表的所有成员均为整型数 示例:(tests/naive.json)

[
    [[], [2, 0, 1, 7], 0]
]

意为,naive.cmm编译成.ir后,仅有一组测试, 该组测试的输入为空,输出为2 0 1 7四个数字。最顶层的main函数应该返回0(由于irsim没有对应接口,它的返回值是解释器的返回值,表示的是解释器是否遇到问题。所以,目前ret_val实际上会被忽略)