Vermeidung einer Neuverbindung zum Gerät

xice

Mitglied
Hallo,

ich habe folgendes Problem. An meinem PC ist ein Gerät über USB angeschlossen.
Das angeschlossene Gerät wird mittels JUnit Klassen getestet.

Dazu muss die Klasse eine Verbindung zum Gerät aufbauen. Diese Verbindung dauert recht lange.
Das heißt, immer wenn ein Test geändert oder neu ausgeführt wird, muss eine Verbindung zum Gerät aufgebaut werden.

Gibts hier Vorschläge bzw. Methoden, wie man die lästige Neuverbindung vermeiden lässt ?

Danke!
 
Zuletzt bearbeitet von einem Moderator:
S

Spacerat

Gast
Eine Vermittlerklasse, die die Verbindung mit dem Gerät aufrecht hält und den Datenaustausch zwischen Unit und Gerät durchschleift. Die Unit kommuniziert dann nicht mit dem Gerät, sondern mit der Vermittlerklasse.
Manko: Die Unit-Tests werden durch fehlerhafte Implementation der Vermittlerklasse verfälscht.
 
S

Spacerat

Gast
Aus der Frage schliesse ich, dass dir das Prinzip einer Vermittlerklasse nicht wirklich geläufig ist. Die Unit kommuniziert nicht mit dem Gerät, sondern mit der Vermittlerklasse. Die Vermittlerklasse baut bei ihrer Instanzierung eine Verbindung zum Gerät auf und bei ihrer Zerstörung wieder ab (ein Fall für "finalize()" oder einem ShutDownHook). Verbindungsaufbau- und -abbauversuche der Unit zur Vermittlungstelle müssen von der Vermittlungsstelle protokolliert (also emuliert) werden, damit diese im Zweifelsfalle mitteilen kann, dass die Unit nicht verbunden ist, wenn sie Daten sendet. Der Datenaustauch sieht dann ungefähr so aus:
[c]Unit<->Vermittlungsklasse<->Gerät[/c]
Wie dass im einzelnen geht ist von deiner Schnittstelle abhängig.
 

tfa

Top Contributor
Dann muss die "Vermittlerklasse" wohl auch auf einer eigenen VM, d.h. einem eigenen Prozess laufen, da die Verbindung ja nicht abreißen soll, wenn die Testklassen neu gestartet oder neu compiliert werden. Und wie läuft dann die Kommunikation mit dem Vermittler? Das Problem ist wohl nicht so einfach zu lösen.
 
S

Spacerat

Gast
Warum das denn? Bedeutet Testunit etwa immer nur das, was z.B. Eclipse als solche vorgibt? Muss für jede Testunit unbedingt immer 'ne neue JVM gestartet werden? Testunits feuert man doch eigentlich auf Schnittstellen ab, die in ihrer Gesamtheit ohnehin immer vorhanden sind. Da kann man doch recht einfach eine ganze Reihe von Units mit nur einem Start testen.
 

tfa

Top Contributor
Wenn ich das richtig verstehe, dauert der Verbindungsaufbau oder die Initialisierung zu dem Gerät sehr lange. Und wenn du deine Testsuite beendest (weil du die Testfälle verändern willst z.B.), dann ist die Verbidnung weg und muss neu aufgebaut werden.
 

tribalup

Bekanntes Mitglied
Kommt drauf an warum die Verbindung so lange dauert. Kommt es vom hochfahren des Gerätes oder ist es die Anmeldeprozedur selber. Ist ersteres der Fall könnte ja einfach eine Verbindung durch pings etc. aufrechterhalten werden. Ist zweites der Fall wäre noch zu klären ob das Gerät selber progs ausführen kann bzw. freien Speicher für solche hat.
 

xice

Mitglied
Momentan ist der Ablauf folgendermaßen...
Eine Testsuite wird ausgeführt. Diese implementiert eine Klasse die für die Verbindung zum Gerät zuständig ist. Ein Testfall innerhalb dieser Testsuite prüft, ob bereits eine Verbindung besteht. Falls nicht -> Neuverbinden.

Wenn ich das richtig verstehe, dauert der Verbindungsaufbau oder die Initialisierung zu dem Gerät sehr lange. Und wenn du deine Testsuite beendest (weil du die Testfälle verändern willst z.B.), dann ist die Verbidnung weg und muss neu aufgebaut werden.

Genau.
 

xice

Mitglied
Kommt drauf an warum die Verbindung so lange dauert. Kommt es vom hochfahren des Gerätes oder ist es die Anmeldeprozedur selber. Ist ersteres der Fall könnte ja einfach eine Verbindung durch pings etc. aufrechterhalten werden. Ist zweites der Fall wäre noch zu klären ob das Gerät selber progs ausführen kann bzw. freien Speicher für solche hat.

