<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Kontrollflussorientierte_Testverfahren</id>
	<title>Kontrollflussorientierte Testverfahren - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Kontrollflussorientierte_Testverfahren"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Kontrollflussorientierte_Testverfahren&amp;action=history"/>
	<updated>2026-06-26T17:05:36Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Wikipedia (Deutsch) – Lokale Kopie</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://wiki-de.moshellshocker.dns64.de/index.php?title=Kontrollflussorientierte_Testverfahren&amp;diff=887444&amp;oldid=prev</id>
		<title>imported&gt;Invisigoth67: typo</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Kontrollflussorientierte_Testverfahren&amp;diff=887444&amp;oldid=prev"/>
		<updated>2026-02-18T06:53:28Z</updated>

		<summary type="html">&lt;p&gt;typo&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;[[Datei:Teststrategien.svg|mini|350px|Zusammenhang verschiedener kontrollflussgraphorientierter Testverfahren.]]&lt;br /&gt;
&lt;br /&gt;
Die &amp;#039;&amp;#039;&amp;#039;kontrollflussorientierten Testverfahren&amp;#039;&amp;#039;&amp;#039;, auch &amp;#039;&amp;#039;&amp;#039;Überdeckungstests&amp;#039;&amp;#039;&amp;#039; genannt, gehören zu der Gruppe der [[Dynamisches Software-Testverfahren#Strukturorientierte Verfahren|strukturorientierten Testmethoden]] von Software.&lt;br /&gt;
&lt;br /&gt;
Die kontrollflussorientierten Testverfahren orientieren sich am [[Kontrollflussgraph]]en des Programms. Es handelt sich bei diesen Tests um [[White Box|White-Box-Testverfahren]], das heißt, die Struktur des Programms muss bekannt sein.&lt;br /&gt;
&lt;br /&gt;
Die einzelnen Testverfahren werden mit &amp;#039;&amp;#039;Cx&amp;#039;&amp;#039; bezeichnet, wobei das „C“ für „Coverage“ steht, was so viel heißt wie die Abdeckung oder die Gesamtheit der ausgewerteten Informationen.&lt;br /&gt;
&lt;br /&gt;
== Nomenklaturen ==&lt;br /&gt;
Es gibt mehrere zueinander sehr ähnlich aussehende, aber in der Bedeutung unterschiedliche Bezeichnungsarten:&lt;br /&gt;
* Beginnt die Bezeichnung mit kleinen c → siehe [[Harry Sneed|Harry M. Sneed]], Mario Winter: &amp;#039;&amp;#039;Testen objektorientierter Software.&amp;#039;&amp;#039; Hanser Verlag, ISBN 3-446-21820-3.&lt;br /&gt;
* Beginnt die Bezeichnung mit einem großen C und steht die nun folgende Ziffer auf der Grundlinie wie das C, z.&amp;amp;nbsp;B. C4 →  Ernest Wallmüller, „Software - Qualitätssicherung in der Praxis“, Hanser Verlag.&lt;br /&gt;
* Beginnt die Bezeichnung mit einem großen C und ist die folgende Ziffer ein Subskript, zum Beispiel C&amp;lt;sub&amp;gt;1&amp;lt;/sub&amp;gt;, liegt also unterhalb der Grundlinie → siehe Standard [[DO-178B]].&lt;br /&gt;
Die [[IEC 61508]] Teil 7 und die davon abgeleiteten Anhänge der [[EN 50128]] verwenden keine Abkürzungen für diese Metriken.&lt;br /&gt;
&lt;br /&gt;
== Die unterschiedlichen Testarten ==&lt;br /&gt;
=== Zeilenüberdeckungstests ===&lt;br /&gt;
Noch vor der Hierarchie der C&amp;lt;sub&amp;gt;x&amp;lt;/sub&amp;gt; Testverfahren steht die von vielen Werkzeugen in der Softwareentwicklung bereitgestellte Zeilenüberdeckungskennzahl. Sie ist etwas unschärfer als C&amp;lt;sub&amp;gt;0&amp;lt;/sub&amp;gt;, orientiert sich auch nicht direkt am Kontrollflussgraph, kann aber oft direkt aus den Informationen gewonnen werden, die Debugger ohnehin liefern.&lt;br /&gt;
&lt;br /&gt;
Bei der Zeilenüberdeckung werden nicht die Anweisungen betrachtet, sondern nur die ausführbaren Quellcodezeilen. Beliebig viele Testfälle für&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
 if(false){print &amp;quot;abgedeckt?&amp;quot;;}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
