Tipps für Organisation von Code-Reviews nach einem Pull Request.

Zrebna

Bekanntes Mitglied
Hallo!

Wie geht man bei Code-Reviews nach einem Pull Request via GIT, bei dem man als Reviewer gesetzt worden ist am Besten vor?

Natürlich kann man sich alle Changes im Browser ansehen - z.B. auf gitHub, BitBuckets, oder was man da auch immer intern verwendet.
Jedoch ist das oft nicht so angenehm und übersichtlich und man kann sich nirgends "reinklicken", wie in der IDE.
In der IDE selber kann man schon einen checkout auf den zu reviewenden Branch machen und dann via Git History einzelne Klassen vor und nach einzelnen Commits ansehen.

Aber was hier fehlt ist eine Art Stand vor dem Pull Request des gesamten Projektes (alle Klassen) im Vergleich mit dem Stand nach dem Pull Request.

Wie macht ihr das in der Praxis?
Evtl. einen eigenen Workspace für Code-Reviews anlegen und dort auf den zu reviewenden Branch auschecken ( = Stand Projekt nach allen Commits des zu reviewenden PRs) und die Situation dort mit dem Stand im eigenem Workspace vergleichen, also dem Stand ohne den Commits, die zum PR gehören.

Wobei dann nicht die Unterschiede "gehigh-lighted" werden.
Mich würde einfach interessieren, wie ihr das in der Praxis am Besten macht, weil von Euch sicher einige bereits in Rollen sind/waren, bei denen man viel Code-Review-Erfahrung sammelt und ggf. gute Tipps geben kann.^^

Lg
Zrebna
 

LimDul

Top Contributor
Wie üblich - Kommt drauf :)

Bei uns in der Firma sieht der Prozess so aus, das der Jenkins auch direkt die gesamten Anwendungen auf dem Stand baut und deployed. Das heißt ich kann den Stand auch Funktional testen ohne ihn auszuchecken. Dann hängt es im Endeffekt vom Umfang der Code-Änderungen.

Lokale Änderungen reviewe ich online (wir verwenden gerrit). Dort sehe ich das Diff, kann anmerken machen und auf dem gebauten Stand auch direkt funktional testen.

Änderungen die nicht mehr lokal sind, sondern sich über mehrere Teile erstrecken checke ich lokal in meiner IDE aus. Ich schaue da auch online mir das Diff an, aber in einigen Stellen wechsel ich dann in die IDE um mehr Kontext zu haben und auch mal links und rechts zu schauen. Relevant ist da auch - was einem kein Tool abnehmen kann - die Erfahrung. Den interessant sind bei solchen Changes auch immer die Stellen, die nicht angepasst wurde, aber hätten angepasst werden müssen. Die findet man nur mit Erfahrung und einem funktionalen Test. Den Browser mit dem Online Diff brauche ich aber eh immer, weil da muss ich ja alle Anmerkungen reinschreiben wenn was nicht passt.
 

bullish

Mitglied
Oh ja, Tests kann Github natürlich auch automatisch durchrattern lassen ... Aber da sind wir schon einen Schritt weiter, den bevor es überhaupt zu einem formalen Review kommt, müssen ja wenigstens die Tests bestanden sein.
 

Zrebna

Bekanntes Mitglied
Immer auf Github reviewen, da kann man den PR-Ersteller auch gleich mitteilen, was falsch gelaufen ist.
Klar, Kommentare gehen auf GitHub in den PR rein.
Aber der Codereview auf GitHub erscheint teils mühseliger als in der IDE Code durchzuklicken.

Wegen Tests:
Nach dem der PR approved ist, springt eh die Pipeline an und Tests laufen da u.a. auch durch.
Jedoch darf bei uns eh nur vorab gepusht werden, wenn alle Tests lokal bestanden sind. Also da gibt es selten Probleme.
 

Zrebna

Bekanntes Mitglied
Änderungen die nicht mehr lokal sind, sondern sich über mehrere Teile erstrecken checke ich lokal in meiner IDE aus. Ich schaue da auch online mir das Diff an, aber in einigen Stellen wechsel ich dann in die IDE um mehr Kontext zu haben und auch mal links und rechts zu schauen. Relevant ist da auch - was einem kein Tool abnehmen kann - die Erfahrung. Den interessant sind bei solchen Changes auch immer die Stellen, die nicht angepasst wurde, aber hätten angepasst werden müssen. Die findet man nur mit Erfahrung und einem funktionalen Test. Den Browser mit dem Online Diff brauche ich aber eh immer, weil da muss ich ja alle Anmerkungen reinschreiben wenn was nicht passt.

Ja, so habe ich mir das auch vorgestellt. Also eine Kombination zwischen dem Browser (muss ja eh, wegen Comments und weil man die Diffs sehen will) und für mehr Kontext dann in der IDE.

