Sto cercando di scrivere unit test per una classe di BinarySearchTree
Il keys()
restituire un Iterable
.Si utilizza un'altra classe denominata Queue
in cui i tasti sono accodati e restituiti ..JUnit uguaglianza sperimentazione di un Iterable
The Queue (classe di terze parti) tuttavia non ha alcun uguale() definito.
public class BinarySearchTree<Key extends Comparable<Key>,Value> {
Node root ;
private class Node{
private Key key;
private Value val;
private Node left;
private Node right;
private int N;
public Node(Key k, Value v,int N) {
super();
this.key = k;
this.val = v;
this.N = N;
}
}
public Iterable<Key> keys(){
Queue<Key> q = new Queue<Key>();
inOrder(root,q);
return q;
}
private void inOrder(Node x,Queue q){
if(x == null)return;
inOrder(x.left,q);
q.enqueue(x.key);
inOrder(x.right,q);
}
...
}
cercando di scrivere unit test
@Test
public void testKeys(){
MyBST<String, Integer> st = new MyBST<String, Integer>();
st.put("S",7);
st.put("E",2);
st.put("X",8);
st.put("A",3);
st.put("R",4);
st.put("C",1);
st.put("H",5);
st.put("M",6);
Queue<String> q = new Queue<String>();
q.enqueue("A");
q.enqueue("C");
q.enqueue("E");
q.enqueue("H");
q.enqueue("M");
q.enqueue("R");
q.enqueue("S");
q.enqueue("X");
Iterable<String> actual = st.keys();
assertEquals(q,actual);
}
Questo non
java.lang.AssertionError: expected: std.Queue<A C E H M R S X > but was: std.Queue<A C E H M R S X >
at org.junit.Assert.fail(Assert.java:93)
at org.junit.Assert.failNotEquals(Assert.java:647)
at org.junit.Assert.assertEquals(Assert.java:128)
at org.junit.Assert.assertEquals(Assert.java:147)
at week4.MyBSTTests.testKeys(BSTTests.java:304)
Devo implementare un equals() nella classe terza parte o c'è qualche altro modo per farlo questo per controllare l'uguaglianza? Tutto quello che riuscivo a pensare era in esecuzione un ciclo dequeueing dalla coda q e confrontandolo con quello che i returned.I iteratore non sono sicuro se c'è un modo migliore .. Si prega di avvisare ..
Iterable<String> actual = st.keys();
Iterator<String> actualit = actual.iterator();
while(actualit.hasNext()){
String actualkey = actualit.next();
String exp = q.dequeue();
assertEquals(actualkey,exp);
}
[Confrontando due collezioni in Java] (http://stackoverflow.com/questions/4085353/comparing-two-collections-in-java) –