Habt ihr eine Idee wie man Serializierung testen kann..?

sirbender

Top Contributor
Ich will verifizieren ob Serialisierung (aktuell Standard Java ObjectOutputStream) wirklich das identische Objekt zurueckliefert. Dabei ist der ganze Code der die Objekte erzeugt nicht meiner. Die Objekte beinhalten sehr stark verschachtelte Datenstrukturen (AST von Code). Ein simples equals reicht da nicht aus, da nur an der Oberflaeche gekratzt wird ob bei den Objekten eine handvoll an Eigenschaften gleich sind.

Meine Idee ist, einfach ein normal erzeugtes Objekt zu serialisieren und wieder in ein neues Objekt zu deserialisieren und dann das alte und neue Objekt "bitgenau" zu vergleichen. Die Frage ist nur, wie kriege ich die Objekte in "bit-form" damit ich sie vergleichen kann? Gibt es da vielleicht irgendeinen Trick oder Mechanismus den ich nicht kenne? Kann die JVM selbst irgendwie aushelfen?

Ganz toll waere es natuerlich wenn ich dann sogar irgendwie aufspueren koennte wo die Objekte sich unterscheiden falls dies der Fall sein sollte. Also z.B. dass beim deserialisierten Objekt irgendwelche kleinen Interna durch das Serialisieren "vergessen" wurden oder dass beim Deserialisieren etwas schief laeuft.
 

LimDul

Top Contributor
Die einzig sinnvolle Möglichkeit, die ich für so eine Anforderung sehe ist per Reflection ranzugehen und durchs gesamte Objektgeflecht zu traversieren und die Attribute, die dann am Ende Standarddatentypen haben, per equals zu vergleichen.

Allerdings ist die Frage "Warum?" Eigentlich ist das Aufgabe der JVM dafür zu sorgen, dass die Serialisierung richtig arbeitet und ich würde mich normalerweise auch drauf verlassen, dass sie dies tut.
 

White_Fox

Top Contributor
Ich würde auch darauf verzichten, Serialisierung zu testen. Du testest damit Code, der nicht unter deiner Verantwortung steht.

Was du tun kannst, ist, deine richtige Implementierung der Serialisierung zu testen. Dazu sollte es aber reichen, ein einfacheres Objekt zu Serialisieren und wieder zu Deserialisieren.

Worauf du achten solltest, ist, daß sich deine serialisierten Klassen nicht mehr ändern. Es wäre mißlich, wenn du erst Daten irgendwo speicherst, dann im Laufe der Zeit dein Programm erweiterst, die betreffende Klasse erweiterst/Variablen umbenennst/... und dann ein Objekt einlesen willst, daß einem älteren Versionsstand der Klasse entspricht.
 

sirbender

Top Contributor
Die Objektstruktur die ich serialisiere ist extrem komplex und wurde nicht von mir geschrieben. Die Serialisierung funktioniert ueber "Serializeable-Interfaces" samt readObjekt(ObjectInputStream), transienten Feldern, usw.

Ich hatte gehofft, dass es schon Frameworks gibt, die Objekte (Originalinstanzen und deserialisierte Instanzen) auf Gleichheit via Reflection testen und vielleicht auch allgemein die Klassen der Objekte analysieren eventuelle Probleme aufzeigen. Alleine schon z.B. wenn das zu serialisierende Objekt irgendwelche transienten Felder hat die auch tatsaechlich Werte aufweisen, die das deserialisierte Objekt dann nicht hat (kann ja auch sein, dass das so gewollt ist und diese Felder eh nur ueber einen Getter erreichbar sind, der dann die Felder auf korrekte Werte setzt).

Aber scheinbar gibt es ein solches Testframework nicht ;)
 

LimDul

Top Contributor
Die Objektstruktur die ich serialisiere ist extrem komplex und wurde nicht von mir geschrieben. Die Serialisierung funktioniert ueber "Serializeable-Interfaces" samt readObjekt(ObjectInputStream), transienten Feldern, usw.

