Software testability: Difference between revisions

Content deleted Content added
I've added the testability hierarchy
m A few typos fixed.
Line 45:
* Class V: all cases.
 
It has been proved that each class is strictly included into the next. For instance, testing when we assume that the implementation under test can be any deterministic [[finite-state machine]] for some known alphabetfinite sets of inputs and outputs and with some known number of states belongs to Class I (and all subsequent classes). However, if the number of states is not known, then it only belongs to all classes from Class II on. If the implementation under test must be a deterministic finite-state machine failing the specification for a single trace (and its continuations), and its number of states is unknown, then it only belongs to classes from Class III on. Testing temporal machines where transitions are triggered if inputs are produced within some real-bounded interval only belongs to classes from Class IV on, whereas testing many non-deterministic systems only belong to Class V (but not all, and some even belong to Class I). The inclusion into Class I does not require the simplicity of the computation device, as some testing cases involving implementations written in any programming language, or testing implementations defined as machines depending on continuous magnitudes, have been proved to be in Class I. Other elaborated cases, such as the testing framework by [[Matthew Hennessy]] under must semantics, and temporal machines with rational timeouts, belong to Class II.
 
== Testability of Requirements ==