Ausführung einer Testmethode in der IDE erfolgreich - failt aber via 'mvn test'

Zrebna

Bekanntes Mitglied
Hi,

Ich habe zwei Testmethoden, die eine Funktionalität testen, bei der bestimmte Daten aus einer JSON-Datei gelesen und in eine TXT-Datei geschrieben werden. Bei einer der Methoden verwendet die dort zu testende und aufgerufene Methode einen String als Eingabeparameter, die andere einen InputStream.
Während der Test mit dem String problemlos funktioniert, schlägt der Test mit dem InputStream fehl, wenn er mit mvn test ausgeführt wird, obwohl er in der IDE (IntelliJ) erfolgreich ist.
Beide Tests generieren die erwartete Ausgabe, aber der InputStream-Test schlägt in der Kommandozeile fehl. Hier sind die relevanten Codesnippets:

Mit InputStream:
Java:
public void generateDataTestWithInputStream() throws IOException {
    final File file = new File("output.txt");

    try (OutputStreamWriter outputStreamWriter = new OutputStreamWriter(new FileOutputStream(file), StandardCharsets.UTF_8);
         PrintWriter out = new PrintWriter(outputStreamWriter)) {
      
        final InputStream inputStream = getClass().getResourceAsStream("/input.json");
        myGeneratorClass.generateData(inputStream, out);
    }

    final String outputStringExpected = readFileToString(new File("output.txt"));
    assertEqualsIgnoreNewLines(outputStringExpected, readFileToString(file));
}

Mit String:
Java:
public void generateDataTestWithString() throws IOException {
    final File file = new File("output.txt");

    try (OutputStreamWriter outputStreamWriter = new OutputStreamWriter(new FileOutputStream(file), StandardCharsets.UTF_8);
         PrintWriter out = new PrintWriter(outputStreamWriter)) {
      
        final String jsonString = readFileToString(new File("input.json"));
        myGeneratorClass.generateData(jsonString, out);
    }

    final String outputStringExpected = readFileToString(new File("output.txt"));
    assertEqualsIgnoreNewLines(outputStringExpected, readFileToString(file));
}


Hat Jemand schon mal diesen Fall gehabt und hat folglich eine Idee.
Der Log hilft nicht wirklich weiter - es gibt eine MojoFailureException und im sure-fire reports-Ordner wird gesagt, dass die assertion failt, aber die erwartete Ausgabe ist korrekt und wie gesagt, die Testausführung failt nur mittels 'mvn test' - in der IDE gibt es keine Probleme.

Ohne mehr Infos ist dieser Thread sicherlich ein "Schuß ins Blaue" - aber möglicherweise hatte hier Jemand schonmal genau dieses Problem bzw. diese "Anomalie" und kann weiterhelfen.

Lg,
Zrebna
 

Zrebna

Bekanntes Mitglied
Update (zu spät zum editieren)


Zusatzinfos:
Allgemein funktioniert der Test so, dass die generierte Datei 'out.txt' (mittels der zu testenden Methode) in den temp-Ordner geschrieben wird und genauso heißt wie die Datei 'out.txt', die im resources-Ordner liegt.
Letztere ist das 'Expected' und ersteres das 'Actual'.

Es gibt zwischen beiden keine Unterschiede, sogar der LineFeed ist bei beiden mit 'LF' identisch und trotzdem failt die Methode, die InputStream als Argument für die zu testende Methode verwendet via mvn test.

Hier noch die public aufgerufenen Prüflinge - nur dieser erster entry-point unterscheidet sich - aber der privaten überladenen Methode, die von beiden aufgerufen wird, ist alles identisch und

Mit InputStream
Java:
public void generateData(InputStream inputStream, PrintWriter out) throws IOException, CustomException {
    final Gson gson = new Gson();
    try (InputStreamReader inputStreamReader = new InputStreamReader(inputStream)) {
        try {
            final JsonObject jsonObject = gson.fromJson(inputStreamReader, JsonObject.class);
            generateData(jsonObject, out);
        } catch (JsonSyntaxException e) {
            throw new CustomException("Failed to parse JSON", e);
        }
    } catch (IOException e) {
        throw new CustomException("Failed to read JSON file", e);
    }
}


Mit String:
Java:
public void generateData(String jsonString, PrintWriter out) throws CustomException {
    final Gson gson = new Gson();
    try {
        final JsonObject jsonObject = gson.fromJson(jsonString, JsonObject.class);
        generateData(jsonObject, out);
    } catch (Exception e) {
        throw new CustomException("Failed to generate Data: " + e.getMessage(), e);
    }
}
 

Zrebna

Bekanntes Mitglied
In der Konsole und aus der Log-Text-Datei im surefire-reports-Ordner gemerged

Code:
[INFO]
[INFO] -------------------------------------------------------
[INFO]  T E S T S
[INFO] -------------------------------------------------------
[INFO] Running com.example.project.GeneratorTest
[ERROR] Tests run: 1, Failures: 1, Errors: 0, Skipped: 0, Time elapsed: 23.253 s <<< FAILURE! - in com.example.project.GeneratorTest
[ERROR] generateDataTestWithInputStream  Time elapsed: 23.253 s  <<< FAILURE!
org.junit.ComparisonFailure: expected:<...<
    ...