Ok, so werde ich es auf jeden Fall mal versuchen - Danke euch :)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
S Suche Tipps für Einstieg in JavaCC Allgemeine Java-Themen 2
gotzi242 Array Summe bestimmen tipps? Allgemeine Java-Themen 14
DaCrazyJavaExpert OOP Ansätze und Tipps zum Porgrammieren eines Taschenrechners Allgemeine Java-Themen 25
C Mouse Bereiche - Besser notieren - Tipps Allgemeine Java-Themen 2
F Message Queue Tipps Allgemeine Java-Themen 3
G Exception handling - b.practices/tipps. etc. Allgemeine Java-Themen 3
T Autostart Programm - brauche Tipps Allgemeine Java-Themen 5
S Tipps: java richtig lernen - wie? Allgemeine Java-Themen 3
B tipps zum schreiben eines mathematischen parser Allgemeine Java-Themen 13
W Vergleichstool für xml-Dateien Tortoise-svn Verknüpfung Allgemeine Java-Themen 2
Zrebna Bitte um Empfehlungen für "zeitlose" Bücher bzgl. Backend mit Spring und Beans Allgemeine Java-Themen 25
D Lesbare args für die main-Methode Allgemeine Java-Themen 6
B Algorithmus für Arbeit mit fehlenden Listenelementen? Allgemeine Java-Themen 1
kodela Eingabe für TextArray bedingt sperren Allgemeine Java-Themen 3
Karl_Der_Nette_Anfänger Hat wer ne Lösung für verknüpfte Postleitzahlen? (Baum/Wurzel Struktur) Allgemeine Java-Themen 11
R 11 GB File lesen ohne zu extrahieren Filedaten Bereich für Bereich adressieren dann mit Multi-Thread id die DB importieren Allgemeine Java-Themen 3
G KeyListener für JTextField Allgemeine Java-Themen 5
webracer999 Library für Textsuche (z. B. include/exclude, and/or)? Allgemeine Java-Themen 5
I Module-Info für Jar erzeugen Allgemeine Java-Themen 7
krgewb Java-Bibliothek für ONVIF Allgemeine Java-Themen 1
B Simpler Eventlistener für Tastaturtaste bauen? Allgemeine Java-Themen 13
_user_q Eingegebenen Text Zeile für Zeile ausgeben lassen Allgemeine Java-Themen 11
E Key für TOTP Algorythmus(Google Authentificator) Allgemeine Java-Themen 0
S Formel für Sonnenwinkel in ein Programm überführen Allgemeine Java-Themen 11
M pfx-Zertifikat in Tomcat für SSL-Verschlüsselung nutzen Allgemeine Java-Themen 14
R Best Practice Erfahrungswerte für eine Migration von JSF nach Angular (oder anderes JS-Framework) Allgemeine Java-Themen 1
B HeapSort für Array of Strings funktioniert nur teilweise Allgemeine Java-Themen 3
jhCDtGVjcZGcfzug Klassen Was genau passiert hier? Kann mir das jemand bitte Zeile für Zeile erklären? Allgemeine Java-Themen 1
rosima26 Bester Sortieralgorithmus für kurze Arrays Allgemeine Java-Themen 40
S Mit Methoden kann man definieren für was <T> steht. Geht das auch irgendwie für Variablen? Allgemeine Java-Themen 12
MangoTango Operatoren while-Schleife für Potenz Allgemeine Java-Themen 3
B Lottospiel, genug Reihen tippen für 3 Richtige (Spaß mit Arrays)? Allgemeine Java-Themen 46
B Mit welchen Datentypen und Strukturierung am Besten dutzende Baccaratspiele Shcritt für Schritt durchsimulieren? Allgemeine Java-Themen 26
D Klassendesign für einen Pascal Interpreter Allgemeine Java-Themen 6
I OCR Library für Belegerkennung Allgemeine Java-Themen 7
farah GetterMathod für Farbkanäle Allgemeine Java-Themen 6
B Welcher Datentyp für sehr große Zahlenbereiche? Allgemeine Java-Themen 1
S Webservices für binäre Daten? Allgemeine Java-Themen 5
G Licence-Header für InHouse entwickelten Source Allgemeine Java-Themen 8
M Schleife für einen TicTacToe Computer Allgemeine Java-Themen 5
O git ignore für Intellji braucht es die .idea Dateien? Allgemeine Java-Themen 8
F Java Script für das Vorhaben das richtige? Allgemeine Java-Themen 9
M wiviel Java muss ich für die Berufswelt können ? Allgemeine Java-Themen 5
Robertop Datumsformat für GB ab Java 16 Allgemeine Java-Themen 1
Thallius Verschiedene entities für gleichen Code…. Allgemeine Java-Themen 8
OnDemand Zentrale "Drehscheibe" für verschiedene APIs Allgemeine Java-Themen 14
S Übergabe eines Sortierkriteriums für ein Artikel Array mittels BiPredicate<Artikel, Artikel> Allgemeine Java-Themen 13
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
D SHA-3 für Java-version 1.8 Allgemeine Java-Themen 1
N Validator für einen SQL-Befehl Allgemeine Java-Themen 22
Muatasem Hammud Erstellung von Testdaten für Arrays Allgemeine Java-Themen 6
B Logikfehlersuche, das perfekte Lottosystem für 3 Richtige mit Arraylists? Allgemeine Java-Themen 61
G Methoden für die Zukunft sinnvoll? Allgemeine Java-Themen 4
M API für PLZ Umkreissuche Allgemeine Java-Themen 3
1Spinne JDK 8 für Eclipse installieren Allgemeine Java-Themen 5
Tobero Meine Funktion für das beinhalten eines Punktes in einem Kreis funktioniert nicht Allgemeine Java-Themen 5
L Methoden Parser für gängige Datumsformate? Allgemeine Java-Themen 1
H Interface PluginSystem ClassNotFound exception für library Klassen Allgemeine Java-Themen 10
N relativier Pfad für sqlite-Datenbank in Gradle/IntelliJ Allgemeine Java-Themen 2
buchfrau Anagram für beliebiges Wort Allgemeine Java-Themen 2
TonioTec Api für Datenaustausch zwischen Client und Server Allgemeine Java-Themen 0
W Suche Ursache für NPE - woher kommt sie? (Hilfe beim Debugging) Allgemeine Java-Themen 19
Kirby.exe Distanz Map für die Distanztransformation erstellen Allgemeine Java-Themen 1
F PI Regler für Heizung Allgemeine Java-Themen 7
8u3631984 Generelle Log4j.xml für alle Module Allgemeine Java-Themen 5
M Wie übergebe ich den Zähler für die Anzahl Rekursionsschritte korrekt? Allgemeine Java-Themen 2
B Login für User, der im Hintergrund Schedules ausführt Allgemeine Java-Themen 16
L RegEx für Teile einer Berechnung Allgemeine Java-Themen 14
S Java-Task-Management-Tool für Windows und Mac selber programmieren Allgemeine Java-Themen 4
M Java 2D Array für ein Grid erstellen ? Allgemeine Java-Themen 2
Z Welches GUI Framework für Java ist aktuell? Allgemeine Java-Themen 16
N Convert.FromBase64 von C# für Java Allgemeine Java-Themen 11
N fixed-keyword von C# für Java Allgemeine Java-Themen 6
O Suche Scripter für alt:V Project! Allgemeine Java-Themen 0
S Interface Design von HookUp oder Callback Methoden für eigenes Framework Allgemeine Java-Themen 9
O Suche Unterstützung für ein OpenSource-Projekt (grafischer Editor) Allgemeine Java-Themen 13
Kirby.exe Software für Graphische Visualisierung Allgemeine Java-Themen 20
B OOP Auslöser für NullPointerException Allgemeine Java-Themen 3
L Generator für einen Parser implementieren Allgemeine Java-Themen 13
DonMalte Ambitioniertes Projekt für Einsteiger & Motivierte Allgemeine Java-Themen 0
Kirby.exe Movement System für Spiel Allgemeine Java-Themen 13
Kirby.exe Framework für Game Design Allgemeine Java-Themen 8
W Alternative für Threads Allgemeine Java-Themen 6
S Rückgabe einer HttpURLConnection für eine Seite einlesen bei der man eingeloggt ist..? Allgemeine Java-Themen 5
Elyt Compiler-Fehler Datei kann nicht erstellt werden. Die Syntax für den Dateinamen etc. ist falsch. Allgemeine Java-Themen 2
Thallius Rätsel für Windows Profis Allgemeine Java-Themen 8
D OOP Gemeinsamen ID-Raum für zwei Klassen implementieren Allgemeine Java-Themen 7
D Input/Output Implementierung eines CommandHandlers/Parsers für viele Eingaben Allgemeine Java-Themen 26
Thallius Alternative für SwingWorker Allgemeine Java-Themen 5
I Lohnt sich heutzutage der Aufwand einer Portierung für MacOS Allgemeine Java-Themen 8
L Klassen Algorithmus für das folgende Problem entwickeln? Allgemeine Java-Themen 30
J Datenstruktur für eine Map erstellen Allgemeine Java-Themen 2
H OOP Setting(config) für Applikation sicheren? Allgemeine Java-Themen 9
OnDemand PDF Libary für Formulare Allgemeine Java-Themen 7
S Warmup für Lineare-Suche mit Zeitmessung Allgemeine Java-Themen 2
T Allgemeine Frage: GUI für 3D-Visualisierung Allgemeine Java-Themen 5
M Brainstorming für mein Projekt Allgemeine Java-Themen 30
K OOP Suche Hilfe + Erklärung für eine Hausaufgabe Allgemeine Java-Themen 1
F Was ist der Dateityp meines Parameters für die Main Methode. Allgemeine Java-Themen 6
C Bibliotheken für Algorithmische Geometrie Allgemeine Java-Themen 2

Ähnliche Java Themen

Neue Themen


Oben