A {@link TestCase} that can define both simple and bulk test methods.
A simple test method is the type of test traditionally supplied by by {@link TestCase}. To define a simple test, create a public no-argument method whose name starts with "test". You can specify the the name of simple test in the constructor of BulkTest
; a subsequent call to {@link TestCase#run} will run that simple test.
A bulk test method, on the other hand, returns a new instance of BulkTest
, which can itself define new simple and bulk test methods. By using the {@link #makeSuite} method, you canautomatically create a hierarchical suite of tests and child bulk tests.
For instance, consider the following two classes:
public class SetTest extends BulkTest { private Set set; public SetTest(Set set) { this.set = set; } public void testContains() { boolean r = set.contains(set.iterator().next())); assertTrue("Set should contain first element, r); } public void testClear() { set.clear(); assertTrue("Set should be empty after clear", set.isEmpty()); } } public class HashMapTest extends BulkTest { private Map makeFullMap() { HashMap result = new HashMap(); result.put("1", "One"); result.put("2", "Two"); return result; } public void testClear() { Map map = makeFullMap(); map.clear(); assertTrue("Map empty after clear", map.isEmpty()); } public BulkTest bulkTestKeySet() { return new TestSet(makeFullMap().keySet()); } public BulkTest bulkTestEntrySet() { return new TestSet(makeFullMap().entrySet()); } }
In the above examples,
SetTest
defines two simple test methods and no bulk test methods;
HashMapTest
defines one simple test method and two bulk test methods. When
makeSuite(HashMapTest.class).run
is executed,
five simple test methods will be run, in this order:
- HashMapTest.testClear()
- HashMapTest.bulkTestKeySet().testContains();
- HashMapTest.bulkTestKeySet().testClear();
- HashMapTest.bulkTestEntrySet().testContains();
- HashMapTest.bulkTestEntrySet().testClear();
In the graphical junit test runners, the tests would be displayed in the following tree:
- HashMapTest
- testClear
- bulkTestKeySet
- bulkTestEntrySet
A subclass can override a superclass's bulk test by returning
null
from the bulk test method. If you only want to override specific simple tests within a bulk test, use the {@link #ignoredTests} method.
Note that if you want to use the bulk test methods, you must define your suite()
method to use {@link #makeSuite}. The ordinary {@link TestSuite} constructor doesn't know how tointerpret bulk test methods.
@version $Id: BulkTest.java 1477661 2013-04-30 14:27:35Z sebb $