-1

我在我的应用程序中使用 Javacc 解析器生成器,并且想对我的语法进行一些单元测试。

我想知道是否有任何用于 javacc 的单元测试框架,例如 gUnit 用于 ANTLR。如果不是,那么测试这种语法的最佳方法是什么?

4

1 回答 1

12

没有框架,但在我书中的示例代码中有一些针对 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"])*>
}
于 2011-04-03T23:58:01.160 回答