Java:使用迭代器测试方法

时间:2017-08-24 01:47:02

标签: java unit-testing junit

我的测试方法失败了。我不确定在迭代器中放置什么。目前为空。如果有迭代器,如何测试?

这是完整的主类,它所做的只是搜索数组并返回给定数字的索引:

public class Main {
    public static void main(String[] args) {

    final List<Integer> numbers = Arrays.asList(3, 4, 6, 1, 9);
    final Integer x = Integer.valueOf(1);
    System.out.println(findSame(numbers.iterator(), x, 0));
}
public static final int findSame(Iterator<Integer> iterator, Integer x, int idx) {
    if (!iterator.hasNext()) {
        return -1;
    }

    if (iterator.next().equals(x)) {
        return idx;
    } else {
        return findSame(iterator, x, idx+1);
    }
    }
}

这是我的测试试用方法,它不起作用。

@Test
public void searchNumReturnsIndex1(){
    Main instance = new Main();    

    System.out.println("Index");

    Iterator<Integer> iterator = null;

    int x = 6;

    int expResult = 2;
    int result = Main.findSame(iterator, x, 2);

    assertEquals(expResult, result);  
    }

1 个答案:

答案 0 :(得分:2)

您的测试应该测试一些东西。像,

  1. &#34;如果我有列表[2,3,5,7,11]并且我搜索了7,它应该返回3&#34;
  2. &#34;如果我有列表[2,3,5,7,11]并且我搜索6,它应该返回-1&#34;
  3. 一旦你确定了你的测试应该是什么,它们应该是简短的,简单的测试一个案例。

    @Test
    public void searchFor7InShortListOfPrimes() {
        List<Integer> numbers = Arrays.asList(2, 3, 5, 7, 11);
        assertEquals(3, Main.findSame(numbers.iterator(), 7, 0));  
    }
    
    @Test
    public void searchFor6InShortListOfPrimes() {
        List<Integer> numbers = Arrays.asList(2, 3, 5, 7, 11);
        assertEquals(-1, Main.findSame(numbers.iterator(), 6, 0));  
    }
    

    但测试应涵盖所有可能性。比如,如果列表按降序排列,或者根本没有排序,该怎么办?什么适合你的方法;如果您的算法根本不依赖于此,请不要测试未排序/降序排序。