würden zu einer Zeilenüberdeckung von 100 % führen, während es für das syntaktisch und semantisch identische, aber anders formatierte Programm&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
 if(false){&lt;br /&gt;
   print &amp;quot;abgedeckt?&amp;quot;;&lt;br /&gt;
 }&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
nur zu einer Zeilenüberdeckung von 50 % führt.&lt;br /&gt;
&lt;br /&gt;
In der Regel sind die Unterschiede in der praktischen Anwendung allerdings nicht relevant, da durch andere Maßnahmen in der Softwareentwicklung wie Kodierungsrichtlinien (engl.: &amp;quot;style guides&amp;quot;) eine weitgehende Homogenisierung der Quellcodeformatierung vorliegt.&lt;br /&gt;
&lt;br /&gt;
==== Vorteile ====&lt;br /&gt;
* siehe C&amp;lt;sub&amp;gt;0&amp;lt;/sub&amp;gt;&lt;br /&gt;
* einfachere technische Implementierung über die von [[Debugger]]n gelieferten Zeilennummern&lt;br /&gt;
&lt;br /&gt;
==== Nachteile ====&lt;br /&gt;
* keine Standardmetrik wie C&amp;lt;sub&amp;gt;0&amp;lt;/sub&amp;gt;&lt;br /&gt;
* liefert bei syntaktisch identischen Programmen je nach Formatierung unterschiedliche Werte&lt;br /&gt;
&lt;br /&gt;
=== C&amp;lt;sub&amp;gt;0&amp;lt;/sub&amp;gt;. Anweisungsüberdeckungstest (Statement Coverage) ===&lt;br /&gt;
[[Datei:C0Ueb.png|mini|Zur Anweisungsüberdeckung genügt es, alle Anweisungen(rot) im Kontrollflussgraphen einmal zu testen.]]&lt;br /&gt;
&lt;br /&gt;
Anweisungsüberdeckungstests, auch C0-Test genannt, testen jede Anweisung mindestens ein Mal. Wurde jede Anweisung in einem Programm mindestens einmal ausgeführt, spricht man von vollständiger Anweisungsüberdeckung. Wurde vollständige Anweisungsüberdeckung erreicht, dann steht fest, dass kein [[toter Code]] (Anweisungen, die niemals durchlaufen werden) im Programm existiert.&lt;br /&gt;
&lt;br /&gt;
Anweisungsüberdeckungstests werden selten als Haupttestwerkzeug in einem Vollständigkeitstest eingesetzt, denn dafür sind sie in der Regel zu schwach.&lt;br /&gt;
&lt;br /&gt;
==== Metrik (Messung) ====&lt;br /&gt;
Der Anweisungsüberdeckungsgrad bestimmt sich wie folgt:&lt;br /&gt;
&lt;br /&gt;
:&amp;lt;math&amp;gt;C_{\text{0}} = \frac{\text{Anzahl der durchlaufenen Anweisungen}}{\text{Gesamtanzahl der Anweisungen}} \cdot 100 \quad\%\,&amp;lt;/math&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==== Vorteil ====&lt;br /&gt;
Die Anweisungsüberdeckung bietet folgende Vorteile:&lt;br /&gt;
* sie deckt nicht erreichbare [[Anweisung (Programmierung)|Anweisungen]] im [[Quellcode]] auf&lt;br /&gt;
* Anweisungsüberdeckung ist im Vergleich zu anderen Überdeckungsmaßen schnell zu erreichen&lt;br /&gt;
&lt;br /&gt;
==== Nachteil ====&lt;br /&gt;
Die Anweisungsüberdeckung sollte jedoch nicht als alleiniges Testkriterium verwendet werden, denn:&lt;br /&gt;
* Anweisungsüberdeckung wertet jede Anweisung im Quellcode gleichgewichtig&lt;br /&gt;
* bei Steuerstrukturen (Schleifen, Bedingungen, …) werden die Datenabhängigkeiten nicht beachtet und&lt;br /&gt;
* leere Zweige werden nicht entdeckt&lt;br /&gt;
&lt;br /&gt;
==== Beispiel mit Quellcode ====&lt;br /&gt;
Gegeben sei folgender Quellcode:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
 /* z wird das Doppelte des größeren Werts von x oder y zugewiesen */&lt;br /&gt;
 int z = x;&lt;br /&gt;
 if (y &amp;gt; x)&lt;br /&gt;
    z = y;&lt;br /&gt;
 z *= 2;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
