3.0+26
Automatisierte Erstellung von Basisprozeduren

Einführung

Am Beginn eines typischen QF-Test Projektes werden die ersten Schritte aufgezeichnet und auch meistens erfolgreich ausgeführt. Nach den ersten Erfolgen und einigen solcher Aufnahmen bemerkt man, dass einfaches Aufnehmen oder ein Kopieren/Einfügen Ansatz einige Probleme bereiten, die Tests wartbar zu halten. Denken Sie nur an eine Änderungen im Haupt-Panel des Workflows. In diesem Fall muss beinahe jeder Test angepasst werden. Wegen solcher Probleme empfehlen wir, die Tests modularisiert zu entwickeln und Prozeduren und Variablen einzusetzen. Für eine genauere Beschreibung modularisierter Testentwicklung siehe Abschnitt 8.5.

In Projekten, die eine große Menge an Dialogen und grafischen Elementen beinhalten, ist es mitunter empfehlenswert, solche Prozeduren in komponentenspezifische Prozeduren, z.B. "Klicke Button OK", und in eigenständige Workflow Prozeduren, z.B. "Ein Fahrzeug anlegen", aufzuteilen. Dieser Ansatz ermöglicht es, dass neue Testfälle relativ schnell angelegt werden können, jedoch müssen vorher diese Basisprozeduren erstellt werden.

QF-Test liefert den Procedure Builder, der genau diese Basisprozeduren automatisiert erstellt. Wenn Sie diesen Procedure Builder verwenden, wird sich die Zeit für Aufnahme und Erstellung der Prozeduren für die grafischen Elemente drastisch verkürzen. Damit kann sich der Tester auf seine eigentliche Aufgabe, Testfälle zu erzeugen und zu planen bzw. Testdaten bereitzustellen, konzentrieren.

Die Verwendung vom Procedure Builder

Um die Basisprozeduren automatisiert zu erzeugen, müssen Sie folgende Schritte ausführen:

  • Starten Sie das SUT von QF-Test aus.
  • Gehen Sie im SUT zum Fenster oder der Komponente, für welche Sie die Basisprozeduren erzeugen wollen.
  • Drücken Sie in QF-Test den 'Prozeduren erstellen' Prozeduren erstellen Knopf, wählen Sie den entsprechenden Menüeintrag aus oder nutzen Sie den Hotkey für Prozedurenaufnahme.
  • Führen Sie einen Rechtsklick auf die entsprechende Komponente im SUT durch.
  • Wählen Sie den entsprechenden Aufnahmemodus aus.
  • Stoppen Sie die Prozedurenaufnahme mittels Klick auf den 'Prozeduren erstellen' Knopf, mittels Auswahl des entsprechenden Menüeintrages in QF-Test oder über den Hotkey für Prozedurenaufnahme.

Nun sollten Sie die neu erstellten Packages unter den 'Prozeduren' Knoten der aktuellen Testsuite, in der Sie die Aufzeichnung gestoppt haben, finden. Diese Packages beinhalten die erstellten Prozeduren für die Komponenten. Standardmäßig wird ein Package procbuilder erzeugt. Falls dieses schon existiert, wird ein Package procbuilder1 erzeugt und so weiter. Wenn Sie dieses Package öffnen, finden Sie weitere Packages für bestimmte Funktionen wie check, get, select, wait etc.. Diese beinhalten die Prozeduren für die Komponenten, welche Sie aufgenommen haben. Unter dem check Package finden Sie noch eine weitere Ebene für unterschiedliche Checkarten. Diese Struktur ist die Standardstruktur, welche Sie allerdings anders konfigurieren können. Eine Beschreibung hierfür finden Sie im nächsten Abschnitt.

RecordedProcbuilderSuite
Abbildung 26.1:  Aufgezeichnete Prozeduren

Konfiguration des Procedure Builder

Die Erstellung der Prozeduren wird über eine Template Testsuite gesteuert, diese Testsuite finden Sie unter qftest-8.0.2/include/procbuilderdef.qft. Diese Datei sollte in ein projektspezifisches Verzeichnis kopiert werden, falls Sie diese anpassen möchten. Den Speicherort dieser Datei können Sie dann in den QF-Test Einstellungen unter Konfigurationsdatei für die Prozedurenaufnahme konfigurieren.

Die Template Testsuite beinhaltet Prozedurvorlagen für die am meisten verwendeten GUI Elemente und deren Aktionen. Wenn Sie eine eigene Aktion definieren möchten, können Sie einfach eine entsprechende Prozedur einfügen.

Die Testsuite selbst hat eine bestimmte Struktur. Diese Struktur ist im Abschnitt 26.3.1 beschrieben. Die Definition erlaubt es den Tester, Prozedurvorlagen für Komponenten einer bestimmten Klasse zu erstellen oder für Prozeduren, die sich auf alle Elemente eines Fenster bzw. Dialoges beziehen, eigene Prozeduren zu definieren.

Sie finden auch einige Beispielkonfigurationen unter qftest-8.0.2/demo/procbuilder.

Die Procedure Builder Definitionsdatei

Die automatisierte Erstellung der Basisprozeduren liefert je nach Komponenten unterschiedliche Prozeduren. Ein Textfeld benötigt eine Setzen-Methode für den Text, ein Button braucht eine Drück-Methode und ein Fenster benötigt eine Setzen-Methode, die die Setzen-Methoden aller enthaltenen Elemente aufruft etc..

Procbuilderdef
Abbildung 26.2:  Die Procedure Builder Definitionsdatei

Das oberste 'Package' im 'Prozeduren' Knoten ist der Name des neuerstellen Packages. Der Defaultname hierfür ist procbuilder. Falls das 'Package' procbuilder bereits besteht, wird ein 'Package' procbuilder1 erzeugt usw..

Die nächste Ebene ist die Klassenebene. Hier können Sie ein Package pro Klasse definieren. Das Package benötigt den kompletten Klassenname, wobei jedoch alle '.' durch '_' ersetzt werden, weil Punkte in Packagenamen nicht erlaubt sind. Der Procedure Builder erzeugt die Prozeduren auch für die abgeleiteten Klassen. Falls Ihre Klasse einen '_' beinhalten sollte, dann müssen Sie diesen mit '\_' kennzeichnen.

Die darauffolgenden Ebenen können frei definiert werden, weil diese die Packagestruktur der Prozeduren vorgeben.

Am Ende müssen Sie jedoch eine Prozedur definieren, welche die entsprechenden Schritte beinhaltet.

Sie können auch einige Variablen, z.B. <COMPID>, in der Definition verwenden.

Variablen, z.B. die aktuelle QF-Test ID der Komponente oder der Komponentenname, können für den Prozedurnamen verwendet werden. Des Weiteren können Sie auf die aktuellen Werte eines Textfeldes oder den aktuellen Status einer Checkbox zugreifen. Es ist sogar möglich, die gesamte Packagestruktur variabel zu gestalten. Für eine Übersicht über alle verwendbaren Variablen siehe Kapitel 55.