2.3. Unit Testing
Robustness tests.
Last updated
Was this helpful?
Robustness tests.
Last updated
Was this helpful?
Let us create and define testRobustnessAux()
that checks the robustness of any PQ inheriting AbstractPriorityQueue
:
L6
: the generic type T
is defined specifically for this method such that the priority queue pq
, the list keys
, and the comparator comp
take the same type T
that is comparable.
L7
: any collection that inherits the interface has the member method that takes a and applies each key in the collection to the consumer.
L8
: any collection has the member method that returns the of the collection.
: creates a stream of the collection whose keys are sorted
: creates a collection specified by the .
: returns a collector that transforms the stream into a list.
L9
: iterates each of the sorted keys and compares it to the returned value of pq.remove()
.
What are the advantages of defining a method-level generic type?
The following code shows a traditional way of iterating over a list (that is equivalent to L7
above):
Java 5 introduced an enhanced for loop that simplified the traditional for loop:
The syntax of the above code can be simplified as follows (as shown in L7
):
What are the main differences between object-oriented programming and functional programming?
Let us define the testRobustness()
method that calls the auxiliary method testRobustnessAux()
:
L7-9
: tests different types of max-PQs. The keys need to be sorted in reverse order for it to test the remove()
method.
L11-13
: tests different types of min-PQs. The keys need to be sorted in the natural order for it to test the remove()
method.
The generic types of the PQs in
L4-5
are explicitly coded as<Integer>
, whereas they are simplified to<>
inL7-13
. When do generic types need to be explicitly coded?
Java 8 introduced that enabled functional programming in Java. The following code takes each key
(as a variable) in keys
and applies it to pq.add()
:
Since Java 8, higher-order methods can be defined by parameterizing types of interfaces in the package.