我在我的应用程序中使用Javacc解析器生成器,并希望对我的语法进行一些单元测试。
我想知道javacc是否有任何单元测试框架,就像gUnit用于ANTLR一样。如果没有,那么测试这种语法的最佳方法是什么?
答案 0 :(得分:12)
没有框架,但my book's example code中有一些JavaCC和JJTree语法测试的例子。
Tom Copeland是经典Generating Parsers with JavaCC的作者。所提到的example code是免费提供的。
以下是简单机器人语法的示例测试用例:
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"])*>
}