Ich hatte gehofft, dass es schon Frameworks gibt, die Objekte (Originalinstanzen und deserialisierte Instanzen) auf Gleichheit via Reflection testen und vielleicht auch allgemein die Klassen der Objekte analysieren eventuelle Probleme aufzeigen. Alleine schon z.B. wenn das zu serialisierende Objekt irgendwelche transienten Felder hat die auch tatsaechlich Werte aufweisen, die das deserialisierte Objekt dann nicht hat (kann ja auch sein, dass das so gewollt ist und diese Felder eh nur ueber einen Getter erreichbar sind, der dann die Felder auf korrekte Werte setzt).

Aber scheinbar gibt es ein solches Testframework nicht ;)
Wie auch?

Serialisierung garantiert dir, dass die Daten auf den nicht transienten Feldern nach serialisieren und einlesen wieder gleich sind.

Transiente Felder sind davon ausgenommen. Was mit denen passiert, hat nichts mehr mit Technik zu tun sondern mit Fachlichkeit und kann daher nicht generell getestet werden. Weil die sind ja bewusst transient, damit muss auch fachlich definiert werden, was beim speichern und laden damit passieren soll. Und das kann dir kein Technik-Tool abnehmen.
 

sirbender

Top Contributor
Das mit den transienten Feldern war nur ein Beispiel wonach ein Framework suchen und in einem Report dem User praesentieren koennte.

Meine Probleme haben nichts mit transienten Feldern zu tun...das ist ja leicht zu checken.
 

White_Fox