In diesem Fall genügt ein einziger Testfall, um eine vollständige Anweisungsüberdeckung zu erreichen, zum Beispiel x = 0, y = 2. Falls y nicht größer als x ist, wird z = y nicht ausgeführt und die vollständige Anweisungsüberdeckung wird nicht erreicht. Um alle Verzweigungen (if und else) einmal zu testen, sollte die Zweigüberdeckung als Testkriterium verwendet werden.&lt;br /&gt;
&lt;br /&gt;
==== Beispiel mit Kontrollflussgraphen ====&lt;br /&gt;
Gegeben sei folgender Kontrollflussgraph:&lt;br /&gt;
&lt;br /&gt;
[[Datei:Control-flow-graph.svg|400px]]&lt;br /&gt;
&lt;br /&gt;
Für diesen Kontrollflussgraphen kann die Anweisungsüberdeckung mit einem Testfall erreicht werden: {(Start, 1, 2, 3, 4, 5, Stopp)}.&lt;br /&gt;
&lt;br /&gt;
=== C&amp;lt;sub&amp;gt;1&amp;lt;/sub&amp;gt;. Zweigüberdeckungstest (Branch Coverage) ===&lt;br /&gt;
[[Datei:C1Ueb.png|mini|Zweigüberdeckungstest]]&lt;br /&gt;
&lt;br /&gt;
==== Allgemein ====&lt;br /&gt;
Der Zweigüberdeckungstest (C&amp;lt;sub&amp;gt;1&amp;lt;/sub&amp;gt;–Test; auch Kantenüberdeckung, Entscheidungsüberdeckungstest, Branch- oder Edge Coverage genannt) umfasst den Anweisungsüberdeckungstest vollständig.&lt;br /&gt;
Für den C&amp;lt;sub&amp;gt;1&amp;lt;/sub&amp;gt;–Test müssen strengere Kriterien erfüllt werden als beim Anweisungsüberdeckungstest.&lt;br /&gt;
Im Bereich des kontrollflussorientierten Testens wird der Zweigüberdeckungstest als Minimalkriterium angewendet.&lt;br /&gt;
Mit Hilfe des Zweigüberdeckungstests lassen sich nicht ausführbare Programmzweige aufspüren.&lt;br /&gt;
Anhand dessen kann man dann Softwareteile, die oft durchlaufen werden, gezielt optimieren.&lt;br /&gt;
&lt;br /&gt;
Analog zum Anweisungsüberdeckungstest wird, um die Codeabdeckung messbar zu machen, der Code in unten stehender Abbildung durch eine boolesche Hilfsvariable test instrumentiert.&lt;br /&gt;
&lt;br /&gt;
Im Gegensatz zum Anweisungsüberdeckungstest durchläuft der Zweigüberdeckungstest alle Zweige. Der Zweigüberdeckungstest wird auch&lt;br /&gt;
Entscheidungsüberdeckungstest genannt, da die Hilfsvariable mindestens einmal mit dem Wert true und false durchlaufen werden muss.&lt;br /&gt;
In diesem Fall muss die While-Schleife mindestens zweimal durchlaufen werden. Mit dem Durchlaufen der Zweige wird auch sichergestellt, dass&lt;br /&gt;
jeder Knoten (Anweisung) mindestens einmal ausgeführt wird.&lt;br /&gt;
Somit wird auch das Kriterium für den Anweisungsüberdeckungstest erfüllt.&lt;br /&gt;
Daher subsumiert der Zweigüberdeckungstest den Anweisungsüberdeckungstest.&lt;br /&gt;
Schwierig ist es für den Zweigüberdeckungstest Testfälle zu generieren, wo Betriebssystemzustände oder Dateikonstellationen getestet werden müssen. Weiterhin ist diese Technik des Testens zum Testen von ’Schleifen’ und zusammengesetzter Entscheidungen nicht geeignet, da weder Kombinationen von Zweigen, noch kompliziert aufgebaute Entscheidungen in Betracht gezogen werden können. Hierfür müssen Erweiterungen herangezogen werden.&lt;br /&gt;
&lt;br /&gt;
Die [[McCabe-Metrik|Zyklomatische Komplexität]] gibt an, wie viele [[Testfall|Testfälle]] höchstens nötig sind, um eine Zweigüberdeckung zu erreichen.&lt;br /&gt;
&lt;br /&gt;
Weitaus problematischer erweist sich das Zweigüberdeckungsmaß. In dem Fall, dass alle Knoten gleich bewertet sind, verzichtet man auf die Betrachtung der Abhängigkeiten untereinander. Dadurch entsteht kein linearer Zusammenhang zwischen der erreichten Überdeckungsrate und dem Verhältnis zwischen der Anzahl der dazu benötigten Testfälle und der eigentlichen Anzahl der Testfälle, die für die 100-prozentige Zweigüberdeckung notwendig sind. Um den Zweigüberdeckungstest zu verbessern, wird ein Zweig, der abhängig von einem anderen Zweig ist,&lt;br /&gt;
nicht weiter berücksichtigt. Die Zweige, die nicht abhängig sind, werden als primitiv bezeichnet.&lt;br /&gt;
&lt;br /&gt;
==== Metrik ====&lt;br /&gt;
Daher ergibt sich für das Überdeckungsmaß:&lt;br /&gt;
:&amp;lt;math&amp;gt;C_{\text{primitiv}}=\frac{\text{Anzahl der ausgefuehrten primitiven Zweige}}{\text{Anzahl aller primitiven Zweige}} \cdot 100\%\,&amp;lt;/math&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
==== Vorteile ====&lt;br /&gt;
* Deckt nicht erreichbare Zweige auf&lt;br /&gt;
* Fehlerentdeckungsrate bei ca. 33 %. Ein Fünftel davon sind Berechnungsfehler, der Rest sind Steuerflussfehler.&lt;br /&gt;
&lt;br /&gt;
==== Nachteile ====&lt;br /&gt;
* Abhängigkeiten zwischen Bedingungen werden nicht berücksichtigt&lt;br /&gt;
* Schleifen werden nur unzureichend getestet; siehe [[Pfadüberdeckungstest]]&lt;br /&gt;
* komplexe Verzweigungsbedingungen werden nur schwach getestet&lt;br /&gt;
&lt;br /&gt;
==== Beispiele ====&lt;br /&gt;
Gegeben sei folgender Quellcode:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
 /* z wird das Doppelte des größeren Werts von x oder y zugewiesen */&lt;br /&gt;
 int z = x;&lt;br /&gt;
 if (y &amp;gt; x)&lt;br /&gt;
    z = y;&lt;br /&gt;
 z *= 2;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Im Gegensatz zum Anweisungsüberdeckungstest ist nun mehr als ein Testfall notwendig, um eine 100%ige Zweigüberdeckung zu erreichen,&lt;br /&gt;