Das Gerät ist bereits hochgefahren. Beim Verbinden werden Initialisierungen und einige checks durchgeführt.
 

xice

Mitglied
Würde dieser Ansatz funktionieren ?

Zwei JVM's, eine ist für die Verbindung des Geräts zuständig und enthält ein Interface zum Gerät. Das heißt muss nur einmal ausgeführt werden und ist immer aktiv.

Die andere nutzt das Interface und steuert das Gerät. Problem dabei ist die Kommunikation der beiden JVMs.
 
S

Spacerat

Gast
Also wenn das Gerät die Verbindung wegen Inaktivität trennt, dann muss die Vermittlungsstelle auf jeden Fall dafür sorgen, dass die Verbindung bestehen bleibt, solange keine Unit-Tests laufen. Und wenn man diese Tests auch noch unterbrechen will (oder sie das aufgrund eines Fehlers selbst tun), muss man entweder mit dem erneuten Verbindungsaufbau leben, oder wie tfa bereits angedeutet hat, die Vermittlerklasse in einem eigenen Thread laufen lassen. Wenn die Verbindung aber nur wegen der Initialisierungen so lange dauert, müssen diese ohnehin auch emuliert werden, was evtl. etwas schneller geht aber dann widerum auch die Testergebnisse verfälscht, wenn es um ConnectionTimeOuts geht. Deswegen ist die Frage, ob diese Aufrechterhaltung der Verbindung überhaupt sinnvoll ist.
 

tfa

Top Contributor
Würde dieser Ansatz funktionieren ?

Zwei JVM's, eine ist für die Verbindung des Geräts zuständig und enthält ein Interface zum Gerät. Das heißt muss nur einmal ausgeführt werden und ist immer aktiv.

Die andere nutzt das Interface und steuert das Gerät. Problem dabei ist die Kommunikation der beiden JVMs.

Ja, so könnte man das machen. Für die Kommunikation könnte man RMI verwenden.
Nur so interessehalber: Wie lange dauert denn der Verbindungsaufbau zu dem Gerät?
 
Würde dieser Ansatz funktionieren ?

Zwei JVM's, eine ist für die Verbindung des Geräts zuständig und enthält ein Interface zum Gerät. Das heißt muss nur einmal ausgeführt werden und ist immer aktiv.

Die andere nutzt das Interface und steuert das Gerät. Problem dabei ist die Kommunikation der beiden JVMs.

Ich hab so was noch nie gemacht, aber eigentlich müsste das doch gehen:
1 JVM die sowohl das Interface enthält als auch die JUnit klassen enthält. Wenn man die JUnit klassen ändert lädt die JVM diese mit dem Classloader erneuert und ruft eine Test-methode auf, die halt in jeder Version JUnit Klassen vorhanden und gleich sein muss, auf.
Dann ist nur noch die Frage wie man diesen Prozess triggert. Dabei könnte vielleicht die JVM alle, sagen wir mal 30 sec überprüfen ob sich die JUnit klasse geändert hat und diese bei Änderung laden und den Testmethodenaufruf ausführen.
 

xice

Mitglied
Ja, so könnte man das machen. Für die Kommunikation könnte man RMI verwenden.
Nur so interessehalber: Wie lange dauert denn der Verbindungsaufbau zu dem Gerät?

Verbindungsdauer ca. 45 Sekunden.

