<?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=Testautomatisierung</id>
	<title>Testautomatisierung - 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=Testautomatisierung"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Testautomatisierung&amp;action=history"/>
	<updated>2026-05-31T06:11:55Z</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=Testautomatisierung&amp;diff=454318&amp;oldid=prev</id>
		<title>imported&gt;Schotterebene: Revert - Spam</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Testautomatisierung&amp;diff=454318&amp;oldid=prev"/>
		<updated>2022-10-05T18:15:50Z</updated>

		<summary type="html">&lt;p&gt;Revert - Spam&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Unter &amp;#039;&amp;#039;&amp;#039;Testautomatisierung&amp;#039;&amp;#039;&amp;#039; (auch &amp;#039;&amp;#039;&amp;#039;Testautomation&amp;#039;&amp;#039;&amp;#039;) ist die Automatisierung von Aktivitäten im [[Test]] zu verstehen, sowohl beim [[Softwaretest]] als auch bei Hardware.&lt;br /&gt;
&lt;br /&gt;
== Motivation ==&lt;br /&gt;
&lt;br /&gt;
In der Softwareentwicklung ist es besonders wichtig, einen festen, definierten Status der Software zu kennen, so z.&amp;amp;nbsp;B.:&lt;br /&gt;
* Ist die jetzige, neue Softwareversion besser als die alte Version?&lt;br /&gt;
&lt;br /&gt;
Automatische Tests, die nach dem Einspielen einer Änderung unerwünschte Auswirkungen auf andere Funktionen abtesten, werden [[Regressionstest]]s genannt. Sie machen Software bezüglich ihrer Qualität erst messbar und zeigen mögliche Nebeneffekte von vorgenommenen Änderungen direkt und erkennbar an. Sie dienen als direkte Rückkopplung für Entwickler und für Tester, die unter Umständen nicht in der Lage sind, das Gesamtsoftwaresystem auf einmal zu überschauen, sowie zur Erkennung von Nebeneffekten und Folgefehlern.&lt;br /&gt;
&lt;br /&gt;
Die Testautomatisierung liefert demnach eine [[Softwaremetrik|Metrik]], die Anzahl erfolgreicher [[Testfall|Testfälle]] pro [[Testlauf]]. Dadurch können folgende Fragen beantwortet werden:&lt;br /&gt;
* Wann ist eine neue [[Anforderung (Informatik)|Anforderung]] durch eine Software vollständig erfüllt?&lt;br /&gt;
* Wann ist ein [[Programmfehler]] behoben?&lt;br /&gt;
* Wann ist die Arbeit des Entwicklers beendet?&lt;br /&gt;
* Wer ist zu welchem Zeitpunkt wofür verantwortlich?&lt;br /&gt;
* Welche Qualität hat eine neue Software-Version (siehe [[Entwicklungsstadium (Software)]])?&lt;br /&gt;
* Ist die neue Software-Version qualitativ besser als die vorherige Version?&lt;br /&gt;
* Hat ein behobener Fehler oder eine neue Anforderung eine Auswirkung auf bestehende Software (Änderung des Verhaltens der Software)?&lt;br /&gt;
* Ist sichergestellt, dass der Echtbetrieb mit der neuen Software erfolgreich und sicher ist?&lt;br /&gt;
* Was beinhaltet die Software tatsächlich an neuer [[Funktionalität (Produkt)|Funktionalität]] sowie etwaigen Fehlerkorrekturen; ist dies nachvollziehbar?&lt;br /&gt;
* Lässt sich der Liefertermin der Software noch einhalten, wenn eine Einschätzung der momentanen Qualität der Software nicht möglich ist?&lt;br /&gt;
&lt;br /&gt;
Zur Beispielfrage: „Wann ist ein Programmfehler behoben?“ lautet die Antwort in diesem Fall:&lt;br /&gt;
:„Genau dann, wenn alle schon existierenden Testfälle und auch die für den Programmfehler selbst geschriebenen Testfälle erfolgreich beendet wurden.“&lt;br /&gt;
&lt;br /&gt;
Eine Rückmeldung liefert nur der ständige Test, und dieser ist durch [[Automatisierung]] erst möglich und realisierbar.&lt;br /&gt;
&lt;br /&gt;
Ein weiterer Vorteil der Testautomatisierung ist die Beschleunigung des Entwicklungsprozesses. Wo bei Software-Projekten ohne Automatisierung die Produktion, die Installation und der Test nacheinander manuell durchgeführt werden, können bei vollautomatisierten Projekten (also wenn außer dem Test auch Produktion und Installation automatisierbar sind) diese drei Schritte automatisch nacheinander gestartet werden, z.&amp;amp;nbsp;B. in einem nächtlichen Lauf. Je nach Umfang des Projektes kann man gegebenenfalls diesen Ablauf abends starten und am nächsten Morgen das Testergebnis verfügbar haben.&lt;br /&gt;
&lt;br /&gt;
== Automatisierbare Aktivitäten ==&lt;br /&gt;
Prinzipiell lassen sich folgende Aktivitäten automatisieren:&lt;br /&gt;
&lt;br /&gt;
* Testfallerstellung&lt;br /&gt;
** Testdatenerstellung&lt;br /&gt;
** Testskripterstellung&lt;br /&gt;
* Testdurchführung&lt;br /&gt;
* Testauswertung&lt;br /&gt;
* Testdokumentation&lt;br /&gt;
* Testadministration&lt;br /&gt;
&lt;br /&gt;
=== Testfallerstellung ===&lt;br /&gt;
Abhängig vom verwendeten Format zur Beschreibung eines [[Testfall]]es&lt;br /&gt;
lässt sich die Testfallerstellung automatisieren, indem höhersprachliche Beschreibungen &amp;#039;&amp;#039;(Testspezifikationen)&amp;#039;&amp;#039; in dieses Format transformiert werden. Zur Testspezifikation werden Sprachen unterschiedlicher Abstraktionsstufe verwendet: einfache tabellenartige Notationen für [[Testdaten]] und Funktionsaufrufe, [[Skriptsprache]]n (z.&amp;amp;nbsp;B. [[Tcl]], [[Perl (Programmiersprache)|Perl]], [[Python (Programmiersprache)|Python]]), imperative Sprachen (z.&amp;amp;nbsp;B. [[C (Programmiersprache)|C]], [[TTCN-3]]), [[objektorientiert]]e Ansätze ([[JUnit]]) und [[deklarativ]]e und logische Formalismen sowie [[modellbasiertes Testen|modellbasierte Ansätze]] (z.&amp;amp;nbsp;B. [[TPT (Software)|TPT]]). Dabei wird eine weitgehende und möglichst vollautomatische Übersetzung von Artefakten in einer maschinenfernen fachlichen Sprachebene in Artefakte in einer maschinennahen technischen Sprachebene angestrebt. Ein anderer Ansatz ist es, die Testfallerstellung anhand von zu deklarierenden [[Business Object|Geschäftsobjekten]] dynamisch zu generieren. Liegt eine Testspezifikation nicht schon in ablauffähiger Form vor, sondern in einer nicht ausführbaren Sprache (z. B. [[UML]], Excel-Tabelle, oder ähnliches), kann diese unter Umständen mit geeigneten Werkzeugen automatisch in ablauffähige Testfälle übersetzt werden.&lt;br /&gt;
&lt;br /&gt;
==== Testdatenerstellung und Testskripterstellung ====&lt;br /&gt;
Da die Anzahl möglicher Eingabewerte und Abläufe eines Programms oft sehr groß ist, müssen bei der Generierung von Testfällen aus Testspezifikationen Eingabedaten und Abläufe gemäß der zu erzielenden [[Testabdeckung]] ausgewählt werden. Zur Testdatenerstellung kann dabei oft das Datenmodell der Software genutzt werden, zur Testskripterstellung werden beim [[modellbasiertes Testen|modellbasierten Testen]] Verhaltensmodelle der Software verwendet. Lösungen, die ohne Skripten auskommen, sind auf dem kommerziellen Markt auch verfügbar.&lt;br /&gt;
&lt;br /&gt;
=== Testdurchführung ===&lt;br /&gt;
Die Testdurchführung erfolgt heute weitgehend durch vollautomatische Testwerkzeuge. Abhängig vom Zielsystem kommen hier [[Liste von Modultest-Software|Unit-Test-Tools]], Testsysteme für [[Grafische Benutzeroberfläche]]n, [[Lasttest (Computer)|Lasttestsysteme]], [[Hardware in the Loop|Hardware-in-the-loop]]-Prüfstände oder andere Werkzeuge zum Einsatz.&lt;br /&gt;
&lt;br /&gt;
=== Testauswertung ===&lt;br /&gt;
Zur Testauswertung muss das erhaltene Testergebnis mit dem Erwartungswert verglichen werden. Im einfachsten Fall ist hier nur ein Tabellenvergleich vorzunehmen; falls das Sollverhalten allerdings durch logische [[Constraint]]s definiert ist oder extrem komplexe Berechnungen enthält, kann das so genannte [[Orakelproblem]] auftreten. Werden zwei Software-Versionen oder zwei Testzyklen und damit zwei Testergebnisse gegen das Soll-Ergebnis verglichen, so lassen sich Tendenzaussagen und Qualitätsstatistiken berechnen.&lt;br /&gt;
&lt;br /&gt;
=== Testdokumentation ===&lt;br /&gt;
Bei der Testdokumentation wird aus den erhaltenen Testergebnissen ein nachvollziehbarer und verständlicher Testbericht erzeugt. Hierfür können Dokumentgeneratoren und Schablonenwerkzeuge eingesetzt werden.&lt;br /&gt;
&lt;br /&gt;
=== Testadministration ===&lt;br /&gt;
Aufgabe der Testadministration ist die Verwaltung und Versionierung von Testsuiten sowie die Bereitstellung einer adäquaten Benutzungsumgebung. Neben Standardwerkzeugen (z.&amp;amp;nbsp;B. [[Concurrent Versions System|CVS]], [[Eclipse (IDE)|Eclipse]]) gibt es eine Reihe von Spezialwerkzeugen, die speziell auf die Belange des Softwaretests zugeschnitten sind.&lt;br /&gt;
&lt;br /&gt;
== Universelle Architektur zur Testautomatisierung ==&lt;br /&gt;
[[Datei:Testsystem-Architektur.png|miniatur|300px|Universelle Testsystem-Architektur]]&lt;br /&gt;
Für die Automatisierung der oben genannten Aktivitäten existieren verschiedene Tools. Diese fokussieren stets die Lösung spezieller Aufgaben und unterscheiden sich in Bedienphilosophie, Syntax und Semantik. Daher ist es oft schwierig, die richtigen Tools für eine bestimmte Menge von Aktivitäten auszuwählen bzw. die Tools richtig einzusetzen.  Eine Strukturierung und Einordnung der automatisierbaren Aktivitäten zur abstrahierten lösungsneutralen Toolfunktionalität bietet die universelle Testsystem-Architektur. Dazu definiert sie fünf Funktionsebenen: Testmanagement, Testausführung und -auswertung, Testbettsteuerung, Testobjektstimulation und -beobachtung sowie Testobjektumgebung. Die Testsystem-Architektur unterstützt die Integration vorhandener Test-Tools und -Komponenten in Testsysteme und stellt somit eine universelle Grundlage zur Testautomatisierung dar.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;div style=&amp;quot;clear:both;&amp;quot;&amp;gt;&amp;lt;/div&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Software für automatisierte Software-Tests ==&lt;br /&gt;
{{Hauptartikel|Liste von Software für automatisierte Softwaretests}}&lt;br /&gt;
&lt;br /&gt;
== Weblinks ==&lt;br /&gt;
* [https://www.testing-board.com/testautomatisierung/ www.testing-board.com] Expertenartikel zur Testautomatisierung und Listen Testautomatisierungswerkzeuge (de)&lt;br /&gt;
&lt;br /&gt;
== Literatur ==&lt;br /&gt;
* Dmitry Korotkiy: &amp;#039;&amp;#039;Universelle Testsystem-Architektur in der Mechatronik.&amp;#039;&amp;#039; Sierke Verlag, Göttingen 2010. ISBN 978-3-86844-238-0&lt;br /&gt;
* {{Literatur |Autor=Manfred Baumgartner, Stefan Gwihs, [[Richard Seidl]], Thomas Steirer, Marc-Florian Wendland |Titel=Basiswissen Testautomatisierung - Aus- und Weiterbildung zum ISTQB® Advanced Level Specialist – Certified Test Automation Engineer |Auflage=3., akt. u. überarb. |Jahr=2021 |Verlag=dpunkt.verlag |Ort=Heidelberg |ISBN=978-3-86490-675-6 |Seiten=398}}&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Testen (Software)]]&lt;/div&gt;</summary>
		<author><name>imported&gt;Schotterebene</name></author>
	</entry>
</feed>