Statisches Software-Testverfahren

Dies ist eine alte Version dieser Seite, zuletzt bearbeitet am 19. März 2007 um 22:14 Uhr durch 84.163.45.166 (Diskussion) (Software Reviews). Sie kann sich erheblich von der aktuellen Version unterscheiden.

Verfahren zur Verbesserung der Softwarequalität können in die Gruppen Verifizierende Verfahren, Analysierende Verfahren und Testende Verfahren eingeteilt werden.

Statische Software-Testverfahren (kurz: statische Tests) gehören zu den analysierenden Verfahren und unterteilen sich in

Statische Software-Testverfahren zeichnen sich dadurch aus, dass die Software bei diesen Tests nicht ausgeführt wird (non-execution based methods), im Gegensatz zu dynamischen Software-Testverfahren (execution based methods).

Software Reviews

Bei Reviews nutzt man die menschlichen Denk- und Analysefähigkeiten, um durch Lesen und Nachvollziehen das Testobjekt zu prüfen. Die Norm IEEE 1028 (Standard for Software Reviews and Audits) beschreibt vier Reviewarten:

  • Technisches Review
  • Informelles Review
  • Walkthrough
  • Inspection

Diese Reviewarten können prinzipiell auf alle Arbeitsergebnisse im Softwareentwicklungsprozess (z.B. Anforderungsspezifikationen, Designspezifikationen, Programmcode, Testspezifikationen, Kundendokumentation) angewendet werden und bieten damit die Möglichkeit bereits sehr früh in der Softwareentwicklungsphase qualitätssichernde Maßnahmen durchzuführen. Teilnehmer eines solchen Reviews sind mindestens der Autor des Porgamms, ein Gutachter, ein Protokollant und ein Moderator. Häufig kommt eine standardisierte Checkliste zum Einsatz. Mit Hilfe eines vollständigen Reviews werden 60-90% der Fehler gefunden. Der Walkthrough ist eine Variante mit weniger formalistischem Aufwand und weniger Teilnehmern.

Beispielhafte Checkliste

  1. Funktionsumfang / Spezifikation / Entwurf / Dokumentation
    Ist die Funktion entsprechend der Spezifikation umgesetzt worden?
    Ist die Dokumentation des Programms vorhanden und vollständig
    Enthält das Programm nicht gewünschten / spezifizierten Code?
    ...
  2. Programmierung allgemein
    Gibt es mehrfach vorhandenen Code (z.B. durch mehfaches Kopieren)
    ...
  3. Initialisierung und Deklaration
  4. Methodenaufruf
  5. Felder
  6. ...

Statische Analyse

Die statische Analyse hat das Ziel, Fehler im Programmcode oder in formal beschriebenen Softwaremodellen zu finden. Die statische Analyse mit entsprechender Werkzeugunterstützung durchgeführt. Einsatzgebiete von statischen Analysewerkzeugen sind die Überprüfung gegen Programmierrichtlinien, Datenflussanalyse, Kontrollflussanalyse und Erstellung von Metriken (z.B. Lines of Code (LOC), Zyklomatische Komplexität). Die statische Analyse ist ein Bestandteil des Reviews und deckt somit auch nur einen Teilbereich des Testumfangs ab.

Literatur

  • Andreas Spillner, Theo Linz. Basiswissen Softwaretest Dpunkt Verlag. ISBN 3-89864-358-1
  • Peter Liggesmeyer: Software-Qualität: Testen, Analysieren und Verifizieren von Software. Spektrum, Akademischer Verlag, Heidelberg, Berlin, 2002, ISBN 3-8274-1118-1
  • IEEE 1028 Standard for Software Reviews and Audits