Testpyramide
Die Testpyramide (engl. Test Automation Pyramid) ist ein von Mike Cohn entwickeltes Konzept zum Testen von Anwendungen: Während Unit-Tests häufig und schnell erfolgen sollen, sollen komplexere und langsamere Integrations- und Systemtests seltener und weniger häufig durchgeführt werden.[1]
Konzept
BearbeitenDas Konzept systematisiert Testverfahren nach Schnelligkeit und verursachten Kosten. Auf der untersten Ebene ordnet es die schnellen Unit Tests ein, die mit wenig Aufwand durchgeführt werden können. Entsprechend häufig sollten sie erfolgen und entsprechend viel Anteil an allen Tests sollen sie einnehmen. Sie bilden die untere, breite Basis der Pyramide.
Auf der zweiten Stufe folgen die Integration Tests, um kritische Schnittstellen zu prüfen, und auf der obersten Stufe die System Tests, die als langsam und wartungsintensiv gelten. Da sie damit auch relativ teuer zu realisieren sind, sollten sie möglichst bewusst eingesetzt und geplant werden.
Anti-Pattern
BearbeitenModerne Testframeworks wie z. B. Selenium erleichtern das Schreiben von Integrations- und Systemtests, wodurch sie häufiger eingesetzt werden. In der Folge können Unit-Tests zunehmend durch die Integrations- und Systemtests verdrängt werden, was aber die Tests komplexer macht. Da sie mehr Zeit benötigen, kann es vorkommen, dass Teams ihre Software seltener Testen, was sich negativ auf die Codequalität auswirken kann. Fachlich wird vom Ice-Cream Cone Anti-Pattern (Eiswaffel) gesprochen.
Weblinks
Bearbeiten- Mike Cohn: The Forgotten Layer of the Test Automation Pyramid. In: mountaingoatsoftware.com vom 17. Dezember 2009. Zuletzt abgerufen am 17. September 2023.
- Marie Poenisch: Die Testpyramide. In: openknowledge.de vom 25. August 2022. Zuletzt abgerufen am 17. September 2023.
Einzelnachweise
Bearbeiten- ↑ Marie Poenisch: Die Testpyramide. In: openknowledge.de vom 25. August 2022. Zuletzt abgerufen am 17. September 2023.