So wie ich das verstanden habe, müssen bei Verwendung von RMI, die Klassen das Interface Serializeable implementieren. Da die genutzten Klassen dies nicht tun führt das zum Problem. Gibts da evtl. eine Alternative ?
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
F Klassen Spaghetti Code Vermeidung Allgemeine Java-Themen 16
P Verschiedene Aspekte einer idempotent API verstehen? Allgemeine Java-Themen 16
Zrebna Ausführung einer Testmethode in der IDE erfolgreich - failt aber via 'mvn test' Allgemeine Java-Themen 5
S Interpreter-Fehler Kann mir das mal einer erklären? Allgemeine Java-Themen 12
Zrebna Aus einer jar-Datei eine exe-Datei erzeugen lassen Allgemeine Java-Themen 37
O Text aus einer Textdatei rausholen, der zwischen zwei Schlüsselworten steht Allgemeine Java-Themen 4
V Umgang mit fehlenden Daten in einer Java-Datenanalyseanwendung Allgemeine Java-Themen 5
M Methodenübersicht einer Klasse einsehen Allgemeine Java-Themen 14
T JNA, Aufruf der Funktionen einer dll Allgemeine Java-Themen 5
I Vom Monolith zu Services in einer Webseite Allgemeine Java-Themen 1
W Variable Initialisierung mit dem Ergebnis einer Regex Allgemeine Java-Themen 1
O Werte einer Generic LinkedList zusammenrechenen Allgemeine Java-Themen 14
C Sortieren und Selektieren einer ArrayList<Point3D> Allgemeine Java-Themen 6
A Einzelne Objekte und Unterobjekte einer ArrayList ausgeben Allgemeine Java-Themen 53
TheSepp Wie kann man Leerzeichen aus einer Array liste entfernen? Allgemeine Java-Themen 10
B Ein Objekt einer Klasse mehreren anderen Klassen zur Verfügung stellen? Allgemeine Java-Themen 6
M Optimierung einer Methode (byte-Geraffel) Allgemeine Java-Themen 2
I Wie kann ich den Wert aus einer If abfrage ausgeben Allgemeine Java-Themen 23
S HTML einer Webseite 1:1 so bekommen wie es auch der Browser anzeigt? Allgemeine Java-Themen 14
melaniemueller Einzelne Zeile aus einer txt Datei in einem String speichern Allgemeine Java-Themen 12
L Java überprüfen lassen, ob sich ein gegebener Pfad / das Programm an sich auf einer CD oder Festplatte befindet Allgemeine Java-Themen 14
J (Geplante) Änderungen an einer Datei vorübergehend speichern und anwenden? Allgemeine Java-Themen 12
ME2002 Fragen aus einer Java Klausur Allgemeine Java-Themen 67
_user_q Obfuscate einer .jar-Datei mit ProGuard? Allgemeine Java-Themen 2
_user_q Verknüpfung einer .jar-Datei (liegt z. B. auf dem Desktop) im Autostart-Ordner erstellen? Allgemeine Java-Themen 20
C Parsen einer sich updatenden Html mithilfe von jsoup Allgemeine Java-Themen 4
E Eine Methode einer extendeten Klasse deakitivieren Allgemeine Java-Themen 12
H Performance einer Monte-Carlo-Simulation verbessern Allgemeine Java-Themen 6
LimDul Kam eine java.net.URL zu einer HashMap und ging als DNS Anfrage wieder heraus Allgemeine Java-Themen 18
E Variablen Nach Übergabe einer Variable den Constructor aufrufen Allgemeine Java-Themen 16
Zeppi NullPointerException in einer if-Abfrage Allgemeine Java-Themen 6
D Abbruch einer ViewScoped Bean in Arbeit Allgemeine Java-Themen 2
Lukas2904 Schleife mit ansteuerung einer Klasse Allgemeine Java-Themen 5
d.lumpi Aus Einer Klasse auf ein Objekt einer anderen Klasse Zugreifen Allgemeine Java-Themen 1
Lukas2904 Wie kann man cps (ClicksPerSecond) in einer GUI anzeigen lassen? Allgemeine Java-Themen 4
O Produziert das Tool "jpackage" (ab JDK 14) .exe Dateien, die auf einer Zielumgebung ohne JRE lauffähig sind ?` Allgemeine Java-Themen 7
R Lambda Expression in einer Methode execute() aufrufen (execute() ist eine Methode aus dem funktionalen Interface Command) Allgemeine Java-Themen 5
Drachenbauer wie kann ich alle instanzen einer Klasse durchsehen, ohne, dass diese in einer Liste erzeugt wurden? Allgemeine Java-Themen 11
N BlueJ Implementation einer Analoguhr Allgemeine Java-Themen 0
O Formatierte String ausgabe bei vier Variablen in einer Zeile Allgemeine Java-Themen 1
N Speicherort einer Datei im Explorer ändern Allgemeine Java-Themen 8
O Datentypen Wie kann ich den Typ einer ArrayList abfragen ? Allgemeine Java-Themen 7
O Leerzeichen und Umlaute im Pfad einer Java Applikation machen Probleme Allgemeine Java-Themen 13
H Mehrere PNG-Files in einer Datei Allgemeine Java-Themen 9
G Java Editor Löschen doppelter Zahlen einer Liste Allgemeine Java-Themen 2
J JSON Daten von einer Webseite erhalten Allgemeine Java-Themen 2
L RegEx für Teile einer Berechnung Allgemeine Java-Themen 14
L Erste Schritte TDD testen einer Methode mit injezierten Services? Allgemeine Java-Themen 12
J Zerlegen einer Zahl Allgemeine Java-Themen 6
Zrebna Wie kann man endgültig aus einer Rekursion ausbrechen? Allgemeine Java-Themen 14
MiMa Person in einer Arraylist hinzugügen mit Prüfung ? Allgemeine Java-Themen 6
Meeresgott Effizientester Weg um nach der Value einer verschachtelten Map aufzulösen Allgemeine Java-Themen 5
H Mehrere Datentypen in einer Arraylist speichern Allgemeine Java-Themen 9
MiMa Prüfziffer einer EAN Nummer berechnen Allgemeine Java-Themen 4
MiMa Erstellungsdatum einer Datei Allgemeine Java-Themen 10
Drachenbauer Wie kann ich einer existierenden Enum von außerhalb veränderte Werte zuweisen? Allgemeine Java-Themen 5
S HTML den ich von einer URL hole nicht identisch mit dem HTML im Browser Allgemeine Java-Themen 1
S Rückgabe einer HttpURLConnection für eine Seite einlesen bei der man eingeloggt ist..? Allgemeine Java-Themen 5
O Java-Applikation tut in Netbeans, als JAR nicht, wegen Pfadangaben einer benötigten Datei Allgemeine Java-Themen 8
M Hilfe bei einer Java Programmieraufgabe! Ab morgen Montag um 08:00 Uhr Allgemeine Java-Themen 5
J Algorithmen Analyse einer Schleife Allgemeine Java-Themen 6
Drachenbauer Wie finde ich den Aufrufer zu einer Methode, die sich nicht in meinem Projekt befindet? Allgemeine Java-Themen 2
J Die Letzte Zahl aus einer Text datei lesen Allgemeine Java-Themen 8
P einen public <Optinal String> in einer anderen Klasse mit einem Int vergleichen Allgemeine Java-Themen 2
A Mithilfe von einer Nummer einen Namen finden n-Beziehung Allgemeine Java-Themen 8
Scream_ilias Auf einer Website die anmeldedaten eingeben Allgemeine Java-Themen 9
V Threads Probleme beim Aufrufen von Methoden einer anderen Klasse (Threads) Allgemeine Java-Themen 14
I Lohnt sich heutzutage der Aufwand einer Portierung für MacOS Allgemeine Java-Themen 8
J Suchen von einer Scannereingabe in einem HashSet Allgemeine Java-Themen 1
M Konstruktor einer Methode Allgemeine Java-Themen 35
L Echtzeitdaten aus einer Webseite ziehen mit Java Allgemeine Java-Themen 19
V EMail, Attachments auslesen von einer Email Allgemeine Java-Themen 0
T Google Links in einer Liste Allgemeine Java-Themen 4
T Sinn einer toString Methode Allgemeine Java-Themen 3
P Durchlaufen einer Queue Allgemeine Java-Themen 9
J Größe einer CD ermitteln Allgemeine Java-Themen 10
L Operatoren Java Reflections: Alle Methoden einer Klasse aufrufen ohne Exceptions Allgemeine Java-Themen 5
H Länge einer verketteten Liste Allgemeine Java-Themen 4
B Quellcode einer Java libary finden um zu copy & paste'n Allgemeine Java-Themen 5
N Daten einer JCoTable in JTextArea anzeigen Allgemeine Java-Themen 7
sascha-sphw Java 9 module Zugriff auf eine resource einer anderen JAR Allgemeine Java-Themen 0
N Generic Type einer Generischen Klasse während der Laufzeit bekommen Allgemeine Java-Themen 2
E Erstellen einer Liste mit einer maximalen Menge an Elementen Allgemeine Java-Themen 13
M Wie kann ich ein int[] Array in einer Methode benutzen? Allgemeine Java-Themen 6
T Compiler-Fehler NoClassDefFoundError beim Laden einer Class Allgemeine Java-Themen 11
H Klassen LibGDX - Verschiedene Klassen als Value in einer Map Allgemeine Java-Themen 8
P Element einer Liste wurde hinzugefügt, aber es gibt keinen Zugriff Allgemeine Java-Themen 2
E Elemente innerhalb einer ArrayList vergleichen Allgemeine Java-Themen 33
J Einen Thread in einer Schleife Allgemeine Java-Themen 2
temi Java Programm aus einer DB laden und starten Allgemeine Java-Themen 2
J int Werte in einer anderen Klasse in Arrays speichern Allgemeine Java-Themen 3
S Hilfe bei dem Auslesen einer YAML Datei Allgemeine Java-Themen 8
D Warum kann ich eine (deflaut) Klasse aus einer Libary in einem anderen Projekt benutzen? Allgemeine Java-Themen 3
B Generelle Frage bei einer Webanwendung / Reduzierung von DB Abfragen Allgemeine Java-Themen 1
ReinerCoder Methode einer Klasse meldet Fehler "misplaced construct(s)" Allgemeine Java-Themen 13
L Fehler bei der Ausführung einer Jar Allgemeine Java-Themen 2
Javafan01 Deklarieren einer Math.random() Zufallszahl Allgemeine Java-Themen 16
A Probleme beim Verstehen einer Aufgabenstellung Allgemeine Java-Themen 11
H Laden einer (Resourcendatei) aus einem Jar-File Allgemeine Java-Themen 17
P Array einer abstrakten Klasse Allgemeine Java-Themen 4

Ähnliche Java Themen

Neue Themen


Oben