>
[INFO]
[ERROR] Tests run: 1, Failures: 1, Errors: 0, Skipped: 0
[INFO]
[INFO]
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time:  39.443 s
[INFO] Finished at: 2024-07-05T15:34:28+02:00
[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-surefire-plugin:3.0.0-M3:test (default-test) on project project-name: There are test failures.
[ERROR]
[ERROR] Please refer to /path/to/project/target/surefire-reports for the individual test results.
[ERROR] Please refer to dump files if any exist [date].dump, [date].dumpstream.
[ERROR] -> [Help 1]
[ERROR]
[ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch.
[ERROR] Re-run Maven using the -X switch to enable full debug logging.
[ERROR]
[ERROR] For more information about the errors and possible solutions, please read the following articles:
[ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoFailureException

Ich kann leider nicht den gesamten als auch originalen Log posten, weil da evtl. sensible Daten enthalten sind.
Es wird halt gezeigt, dass Daten eingelesen werden - irgendwann wirds rot und denn der Fehler oben.


Output ist aber wie expected und unterscheidet sich mit dem Auge und auch mittels GitTurtoise-Differences-Check nicht von 'actual' - daher nochmal:
Test macht nur mit 'mvn test' Probleme (und deswegen halt leider auch in der Pipeline) - führt man in der IDE aus, gibts keine Probleme.
 

Robert Zenz

Top Contributor
Output ist aber wie expected und unterscheidet sich mit dem Auge und auch mittels GitTurtoise-Differences-Check nicht von 'actual' - daher nochmal:
Test macht nur mit 'mvn test' Probleme (und deswegen halt leider auch in der Pipeline) - führt man in der IDE aus, gibts keine Probleme.
Du musst dann in dem Fall beide als byte-Arrays ausgeben lassen, weil da wird etwas drinnen sein was bei der Anzeige nicht auffaellt. Also getBytes und dann das ausgeben von beiden. Oder noch besser direkt die Dateiinhalte beim lesen.

Jetzt wo es mir gerade auffaellt, was macht readFileToString genau und hast du das Beispiel gekuerzt? Weil

Java:
    final File file = new File("output.txt");
    // ...
    final String outputStringExpected = readFileToString(new File("output.txt"));
    assertEqualsIgnoreNewLines(outputStringExpected, readFileToString(file));

klingt jetzt auch nicht so korrekt.
 

Zrebna

Bekanntes Mitglied
Danke schon mal - ich versuche deine Tipps nach dem Wochenende, da ich übers Wochenende nicht da bin...

Java:
readFileToString
hab ich umbenannt und gekürzt für den Forenpost.

Nun hat es trotzdem bereits doch noch geklappt - Lösung war:
Das selbe Encoding für den InputStreamReader zu verwenden (StandardCharsets.UTF_8) wie man dem OutputStreamWriter gegeben hat:

Hier funktioniert es nun auch mit 'mvn test'
Java:
public void generateData(InputStream inputStream, PrintWriter out) throws IOException, CustomException {
    final Gson gson = new Gson();

    try (InputStreamReader inputStreamReader = new InputStreamReader(inputStream, StandardCharsets.UTF_8)) {

        try {
            final JsonObject jsonObject = gson.fromJson(inputStreamReader, JsonObject.class);
            generateData(jsonObject, out);
        } catch (JsonSyntaxException e) {
            throw new CustomException("Failed to parse JSON", e);
        }

    } catch (IOException ie) {
        throw new CustomException("Failed to read JSON file", ie);
    }
}




Wie gesagt, ich sehe mir das nach dem Wochenende nochmal genauer an und werde nachsehen, ob es via ByteArray doch Unterschiede gibt und welche das dann sind, weil mich das auch interessiert.

Danke schon einmal!
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
L Fehler bei der Ausführung einer Jar Allgemeine Java-Themen 2
H Plattformunabhänginge Ausführung einer .jar Datei Allgemeine Java-Themen 8
J Fehlermeldung bei Ausführung von .jar-Datei Allgemeine Java-Themen 9
S Gibt es eine Moeglichkeit die Runtime Ausführung zu analysieren..? Allgemeine Java-Themen 7
M Webservice timeout bei Ausführung der .jar Allgemeine Java-Themen 3
S Fehlermeldungen erscheinen erst in der Ausführung des Programms Allgemeine Java-Themen 11
A einmalige Ausführung eines Methodenabschnittes Allgemeine Java-Themen 3
E Threads Ausführung in Threads ist langsamer als ohne Threads Allgemeine Java-Themen 13
B Ungewollte mehrmalige ausführung des codes Allgemeine Java-Themen 10
R Internetverbindung weg bei ausführung Allgemeine Java-Themen 3
W Deserialisierung und Ausführung Allgemeine Java-Themen 2
X Prozess-Objekt nach Ausführung der destroy-Methode null oder nicht null ? Allgemeine Java-Themen 10
J Wie die gleichzeitige Ausführung mehrerer Tasks trotz Multithreading verhindern? Allgemeine Java-Themen 2
Daniel_L Mehrfache Ausführung desselben Threads/Tasks verhindern? Allgemeine Java-Themen 4
V Parallele Ausführung Allgemeine Java-Themen 8
D Eclipse-build vs. Jar-Ausführung Allgemeine Java-Themen 3
V Ausführung Client- oder Serverseitig? Allgemeine Java-Themen 13
I Thread eine bestimmte Zeit zur Ausführung geben Allgemeine Java-Themen 2
R ClientHTTPRequest - bei mehrfacher Ausführung? Allgemeine Java-Themen 2
K Richtige JVM für jar Ausführung? Allgemeine Java-Themen 4
F JAR-Datei-Ausführung löst Fehler aus Allgemeine Java-Themen 5
P Verschiedene Aspekte einer idempotent API verstehen? Allgemeine Java-Themen 16
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

Ähnliche Java Themen


Oben