我正在开发一个具有网格的应用程序,并且只有网格的某些点被认为是有效的。我需要对所有可能的网格值进行广泛测试,或至少对所有边界点进行测试。
我已经尝试过参数化测试。对于数据在一个点之后变得难以管理的事实,它可以正常工作。下面给出了3x3网格的样本测试。
@RunWith(Parameterized.class)
public class GridGameTest {
@Parameters
public static Collection<Object[]> data(){
return Arrays.asList(new Object[][] {
{ 0, 0, false }, { 0, 1, false }, { 0, 2, false },
{ 1, 0, false }, { 1, 1, true }, { 1, 2, false },
{ 2, 0, false }, { 2, 1, false }, { 2, 2, false }
} );
}
private final int x;
private final int y;
private final boolean isValid;
public GridGameTest(int x, int y, boolean isValid){
this.x = x;
this.y = y;
this.isValid = isValid;
}
@Test
public void testParameterizedInput(){
Grid grid = new Grid(3,3);
assertEquals(isValid, grid.isPointValid(new Point(x,y)));
}
}
关于如何分组/管理数据的任何输入,以便我的测试仍然简单易读?
答案 0 :(得分:1)
我会创建一个数据生成器,而不必硬编码所有可能的值。类似的东西:
public static Collection<Object[]> data(){
Object[][] result = new Object[3][3];
for (Boolean flag : new Boolean[]{Boolean.FALSE, Boolean.TRUE})
{
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 3; j++)
{
Object[] row = new Object[] {j, i, flag};
result[i][j] = row;
}
}
}
return Arrays.asList(result);
}
无论如何打印参数都是失败的测试。
答案 1 :(得分:1)
我会将测试分为两组。有效和无效点。如果有很多分数,那么使用@Parameterized
生成它们而不是列出它们。或使用JunitParams从文件中读取它们。如果您希望保留源文件中的所有点,那么我建议使用zohhak:
import static java.lang.Integer.parseInt;
import static junit.framework.Assert.*;
import org.junit.runner.RunWith;
import com.googlecode.zohhak.api.Coercion;
import com.googlecode.zohhak.api.TestWith;
import com.googlecode.zohhak.api.runners.ZohhakRunner;
@RunWith(ZohhakRunner.class)
public class MyTest {
Grid grid = new Grid(3,3);
@TestWith({
"1-1"
})
public void should_be_valid_point(Point point) {
assertTrue(grid.isPointValid(point));
}
@TestWith({
"0-0",
"1-0",
"2-0",
"2-1"
})
public void should_be_invalid_point(Point point) {
assertFalse(grid.isPointValid(point));
}
@Coercion
public Point parsePoint(String input) {
String[] split = input.split("-");
return new Point(parseInt(split[0]), parseInt(split[1]));
}
}