Top Contributor
Inwieweit hast du das komplexe Objekt, daß du serialisieren willst, denn selber verstanden? Das erscheint mir für dein weiteres Vorhaben notwendig zu sein.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
T Habt ihr mir ein paar Lerntipps für Java? Allgemeine Java-Themen 5
KonradN Mal eine Frage zu Binary Serialization Allgemeine Java-Themen 15
D Hat Java eine Library um JavaScript auszuwerten? Allgemeine Java-Themen 2
dokan wie kann ich eine funktionierende Suchleiste erstellen Allgemeine Java-Themen 1
B Wie erstelle ich dazu eine Abfrage ob der Button gedrückt wurde? Allgemeine Java-Themen 8
J Integration pay Pale in eine JavaFx Desktop Application Allgemeine Java-Themen 1
berserkerdq2 Wenn ich einfach eine GIF in den Scenebuilder als Bild reinpacke, wird das dann asl Gif angezeigt Allgemeine Java-Themen 1
8u3631984 Strukturiertes Logging : Jedes Feld in eine seperate Zeile - aber wie ? Allgemeine Java-Themen 2
berserkerdq2 Gibt es eine saubere Dokumentation von Jfoenix? Allgemeine Java-Themen 1
M Eigene Datenstruktur um eine Menge zu speichern Allgemeine Java-Themen 3
A Wie schreibe ich eine For-Schleife in ein Stream API um? Allgemeine Java-Themen 12
E Es ist nicht möglich, eine Batch-Anweisung auszuführen. Allgemeine Java-Themen 9
T Eine Frage des Designs Allgemeine Java-Themen 2
R Best Practice Erfahrungswerte für eine Migration von JSF nach Angular (oder anderes JS-Framework) Allgemeine Java-Themen 1
H Eine Linie verkürzen Allgemeine Java-Themen 5
N rekursion mehrfach eine Methode Öffnen Allgemeine Java-Themen 4
berserkerdq2 Wenn ich eine Methode nur jede 50ms ausführen will, wie mach ich das? Allgemeine Java-Themen 4
berserkerdq2 Wie synchronisiere ich eine for-Schleife Allgemeine Java-Themen 12
berserkerdq2 Wie mache ich in IJVM eine if verzweigung? Allgemeine Java-Themen 27
F Gibt es mittlerweile eine Alternative zu DaisyDiff Allgemeine Java-Themen 2
_user_q Was brauche ich, um eine eigene "Search for updates"-Funktion einzubauen? Allgemeine Java-Themen 1
E Eine Methode einer extendeten Klasse deakitivieren Allgemeine Java-Themen 12
LimDul Kam eine java.net.URL zu einer HashMap und ging als DNS Anfrage wieder heraus Allgemeine Java-Themen 18
pizza_dox_9999 Wie füge ich eine "eigene" ScriptEngine dem ScriptEngineManager? Allgemeine Java-Themen 3
F Kennt ihr eine Library um 2 HTML Seiten zu diffen? Allgemeine Java-Themen 8
Y ImagePanel von anderer Klasse in eine MainFrame Klasse hinzufügen. Allgemeine Java-Themen 1
OnDemand Anzeigen was eine Applikation macht Allgemeine Java-Themen 1
T Problem beim Umwandeln in eine Jar-Datei Allgemeine Java-Themen 3
J Eine Frage zu den Threads und Task Allgemeine Java-Themen 1
Tobero Wie bekomme ich in welchem Quadrat sich eine Position in einem Grid befindet Allgemeine Java-Themen 11
Tobero Wie kann man eine Poisson Disc Sampler? Allgemeine Java-Themen 7
M Openjdk - gibt es auch eine Openjre? 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
S Noch eine Design-Frage zu Setter Allgemeine Java-Themen 6
N Arrayliste in eine Datei speichern Allgemeine Java-Themen 4
J Öffnen eine jar-Datei Allgemeine Java-Themen 11
Zrebna Gibt es eine Möglichkeit eine NPE zu vermeiden, wenn null returned wird? Allgemeine Java-Themen 3
S Klassen Einfügen von unbekannter menge an Variablen in eine Klasse mithilfe von ASM Allgemeine Java-Themen 5
R Wo müsste ich im Code eine Änderung vornehmen? Allgemeine Java-Themen 6
S Rückgabe einer HttpURLConnection für eine Seite einlesen bei der man eingeloggt ist..? Allgemeine Java-Themen 5
S Gibt es eine Moeglichkeit die Runtime Ausführung zu analysieren..? Allgemeine Java-Themen 7
S Wenn eine Klasse zwei Interfaces mit derselben Methodensignatur implementiert: welche wird aufgerufen? Allgemeine Java-Themen 15
Drachenbauer warum bekomme ich hier eine NullPointerException Allgemeine Java-Themen 6
M Gibt es eine API die den aktuellen Wert eines Indikators beim Trading zurückgibt? Allgemeine Java-Themen 7
X Collections Gibt es eine Klasse welche die Vorteile von List und HashMap vereint, aber konstante Laufzeit (O(1)) hat in Java? Allgemeine Java-Themen 4
N Eine stelle der Fibonacci-Zahlenfolge ausgeben. Allgemeine Java-Themen 4
E Hat der Compiler einen Fehler oder warumbeendet return nicht eine Methode ? Allgemeine Java-Themen 7
W Collections Suche etwas Sorted-List-Artiges...hat jemand eine Idee? Allgemeine Java-Themen 13
L Methoden Über Reflections eine Methode mit aufrufen Allgemeine Java-Themen 3
S Kann ich eine Methode schreiben die alle Arten von funktionalen Interfaces akzeptiert..? Allgemeine Java-Themen 21
Drachenbauer Wie kann eine vorgegebene Farbe über einen String erkannt werden? Allgemeine Java-Themen 11
J Datenstruktur für eine Map erstellen Allgemeine Java-Themen 2
sascha-sphw Java 9 module Zugriff auf eine resource einer anderen JAR Allgemeine Java-Themen 0
pkm Kann eine ServerSocket-Klasse nicht stateful sein? Allgemeine Java-Themen 4
B Aufruf der Methode ergibt eine Exception Allgemeine Java-Themen 13
I Eine Anwendung so gut wie möglich beschützen Allgemeine Java-Themen 9
M Wie kann man eine void Methode mit Variablen von zwei verschiedenen Objekten ausführen? Allgemeine Java-Themen 15
X Wie mache ich hier eine Rekursion rein ? Allgemeine Java-Themen 7
K OOP Suche Hilfe + Erklärung für eine Hausaufgabe Allgemeine Java-Themen 1
N Über einen Button in JavaFX ein Event über eine Pipeline schicken(Netty) Allgemeine Java-Themen 1
M Login in eine Webseite mit Java Allgemeine Java-Themen 3
A NetBeans Suche Programmierer für eine Belegarbeit Allgemeine Java-Themen 11
D Warum kann ich eine (deflaut) Klasse aus einer Libary in einem anderen Projekt benutzen? Allgemeine Java-Themen 3
L Übergabe an eine eher einfache Java- Applikation wegen Kündigung Allgemeine Java-Themen 1
C Ein Iterator ist eine Implementierung des Interface Iterable? Allgemeine Java-Themen 2
M Schlüsselworte Was ist eine Java Spezifikation + JSR? Allgemeine Java-Themen 11
E RMI NULL-Pointer-Exeception wenn der RMI-Proxy eine Methode deligiert Allgemeine Java-Themen 2
E RMI FWH: RMI- Wie erstelle ich stubs dynamisch, bzw. unterdrücke eine Statisch-Warnung? Allgemeine Java-Themen 0
J Eine bestimmte Zahl im Integer ändern Allgemeine Java-Themen 9
Q-bert Strings aus der JList in eine Datenbank speichern Allgemeine Java-Themen 1
D Möglichkeit mit GAE eine Table auszulesen und eine csv zu schreiben Allgemeine Java-Themen 22
S Korrekte Pfadangaben damit eine .jar Datei unter Windwos läuft. Allgemeine Java-Themen 24
D Eine Forschleife mit Threads abarbeiten um es zu schneller zu machen. Ist das möglich? Allgemeine Java-Themen 20
S Wie kann ich eine kleine Stelle in meinem Code mit multiplen Threads abarbeiten..? Allgemeine Java-Themen 20
B Gibt es eine Funktion die den Datentyp einer Variablen ermittelt? Allgemeine Java-Themen 8
R bei eclipse von java in eine andere programmiersprache wechseln? Allgemeine Java-Themen 2
D Pivot-Wahl beim QuickSort steigert die Effizienz, eine Lüge??? Allgemeine Java-Themen 17
C Eclipse einstellen, dass eine bestimmte JDK benutzt werden soll Allgemeine Java-Themen 3
M Klassen Eine Klasse in mehreren Klassen einbinden Allgemeine Java-Themen 11
A Best Practice Java - eine Art Plugin-Struktur Allgemeine Java-Themen 3
S wie rufe ich mit .jar datei eine .bat auf? Allgemeine Java-Themen 15
R Signatur von Methoden in eine Datei schreiben? Allgemeine Java-Themen 4
perlenfischer1984 Functionsparameter prüfen und eine Exception werfen !? Allgemeine Java-Themen 11
J Mehrere Wörter getrennt in eine Array einlesen, wie ? Allgemeine Java-Themen 7
E Methoden Hat jemand eine gute Lösung? Allgemeine Java-Themen 5
Z NullPointerException beim Schreiben einer ArrayList in eine Datei Allgemeine Java-Themen 6
Exdroid BlueJ Wie bekomme ich die Ausgabe in eine TXT Datei? Allgemeine Java-Themen 2
G Methoden Aus einem Event, wo ich weiß, dass es ausgeführt werden wird, eine Get-Methode basteln Allgemeine Java-Themen 8
F Wie kann ich auf einem System prüfen, ob eine lib verfügbar ist? Allgemeine Java-Themen 2
Tausendsassa Interface Eine Gui von einer anderen schließen lassen Allgemeine Java-Themen 3
S Threads Kann mir jemand helfen eine parallele Hilfsklasse zu implementieren..? Allgemeine Java-Themen 3
S Best Practice Brauche eine Idee für eine Java Projekt! Allgemeine Java-Themen 11
P Zwei ArrayLists: Ohne die eine überhaupt anzurühren, wird sie verändert Allgemeine Java-Themen 2
M Eine Datei im Speicher erneut laden(?) Allgemeine Java-Themen 1
V Gibt es eine Möglichkeit die Internet auslastung mit Java auszulesen Allgemeine Java-Themen 11
L Drop Emails von Outlook in eine JList Allgemeine Java-Themen 5
P Wie funktioniert das Feedback eines Klicks auf eine Java GUI Allgemeine Java-Themen 10
P Dezimalzahl in eine Binärzahl umrechnen Allgemeine Java-Themen 12
M Eine static-Methode verlassen Allgemeine Java-Themen 2
X HTTP Auslesen der Ergebnisse von einer Webseite und in eine Liste packen Allgemeine Java-Themen 1

Ähnliche Java Themen

Neue Themen


Oben