public abstract class TestCase extends Assert implements Test
setUptearDown.
public class MathTest extends TestCase {
protected double fValue1;
protected double fValue2;
protected void setUp() {
fValue1= 2.0;
fValue2= 3.0;
}
}
For each test implement a method which interacts
with the fixture. Verify the expected results with assertions specified
by calling assertTrue with a boolean.
public void testAdd() {
double result= fValue1 + fValue2;
assertTrue(result == 5.0);
}
Once the methods are defined you can run them. The framework supports
both a static type safe and more dynamic way to run a test.
In the static way you override the runTest method and define the method to
be invoked. A convenient way to do so is with an anonymous inner class.
TestCase test= new MathTest("add") {
public void runTest() {
testAdd();
}
};
test.run();
The dynamic way uses reflection to implement runTest. It dynamically finds
and invokes a method.
In this case the name of the test case has to correspond to the test method
to be run.
TestCase test= new MathTest("testAdd");
test.run();
The tests to be run can be collected into a TestSuite. JUnit provides
different test runners which can run a test suite and collect the results.
A test runner either expects a static method suite as the entry
point to get a test to run or it will extract the suite automatically.
public static Test suite() {
suite.addTest(new MathTest("testAdd"));
suite.addTest(new MathTest("testDivideByZero"));
return suite;
}
TestResult,
TestSuite| Constructor and Description |
|---|
TestCase()
No-arg constructor to enable serialization.
|
TestCase(java.lang.String name)
Constructs a test case with the given name.
|
| Modifier and Type | Method and Description |
|---|---|
int |
countTestCases()
Counts the number of test cases executed by run(TestResult result).
|
protected TestResult |
createResult()
Creates a default TestResult object
|
java.lang.String |
getName()
Gets the name of a TestCase
|
TestResult |
run()
A convenience method to run this test, collecting the results with a
default TestResult object.
|
void |
run(TestResult result)
Runs the test case and collects the results in TestResult.
|
void |
runBare()
Runs the bare test sequence.
|
protected void |
runTest()
Override to run the test and assert its state.
|
void |
setName(java.lang.String name)
Sets the name of a TestCase
|
protected void |
setUp()
Sets up the fixture, for example, open a network connection.
|
protected void |
tearDown()
Tears down the fixture, for example, close a network connection.
|
java.lang.String |
toString()
Returns a string representation of the test case
|
assertEquals, assertEquals, assertEquals, assertEquals, assertEquals, assertEquals, assertEquals, assertEquals, assertEquals, assertEquals, assertEquals, assertEquals, assertEquals, assertEquals, assertEquals, assertEquals, assertEquals, assertEquals, assertEquals, assertEquals, assertFalse, assertFalse, assertNotNull, assertNotNull, assertNotSame, assertNotSame, assertNull, assertNull, assertSame, assertSame, assertTrue, assertTrue, fail, fail, failNotEquals, failNotSame, failSamepublic TestCase()
public TestCase(java.lang.String name)
public int countTestCases()
countTestCases in interface Testprotected TestResult createResult()
TestResultpublic TestResult run()
TestResultpublic void run(TestResult result)
public void runBare()
throws java.lang.Throwable
java.lang.Throwable - if any exception is thrownprotected void runTest()
throws java.lang.Throwable
java.lang.Throwable - if any exception is thrownprotected void setUp()
throws java.lang.Exception
java.lang.Exceptionprotected void tearDown()
throws java.lang.Exception
java.lang.Exceptionpublic java.lang.String toString()
toString in class java.lang.Objectpublic java.lang.String getName()
public void setName(java.lang.String name)
name - The name to set