我在我的应用程序中使用 Javacc 解析器生成器,并且想对我的语法进行一些单元测试。
我想知道是否有任何用于 javacc 的单元测试框架,例如 gUnit 用于 ANTLR。如果不是,那么测试这种语法的最佳方法是什么?
我在我的应用程序中使用 Javacc 解析器生成器,并且想对我的语法进行一些单元测试。
我想知道是否有任何用于 javacc 的单元测试框架,例如 gUnit 用于 ANTLR。如果不是,那么测试这种语法的最佳方法是什么?
没有框架,但在我书中的示例代码中有一些针对 JavaCC 和 JJTree 语法的测试示例。
Tom Copeland 是经典的Generating Parsers with JavaCC的作者。所引用的示例代码是免费提供的。
下面是一个简单的 Robot 语法的示例测试用例:
public class RobotTest {
@Test
public void tokenizeMoveCommand() {
String cmd = "STEP 10";
SimpleCharStream cs = new SimpleCharStream(new StringReader(cmd));
RobotTokenManager ltm = new RobotTokenManager(cs);
Token t = ltm.getNextToken();
assertEquals(RobotConstants.STEP, t.kind);
t = ltm.getNextToken();
assertEquals(RobotConstants.NUM, t.kind);
}
@Test(expected = TokenMgrError.class)
public void tokenizeFailure() {
String cmd = "STOP 10";
SimpleCharStream cs = new SimpleCharStream(new StringReader(cmd));
RobotTokenManager ltm = new RobotTokenManager(cs);
ltm.getNextToken();
}
}
语法本身:
options {
BUILD_PARSER=false;
STATIC=false;
}
PARSER_BEGIN(Robot)
public class Robot {}
PARSER_END(Robot)
TOKEN_MGR_DECLS: {
public static void main(String[] args) throws Exception {
java.io.Reader r = new java.io.FileReader(args[0]);
SimpleCharStream scs = new SimpleCharStream(r);
RobotTokenManager mgr = new RobotTokenManager(scs);
for (Token t = mgr.getNextToken(); t.kind != EOF;
t = mgr.getNextToken()) {
System.out.println("Found a " + RobotConstants.tokenImage[t.kind] + ": " + t.image);
}
}
}
SKIP :
{
" "
| "\n"
| "\r"
| "\r\n"
}
TOKEN :
{
<STEP : "STEP">
| <RIGHT : "RIGHT">
| <LEFT : "LEFT">
| <NUM : (["1"-"9"])+ (["0"-"9"])*>
}