AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein Delphi Unit-Test -> Integrationstests
Thema durchsuchen
Ansicht
Themen-Optionen

Unit-Test -> Integrationstests

Ein Thema von Mavarik · begonnen am 21. Apr 2017 · letzter Beitrag vom 21. Apr 2017
Antwort Antwort
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.144 Beiträge
 
Delphi 10.3 Rio
 
#1

Unit-Test -> Integrationstests

  Alt 21. Apr 2017, 12:25
Hallo Zusammen...

Da wir ja alle täglich unsere Klassen per Unittests überprüfen, hat ja sicherlich jeder hierzu eine Idee...

Spaß beiseite...

Oft sind Klassen sehr simpel und einfach zu testen. Was aber wenn die Funktionalität einer Klasse von Faktoren wie Kommunikation oder Timing abhängen, was dann?

Beispiel: Eine http Komponente... Für einen ernsthaften Funktionstest wird ein Http-Server benötigt. (Oder eine Simulation von einem)

Bei einer Kommunikation die immer ein Feedback liefert (ACK) mag das noch zu bewerkstelligen sein, aber was ist mit UPnP bzw. UDP / Broadcast Kommunikation.

Der Sender hat keine Ahnung, ob der Empfänger die Nachricht empfangen hat.

Egal wie wir das Kind nennen : Unittest / Integrationstest / ggf. sogar GUI Test, soll für die Fragestellung keine Rolle spielen.

Bleiben wir mal bei dem Beispiel HTTP... Für einen vollständigen Test benötigt man eine Gegenstelle, also einen Http-Server. Das kann natürlich ein MOCK sein der
einen HTTP-Server simuliert (auch die möglichen Fehler). Aber wer hat schon Lust extra noch einen Server zu programmieren?

Dem Unit-Test also eine 2. Exe mitgeben und im Setup starten / im Teardown killen?

Wie testet Ihr solche Klassen?

Mavarik
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
9.648 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: Unit-Test -> Integrationstests

  Alt 21. Apr 2017, 12:48
Das kommt darauf an was alles getestet werden muss.

Bei einem simulierten Server kannst du verschiedene Werte simulieren usw., was du bei einem Test über die normale GUI vermutlich nicht kannst.

Dafür ist es mit TestComplete z.B. sehr einfach beide Seiten zu starten und dann über die Oberfläche zu testen wie ein normaler Bediener die Software bedienen würde.

Beide Varianten werden benutzt. Was man benutzt, hängt davon ab was man genau testen möchte, welchen Aufwand man betreiben möchte, ...
Sebastian Jänicke
AppCentral
  Mit Zitat antworten Zitat
mjustin

Registriert seit: 14. Apr 2008
3.006 Beiträge
 
Delphi 2009 Professional
 
#3

AW: Unit-Test -> Integrationstests

  Alt 21. Apr 2017, 13:15
Warum eine zweite EXE starten? Einfach eine TIdHTTPServer Instanz im Setup erzeugen und im TearDown freigeben.
Michael Justin
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.144 Beiträge
 
Delphi 10.3 Rio
 
#4

AW: Unit-Test -> Integrationstests

  Alt 21. Apr 2017, 13:39
Warum eine zweite EXE starten? Einfach eine TIdHTTPServer Instanz im Setup erzeugen und im TearDown freigeben.
Oft geht es um timing - also braucht man mindestens einen 2. Thread... ggf. besonders bei UDP möchte man gerne die Reaktion im Netzwerk haben - da hilft keine lokale Instance...
  Mit Zitat antworten Zitat
mjustin

Registriert seit: 14. Apr 2008
3.006 Beiträge
 
Delphi 2009 Professional
 
#5

AW: Unit-Test -> Integrationstests

  Alt 21. Apr 2017, 14:28
Warum eine zweite EXE starten? Einfach eine TIdHTTPServer Instanz im Setup erzeugen und im TearDown freigeben.
Oft geht es um timing - also braucht man mindestens einen 2. Thread...
Das ist der Fall - TIdHTTPServer läuft (so wie alle Indy TCP Serverkomponenten) in einem separaten Thread, und erzeugt weitere Threads je Connection.

Ob die TCP Verbindung zwischen Sockets aus zwei verschiedenen Prozessen oder nur innerhalb eines Prozesses stattfinden, macht keinen Unterschied, addressiert wird nur über IP und Portnummer.
Michael Justin
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.144 Beiträge
 
Delphi 10.3 Rio
 
#6

AW: Unit-Test -> Integrationstests

  Alt 21. Apr 2017, 14:39
Warum eine zweite EXE starten? Einfach eine TIdHTTPServer Instanz im Setup erzeugen und im TearDown freigeben.
Oft geht es um timing - also braucht man mindestens einen 2. Thread...
Das ist der Fall - TIdHTTPServer läuft (so wie alle Indy TCP Serverkomponenten) in einem separaten Thread, und erzeugt weitere Threads je Connection.

Ob die TCP Verbindung zwischen Sockets aus zwei verschiedenen Prozessen oder nur innerhalb eines Prozesses stattfinden, macht keinen Unterschied, addressiert wird nur über IP und Portnummer.
Das ist richtig - Auch wenn es hier nicht die Frage ist - besonders bei UDP spielt es schon eine Rolle ob ich einen 1er Ping oder 300 habe...

Auch die Geschwindigkeit der Gegenseite...

Wenn ich in einer Sekunde 100 UDP Nachrichten sende und die Gegenseite nur 40 verarbeiten/abholen kann - hat man schon ein anderes Ergebnis als lokal...
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.475 Beiträge
 
Delphi 12 Athens
 
#7

AW: Unit-Test -> Integrationstests

  Alt 21. Apr 2017, 14:47
Wenn ich in einer Sekunde 100 UDP Nachrichten sende und die Gegenseite nur 40 verarbeiten/abholen kann - hat man schon ein anderes Ergebnis als lokal...
Sebastian's Hinweis auf TestComplete gilt auch und gerade für diesen Fall. Das TC Framework bietet da einen Haufen Möglichkeiten, die Bedingungen von ideal bis äußerst widrig zu konfigurieren. AUch sind unterschiedliche Last-Szenarien realisierbar. Natürlich kann man das alles auch selbst von Hand mit einem integrierten Server nachbauen (auch SmartBear kann nicht zaubern). Das kostet halt nur eine Menge Zeit und ist längst nicht so flexibel.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.027 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#8

AW: Unit-Test -> Integrationstests

  Alt 21. Apr 2017, 19:17
Wenn du genaue und reproduzierbare Ergebnisse willst, dann benutz mocks und implementier das Delay dort.
Dann kannst du einfach testen, wie sich dein Client bei Verzögerungen verhält.

Mittels diverser Patterns sollte das kein Problem darstellen.
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.144 Beiträge
 
Delphi 10.3 Rio
 
#9

AW: Unit-Test -> Integrationstests

  Alt 21. Apr 2017, 19:55
Wenn du genaue und reproduzierbare Ergebnisse willst, dann benutz mocks und implementier das Delay dort.
Dann kannst du einfach testen, wie sich dein Client bei Verzögerungen verhält.

Mittels diverser Patterns sollte das kein Problem darstellen.
Ich denke auch, das ist der beste Weg!
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 17:17 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz