360 likes | 534 Views
Formal Testing with Input-Output Transition Systems . Ed Brinksma Course 2004. Formal Testing. s SPECS. der : SPECS (TESTS). imp. T s TESTS. IUT IMPS. pass. i IUT MODS. exec : TESTS IMPS (OBS). obs : TESTS MODS (OBS).
E N D
Formal Testing withInput-Output Transition Systems Ed Brinksma Course 2004
Formal Testing s SPECS der : SPECS (TESTS) imp Ts TESTS IUT IMPS pass iIUT MODS exec : TESTS IMPS (OBS) obs : TESTS MODS (OBS) t: (OBS) {fail,pass} OBS fail Test hypothesis : IUTIMPS . iIUT MODS . tTESTS . exec(t,IUT) = obs(t,iIUT) Proof soundness and exhaustivess: iMODS . ( tder(s) . t(obs(t,i)) = pass ) i imp s
Input-Output Transition Systems ? ? S0 dub kwart ! ! S1 S2 coffee tea S4 S3 dub, kwart coffee, tea from user to machine from machine to userinitiative with user initiative with machinemachine cannot refuse user cannot refuse input outputLILU LI LU = LI LU = L LI = { ?dub, ?kwart } LU = { !coffee, !tea }
Input-Output Transition Systems ?dub ?kwart ?dub?kwart ?dub?kwart !coffee !tea ?dub?kwart ?dub?kwart ?a S Input-Output Transition Systems IOTS (LI ,,LU ) LTS (LI , LU ) IOTS is LTS with Input-Outputand always enabled inputs: for all states s,for all inputs ?a LI : LI = { ?dub, ?kwart } LU = { !coffee, !tea }
Input-Output Transition Systems ?kwart ?kwart ?kwart?dub ?dub ?dub?kwart !coffee !tea ?dub?kwart ?dub?kwart ?dub?kwart ?kwart ?dub ?dub ?dub ?kwart?dub ?kwart?dub !coffee !coffee !tea ?dub?kwart ?dub?kwart
Labelled Transition System Testing ioco • SPECS LTS ( LILU ) LTS • MODS IOTS (LI , LU ) LTS • TESTS TTS ( LU , LI ) LTS • OBS traces • obs t || i • der der : LTS ( LTS ) • Which imp ? • (strong, weak, branching, ... ) bisimulation • trace-, testing-, refusal - preorder / equivalence • conf, conf*, aconf, • ioconf, ioco, miocoF
Formal Correctness Input Output Automata quiescence refusal testing canonical tester testing equivalences ioco
Preorders on Transition Systems implementationi specifications environmente environmente is e E. obs ( e, i ) obs (e, s ) i LTS s LTS ? ? ?
Preorders onInput-Output Transition Systems implementationi specifications environmente environmente imp s LTS(LILU) i IOTS(LI,LU) imp IOTS (LI,LU) x LTS (LILU) Observing IOTS where system inputs interact with environment outputs, and v.v.
Preorders onInput-Output Transition System implementationi specifications environmente environmente imp s LTS(LILU) i IOTS(LI,LU) iimps eE. obs (e, i ) obs (e, s ) IOTS(LU,LI)
Input-Output Testing Relation implementationi specifications environmente environmente iot s LTS(LILU) i IOTS(LI,LU) iiots eIOTS(LU,LI). obs (e, i ) obs (e, s ) obs (e, p )= ( traces (e||i ), Ctraces (e||i ) )
Input-Output Refusal Relation implementationi specifications environmente environmente ior s LTS(LILU) i IOTS(LI,LU) iiors eIOTS(LU,LI {}). obs (e, i ) obs (e, s ) obs (e, p )= ( traces (e||i ), Ctraces (e||p) )
Input-Output Testing Relation i,s LTS : ites eLTS. obs (e, i ) obs (e, s ) FP ( i ) FP ( s ) FP ( p ) ={ ,A | A L, traces(p),p afer refuses A} i IOTS(LI,LU): iiots eIOTS(LU,LI). obs (e, i ) obs (e, s ) inputs can never be refused by i outputs can never be refused by e : i afer refuses A A= or A= LU
Input-Output Testing Relation LU !x ii= ii = !xLU{} : i i IOTS(LI,LU): iiots eIOTS(LU,LI). obs (e, i ) obs (e, s ) FP ( i ) FP ( s ) { | traces(i),i afer refuses } { | traces(s),s afer refuses } and { | traces(i),i afer refuses LU} { | traces(s),s afer refuses LU} traces(i) traces(s)and Qtraces(i)Qtraces(s) Qtraces : Quiescent traces = traces ending in quiescence
Input-Output Refusal Relation A A {} : i Failure A : ii ( L ( L) )* :i Failure trace : Failure traces ofi : Ftraces ( i ) = { ( L ( L) )* |i } i IOTS(LI,LU): iiors eIOTS(LU,LI {}). obs (e, i ) obs (e, s ) Ftraces( i ) Ftraces ( s ) where: inputs can never be refused by i outputs can never be refused by e : i afer refuses A A= or A= LU
Input-Output Refusal Relation Straces (i) = Ftraces ( i ) (L{LU})*= { (L{})* | i } i IOTS(LI,LU): iiors eIOTS(LU,LI {}). obs (e, i ) obs (e, s ) Ftraces( i ) Ftraces ( s ) Straces( i ) Straces ( s ) Straces : Suspension traces = Failure traces restricted to refusals quiescence LU =
Input-Output Refusal Relation !x out ( iafter ) = { !xLU {}| i } out ( I ) = { !xLU | i!x, iI } { | ii, i S } i IOTS(LI,LU): iiors eIOTS(LU,LI {}). obs (e, i ) obs (e, s ) Straces( i ) Straces ( s ) (L{})*: out ( iafter ) out ( safter) where:
Implementation Relation ioco i IOTS(LI,LU): iiors (L{})*: out ( iafter ) out ( safter) To allow under-specification : iiocos Straces( s ) : out ( iafter ) out ( safter)
Implementation Relation ioco Correctness expressed by implementation relation ioco: iiocos =defStraces (s) : out (iafter ) out (safter) Intuition: i ioco-conforms to s, iff • if i produces output x after trace , then s can produce x after • if i cannot produce any output after trace , then s cannot produce any output after (quiescence)
Implementation Relationioco out ( P) = { !xLU | p, pP } { | pp, pP } LU !x pp = p p = !xLU{} : p Straces (s) = Ftraces (s) (L{LU})*= { (L{})* | s } !x pafter= { p’ | pp’ } iiocos =defStraces (s) : out (iafter ) out (safter)
Implementation Relation ioco i d ?kwart ?dub ?dub ?kwart !coffee ?dub ?kwart d iiocos =defStraces (s) : out (iafter ) out (safter) {d} { !coffee } { !coffee } {d} {d} {d} out ( iaftere )= out ( iafter ?dub ) = out ( iafter ?dub.?dub ) = out ( iafter ?dub.!coffee) = out ( iafter ?kwart ) = out ( iafter !coffee ) = out ( iafter ?dub.!tea ) = out ( iafterd ) =
Implementation Relation ioco i s ?dub ?dub ?dub !coffee !coffee ?dub iiocos =defStraces (s) : out (iafter ) out (safter) ioco out (iaftere) = {d } out (iafter ?dub) = { !coffee } out (iafter ?dub.!coffee) = {d } out (saftere) = { d} out (safter ?dub) = { !coffee } out (safter ?dub.!coffee) = {d}
Implementation Relation ioco i s ?dub ?dub ?dub !coffee !tea !coffee ?dub iiocos =defStraces (s) : out (iafter ) out (safter) ioco out (iafter ?dub) = { !coffee } out (safter ?dub) = { !coffee, !tea }
Implementation Relation ioco i s ?dub ?dub ?dub !coffee !tea !coffee ioco ?dub ?dub out (iafter ?dub) = { !coffee, !tea } out (safter ?dub) = { !coffee} iiocos =defStraces (s) : out (iafter ) out (safter)
Implementation Relation ioco i s ?dub ?dub ?dub ?dub ?dub !coffee !tea !coffee !tea ?dub ?dub out (iafter ?dub) = { !coffee, !tea } out (safter ?dub) = { !coffee, !tea} iiocos =defStraces (s) : out (iafter ) out (safter) ioco
Implementation Relation ioco i s ?dub ?kwart ?dub ?dub ?kwart !coffee !coffee !tea iiocos =defStraces (s) : out (iafter ) out (safter) ioco out (iafter ?dub) = { !coffee } out (iafter ?kwart) = { !tea } out (safter ?dub) = { !coffee }out (safter ?kwart) = But ?kwart Straces ( s )
Implementation Relation ioco i s ?dub ?kwart ?dub ?kwart ?dub ?kwart !coffee !coffee !tea !tea out (iafter ?dub) = { !coffee } out (iafter ?kwart) = { !tea } out (safter ?dub) = { !coffee }out (safter ?kwart) = { !tea } iiocos =defStraces (s) : out (iafter ) out (safter) ioco
Implementation Relation ioco s i ?kwart ?dub ?kwart ?dub ?dub ?kwart !coffee !coffee !tea ioco ?dub ?kwart out (iafter ?kwart) = { d} out (safter ?kwart) = { !tea } iiocos =defStraces (s) : out (iafter ) out (safter)
Implementation Relation ioco i s ?dub ?dub ?dub ?dub ?dub !coffee !coffee ioco ?dub iiocos =defStraces (s) : out (iafter ) out (safter) out (iafter ?dub) = { d, !coffee } out (safter ?dub) = { !coffee }
Implementation Relation ioco i s ?dub ?dub ?dub ?dub ?dub t !coffee !coffee ?dub iiocos =defStraces (s) : out (iafter ) out (safter) ioco out (iafter ?dub) = { d, !coffee } out (safter ?dub) = { d, !coffee }
Implementation Relation ioco ?dub ?dub ?dub ?dub s ioco i ?dub ?dub ?dub ?dub !tea !tea ?dub ?dub ?dub ?dub !tea !coffee !coffee ?dub ?dub ?dub iiocos =defStraces (s) : out (iafter ) out (safter) s i i ioco s out (iafter ?dub.?dub) = out (safter ?dub.?dub) = { !tea, !coffee } out (iafter ?dub.d.?dub) = { !coffee } out (safter ?dub.d.?dub) = { !tea, !coffee }
Implementation Relation ioco ?kwart ioco ?dub?kwart ioco ?dub !coffee !tea ?dub?kwart ioco ioco ?dub ?kwart ?dub ioco ioco !coffee !coffee !tea
Implementation Relation ioco implementation i specification s ? x (x < 0) ? x (x < 0) ! x ? x (x >= 0) ! -x ! x ? x (x >= 0) ? y ? y sioco i iiocos =defStraces (s) : out (iafter ) out (safter) equation solver for y2 =x : iioco s
Genealogy of ioco Labelled Transition Systems IOTS (IOA, IOSM, IOLTS) Canonical Testerconf Testing Equivalences(Preorders) Quiescent Trace Preorder Repetitive QuiescentTrace Preorder(Suspension Preorder) Refusal Equivalence(Preorder) ioconf ioco
Formal Testing with Transition Systems s LTS der : LTS(TTS) ioco Ts TTS IUT IMPS pass t: (traces){fail,pass} iIUT IOTS exec : TESTS IMPS (OBS) obs : TTS IOTS (traces) traces fail Test hypothesis : IUTIMPS . iIUT IOTS . tTTS . exec(t,IUT) = obs(t,iIUT) Soundness and exhaustivess proved: iIOTS . ( tder(s) . t(obs(t,i)) = pass ) iiocos