1324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/*
2324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver [The "BSD license"]
3324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver Copyright (c) 2009 Shaoting Cai
4324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver All rights reserved.
5324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
6324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver Redistribution and use in source and binary forms, with or without
7324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver modification, are permitted provided that the following conditions
8324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver are met:
9324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver 1. Redistributions of source code must retain the above copyright
10324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    notice, this list of conditions and the following disclaimer.
11324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver 2. Redistributions in binary form must reproduce the above copyright
12324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    notice, this list of conditions and the following disclaimer in the
13324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    documentation and/or other materials provided with the distribution.
14324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver 3. The name of the author may not be used to endorse or promote products
15324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    derived from this software without specific prior written permission.
16324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
17324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver*/
28324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverpackage org.antlr.gunit;
29324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
30324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver/**
31324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver * ITestCase object locates one test case in a gUnit script by specifying the
32324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver * tested rule and the index number of the test case in that group.
33324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver *
34324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver * For example:
35324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver * ----------------------
36324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver * ...
37324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver * varDef:
38324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver * "int i;" OK
39324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver * "float 2f;" FAIL
40324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver * ...
41324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver * ----------------------
42324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver * The "testedRuleName" for these two test cases will be "varDef".
43324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver * The "index" for the "int"-test will be 0.
44324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver * The "index" for the "float"-test will be 1.  And so on.
45324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver *
46324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver * @see ITestSuite
47324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver */
48324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruverpublic interface ITestCase {
49324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
50324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    /**
51324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver     * Get the name of the rule that is tested by this test case.
52324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver     * @return name of the tested rule.
53324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver     */
54324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    public String getTestedRuleName();
55324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
56324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    /**
57324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver     * Get the index of the test case in the test group for a rule. Starting
58324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver     * from 0.
59324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver     * @return index number of the test case.
60324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver     */
61324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver    public int getTestCaseIndex();
62324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver
63324c4644fee44b9898524c09511bd33c3f12e2dfBen Gruver}
64