da sowohl der Fall für den durchlaufenen If-Zweig als auch der Fall für den nicht-durchlaufenen If-Zweig überprüft werden muss:&lt;br /&gt;
&lt;br /&gt;
Testfall 1: x = 0, y = 2&lt;br /&gt;
Testfall 2: x = 2, y = 0&lt;br /&gt;
&lt;br /&gt;
Wie auch im Anweisungsüberdeckungstest sind verschiedene Testfälle möglich, die das geforderte Kriterium erfüllen.&lt;br /&gt;
Nach Ausführung stellt sich heraus, dass das Ergebnis bei beiden Testfällen der Spezifikation entspricht und der Test somit bestanden ist.&lt;br /&gt;
&lt;br /&gt;
Ein weiteres Beispiel:&lt;br /&gt;
&lt;br /&gt;
Gegeben sei folgender Kontrollflussgraph:&lt;br /&gt;
&lt;br /&gt;
[[Datei:Control-flow-graph.svg|400px]]&lt;br /&gt;
&lt;br /&gt;
Eine Zweigüberdeckung ist {(Start, 1, 2, 3, 4, 5 Stopp), (Start, 1, 3, 5, Stopp)}.&lt;br /&gt;
&lt;br /&gt;
=== {{Anker|Pfadüberdeckungstest}}C&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt;. Pfadüberdeckungstest (Path Coverage) ===&lt;br /&gt;
Beim Pfadüberdeckungstest (auch C2-Test bzw. englisch path coverage) werden im Kontrollflussgraphen die möglichen Pfade vom Startknoten bis zum Endknoten betrachtet.&lt;br /&gt;
&lt;br /&gt;
==== Übersicht ====&lt;br /&gt;
* C&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt;a – vollständiger Pfadüberdeckungstest&lt;br /&gt;
* C&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt;b – Boundary-Interior Pfadüberdeckungstest&lt;br /&gt;
* C&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt;c – Strukturierter Pfadüberdeckungstest&lt;br /&gt;
&lt;br /&gt;
==== C&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt;a – vollständiger Pfadüberdeckungstest ====&lt;br /&gt;
Es werden alle möglichen Pfade getestet. Problem: Bei Programmen mit Schleifen kann es extrem viele Pfade geben.&lt;br /&gt;
&lt;br /&gt;
==== C&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt;b – Boundary-Interior-Pfadüberdeckungstest ====&lt;br /&gt;
Im Prinzip wie der C&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt;a-Test, nur dass nun die Schleifendurchläufe auf höchstens zwei reduziert werden.&lt;br /&gt;
&lt;br /&gt;
Für jede Schleife gibt es zwei Gruppen von Pfaden:&lt;br /&gt;
&lt;br /&gt;
===== Boundary-Test =====&lt;br /&gt;
* Jede Schleife wird&lt;br /&gt;
**keinmal und&lt;br /&gt;
**genau einmal betreten und alle Pfade in dem Schleifenkörper werden einmal abgearbeitet.&lt;br /&gt;
&lt;br /&gt;
===== Interior-Test =====&lt;br /&gt;
* Das Schleifeninnere gilt als getestet, wenn alle Pfade, die bei zweimaligem Durchlaufen möglich sind, abgearbeitet wurden.&lt;br /&gt;
&lt;br /&gt;
==== C&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt;c – Strukturierter Pfadüberdeckungstest ====&lt;br /&gt;
Im Prinzip wie der C&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt;b-Test, nur dass nun die Anzahl der Schleifendurchläufe auf eine vorgegebene natürliche Zahl n reduziert wird.&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;Vorteil&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
* Hohe Fehlererkennungsrate&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;Nachteil&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
* nicht ansprechbare Pfade auf Grund von Bedingungen&lt;br /&gt;
&lt;br /&gt;
==== Beispiel ====&lt;br /&gt;
Gegeben sei folgender Kontrollflussgraph:&lt;br /&gt;
&lt;br /&gt;
[[Datei:Control-flow-graph.svg|400px]]&lt;br /&gt;
&lt;br /&gt;
Eine Pfadüberdeckung ist {(Start, 1, 2, 3, 4, 5 Stopp), (Start, 1, 3, 5, Stopp), (Start, 1, 3,  4, 5, Stopp), (Start, 1, 2, 3, 5, Stopp)}.&lt;br /&gt;
&lt;br /&gt;
=== C&amp;lt;sub&amp;gt;3&amp;lt;/sub&amp;gt;. Bedingungsüberdeckungstest (Condition Coverage) ===&lt;br /&gt;
[[Datei:C23Ueb.png|mini|Bedingungsüberdeckungstest]]&lt;br /&gt;
&lt;br /&gt;
Das Problem der bisherigen Überdeckungstests (C&amp;lt;sub&amp;gt;1&amp;lt;/sub&amp;gt;-Test, C&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt;-Test) ist, dass zusammengesetzte, hierarchische Bedingungen nicht ausreichend getestet werden.&lt;br /&gt;
&lt;br /&gt;
* [[#Einfachbedingungsüberdeckungstest|C&amp;lt;sub&amp;gt;3&amp;lt;/sub&amp;gt;a – Einfachbedingungsüberdeckungstest]]&lt;br /&gt;
* [[#Mehrfachbedingungsüberdeckungstest|C&amp;lt;sub&amp;gt;3&amp;lt;/sub&amp;gt;b – Mehrfachbedingungsüberdeckungstest]]&lt;br /&gt;
* [[#minimaler Mehrfachbedingungsüberdeckungstest|C&amp;lt;sub&amp;gt;3&amp;lt;/sub&amp;gt;c – minimaler Mehrfachbedingungsüberdeckungstest]]&lt;br /&gt;
* [[#Bewertung|Bewertung]]&lt;br /&gt;
&lt;br /&gt;
==== {{Anker|Einfachbedingungsüberdeckungstest}} C&amp;lt;sub&amp;gt;3&amp;lt;/sub&amp;gt;a – Einfachbedingungsüberdeckungstest ====&lt;br /&gt;
Jede atomare Bedingung einer Entscheidung muss einmal mit true und einmal mit false getestet werden. Beispiel:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
boolean a,b;&lt;br /&gt;
if(a || b)&lt;br /&gt;
{&lt;br /&gt;
    ...&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Eine minimale Testfallmenge, die die Einfachbedingungsüberdeckung erfüllt, ist &amp;lt;code&amp;gt;{(a=false, b=false), (a=true, b=true)}&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
==== {{Anker|Mehrfachbedingungsüberdeckungstest}} C&amp;lt;sub&amp;gt;3&amp;lt;/sub&amp;gt;b – Mehrfachbedingungsüberdeckungstest ====&lt;br /&gt;
Dieser Test betrachtet alle atomaren Bedingungen einer Bedingung. Wenn n atomare Bedingungen in der Bedingung stehen, dann werden &amp;lt;math&amp;gt;2^n&amp;lt;/math&amp;gt; Kombinationen gebildet.&lt;br /&gt;
&lt;br /&gt;
Das heißt für das obige Beispiel, dass 4 Testfälle gebildet werden.&lt;br /&gt;
&lt;br /&gt;
==== {{Anker|minimaler Mehrfachbedingungsüberdeckungstest}} C&amp;lt;sub&amp;gt;3&amp;lt;/sub&amp;gt;c – minimaler Mehrfachbedingungsüberdeckungstest ====&lt;br /&gt;
Diese Version erstellt mehr Testfälle als C&amp;lt;sub&amp;gt;3&amp;lt;/sub&amp;gt;a und weniger als C&amp;lt;sub&amp;gt;3&amp;lt;/sub&amp;gt;b, indem jede Bedingung (atomar und zusammengestellt) zu true und zu false evaluiert wird. Die logische Struktur wird hierbei berücksichtigt und der C&amp;lt;sub&amp;gt;1&amp;lt;/sub&amp;gt;-Test (Zweigüberdeckungstest) ist vollständig in diesem Test enthalten. Ein weiterer Punkt ist, dass der C&amp;lt;sub&amp;gt;3&amp;lt;/sub&amp;gt;c-Test berechenbar ist. Im obigen Beispiel wird somit der Testfall &amp;lt;code&amp;gt;{(a=false, b=true)}&amp;lt;/code&amp;gt; oder &amp;lt;code&amp;gt;{(a=false, b=false)}&amp;lt;/code&amp;gt; gewählt, da andernfalls die logische Struktur bereits bei der ersten Teilbedingung abbricht.&lt;br /&gt;
&lt;br /&gt;
==== Vorteil ====&lt;br /&gt;
* Hohe Fehlererkennungsrate&lt;br /&gt;
&lt;br /&gt;
==== Nachteil ====&lt;br /&gt;
* nicht ansprechbare Pfade auf Grund von Bedingungen&lt;br /&gt;
&lt;br /&gt;
==== Bewertung ====&lt;br /&gt;
* Unvollständige Auswertung einer Bedingung durch eine Programmiersprache mit sog. short circuit evaluation wie zum Beispiel C++, C, Java, C#.&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;Beispiel:&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
 if (a &amp;amp;&amp;amp; b)&lt;br /&gt;
 {&lt;br /&gt;
     ...&lt;br /&gt;
 }&lt;br /&gt;
 else&lt;br /&gt;
 {&lt;br /&gt;
    // Lies b aus&lt;br /&gt;
 }&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Wenn a false ist, dann ist die Belegung der Variable b egal.&lt;br /&gt;
Zum Beispiel a=false und b=null, dann passiert ein Fehler im else-Zweig.&lt;br /&gt;
&lt;br /&gt;
== Zusammenfassung ==&lt;br /&gt;
{| style=&amp;quot;border:1px solid #000000;&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
!&lt;br /&gt;
! Kurzname&lt;br /&gt;
! erfüllte Bedingung&lt;br /&gt;
! Durchführbarkeit&lt;br /&gt;
|-&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Anweisungsüberdeckungstest&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| C&amp;lt;sub&amp;gt;0&amp;lt;/sub&amp;gt;&lt;br /&gt;
| jede Anweisung wird mindestens einmal ausgeführt&lt;br /&gt;
| relativ einfach&lt;br /&gt;
|-&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Zweigüberdeckungstest&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| C&amp;lt;sub&amp;gt;1&amp;lt;/sub&amp;gt;&lt;br /&gt;
| jede Kante im Kontrollflussgraph (KFG) wird mindestens einmal durchlaufen&lt;br /&gt;
| realistische Mindestanforderung, vertretbarer Aufwand&lt;br /&gt;
|- style=&amp;quot;background:#BBBBBB&amp;quot;&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Pfadüberdeckungstest&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| C&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt;&lt;br /&gt;
|&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| Vollständig&lt;br /&gt;
| C&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt;a&lt;br /&gt;
| Alle möglichen Pfade werden durchlaufen&lt;br /&gt;
| unmöglich bei Schleifen&lt;br /&gt;
|-&lt;br /&gt;
| Boundary-Interior&lt;br /&gt;
| C&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt;b&lt;br /&gt;
| wie C&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt;a, Schleifen werden jedoch nach speziellen Regeln durchlaufen&lt;br /&gt;
| aufwendig&lt;br /&gt;
|-&lt;br /&gt;
| Strukturiert&lt;br /&gt;
| C&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt;c&lt;br /&gt;
| wie C&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt;b, Schleifen werden jedoch genau n-mal durchlaufen&lt;br /&gt;
| aufwendig&lt;br /&gt;
|- style=&amp;quot;background:#BBBBBB&amp;quot;&lt;br /&gt;
| &amp;#039;&amp;#039;&amp;#039;Bedingungsüberdeckungstest&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
| C&amp;lt;sub&amp;gt;3&amp;lt;/sub&amp;gt;&lt;br /&gt;
|&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| Einfachbedingung&lt;br /&gt;
| C&amp;lt;sub&amp;gt;3&amp;lt;/sub&amp;gt;a&lt;br /&gt;
| jede atomare Bedingung wird einmal mit true und false getestet&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
| Mehrfachbedingung&lt;br /&gt;
| C&amp;lt;sub&amp;gt;3&amp;lt;/sub&amp;gt;b&lt;br /&gt;
| jede true/false Kombination der atomaren Bedingungen wird getestet&lt;br /&gt;
| sehr hoher Aufwand&lt;br /&gt;
|-&lt;br /&gt;
| Minimale Mehrfachbedingung&lt;br /&gt;
| C&amp;lt;sub&amp;gt;3&amp;lt;/sub&amp;gt;c&lt;br /&gt;
| jede atomare Bedingung und die Gesamtbedingung wird mit true und false getestet&lt;br /&gt;
| hoher Aufwand&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Bewertung ==&lt;br /&gt;
Die Qualität eines Tests hängt entscheidend vom gewählten Test ab: Wurde nur nach C&amp;lt;sub&amp;gt;0&amp;lt;/sub&amp;gt; mit Überdeckungsgrad 100 % getestet, so ist dies trotzdem kein verlässlicher Indikator für eine fehlerfreie Software. Wurde hingegen mit C&amp;lt;sub&amp;gt;2&amp;lt;/sub&amp;gt; auf 100 % getestet, würde dies ein gutes Kriterium für eine fehlerfreie bzw. -arme Software darstellen. In der Praxis wird dieser Test wegen der [[Kombinatorische Explosion|kombinatorischen Explosion]] nur für [[DO-178B|sicherheitskritische Software]] (zum Beispiel [[Luftfahrt]]) durchgeführt.&lt;br /&gt;
&lt;br /&gt;
Die zweite wichtige Größe ist der Überdeckungsgrad. Dieser ist aber nur bei Verwendung des gleichen Tests untereinander vergleichbar. Bei einem hohen Überdeckungsgrad werden mehr Fehler gefunden als bei einem niedrigen.&lt;br /&gt;
&lt;br /&gt;
== Siehe auch ==&lt;br /&gt;
* [[Kontrollflussgraph]]&lt;br /&gt;
* [[Softwaremetrik]]&lt;br /&gt;
* [[Testabdeckung]]&lt;br /&gt;
&lt;br /&gt;
== Literatur ==&lt;br /&gt;
* Helmut Balzert: &amp;#039;&amp;#039;Lehrbuch der Software-Technik.&amp;#039;&amp;#039; Spektrum Verlag 2008, ISBN 978-3-8274-1161-7.&lt;br /&gt;
* Andreas Spillner, Tilo Linz: &amp;#039;&amp;#039;Basiswissen Softwaretest.&amp;#039;&amp;#039; dpunkt.Verlag 2005, ISBN 3-89864-358-1.&lt;br /&gt;
* Harry M. Sneed, Mario Winter: &amp;#039;&amp;#039;Testen objektorientierter Software.&amp;#039;&amp;#039; Hanser Verlag 2002, ISBN 3-446-21820-3.&lt;br /&gt;
* Ernest Wallmüller: &amp;#039;&amp;#039;Software Qualitätssicherung in der Praxis.&amp;#039;&amp;#039; Hanser Verlag 2001, ISBN 3-446-21367-8.&lt;br /&gt;
&lt;br /&gt;
== Weblinks ==&lt;br /&gt;
* [https://christian-grafe.de/wiki/SEII_Kontrollflussorientierte%20Testverfahren.pdf christian-grafe.de] Seminararbeit über die Thematik (Grundlagen dieser Seite; PDF-Datei; 511&amp;amp;nbsp;kB)&lt;br /&gt;
* [https://christian-grafe.de/wiki/Vortrag_SE2.ppt christian-grafe.de] PowerPoint-Vortrag über die Verfahren und theoretische Grundlagen&lt;br /&gt;
* [https://web.archive.org/web/20160328111201/http://www2.informatik.hu-berlin.de/~hs/Lehre/2004-WS_SWQS/20041124_Ueberdeckung.pdf informatik.hu-berlin.de] Prof. Dr Holger Schlingloff, Fraunhofer Ges., FIRST, &amp;quot;Überdeckungen&amp;quot; (PDF-Datei; 337&amp;amp;nbsp;kB)&lt;br /&gt;
* [https://www.bullseye.com/coverage.html bullseye.com] Steve Cornett, &amp;quot;Code Coverage Analysis&amp;quot;&lt;br /&gt;
* [http://www.rtca.org/onlinecart/product.cfm?id=202 rtca.org] DO-248B, Final Annual Report For Clarification Of DO-178B “Software Considerations In Airborne Systems And Equipment Certification”&lt;br /&gt;
* [https://www.verifysoft.com/Code-Coverage_auf_Embedded-Systemen.pdf verifysoft.com] (PDF; 920&amp;amp;nbsp;kB) Professor Dr. D. Fischer: Code-Coverage auf Embedded Systemen&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Testen (Software)]]&lt;br /&gt;
[[Kategorie:Software-Metrik]]&lt;/div&gt;</summary>
		<author><name>imported&gt;Invisigoth67</name></author>
	</entry>
</feed>