Die 7 Wege zum Clean Code
Über mich Claudio Altamura Softwareentwickler Certified ScrumMaster Interessen Agile Softwareentwicklung Softwarearchitekturen Java ccd2013@claudioaltamura.de 2
Inhalt 1. Statische Codeanalyse 2. Testdriven Development 3. Refactoring 4. Continuous Integration 5. Reviews 6. Coding Standards 7. Coding Dojos ccd2013@claudioaltamura.de 3
Statische Codeanalyse Automatische Erkennung von Fehlern Sicherstellung von Coding-Standards Prüfung zum Softwaredesign Einhaltung diverser Metriken Namen, Größen, Anzahl weitere Verifikationen ccd2013@claudioaltamura.de 4
Statische Codeanalyse Welche Tools gibt es? Checkstyle, Findbugs, PMD, etc. mvn checkstyle:checkstyle mvn findbugs:findbugs Was messen? Anzahl Zeilen, Methoden und Klassen Duplicate Code Abhängigkeiten, Komplexität Anzahl von Tests, Anzahl fehlgeschlagener Tests ccd2013@claudioaltamura.de 5
SONARQUBE Statische Codeanalyse ccd2013@claudioaltamura.de 6
Vorteile Testdriven Development Senkt die Entwicklungskosten Produktivere Programmierer Einfache Validierung Positive Auswirkungen auf das Design Vorgehen ccd2013@claudioaltamura.de 7
Best Practices Testdriven Development Zuerst die Tests schreiben "Keep it simple stupid" (KISS) "You aren't gonna need it" (YAGNI). Keep the unit small Der Testcode ist genau so wichtig Nicht auf Zustände vorhergelaufenen Tests bauen ccd2013@claudioaltamura.de 8
Vorsicht! Testdriven Development Nicht für alle Bereiche geeignet: z.b. Oberflächen Unterstützung durch Management wichtig Schlecht geschriebene Tests Betriebsblindheit bei Unit Tests ccd2013@claudioaltamura.de 9
Refactoring By continuously improving the design of code, we make it easier and easier to work with.... If you get into the hygienic habit of refactoring continuously, you'll find that it is easier to extend and maintain code. Joshua Kerievsky, Refactoring to Patterns Vorteile Erhöhung der Lesbarkeit und Verständlichkeit Verbesserung der Wartbarkeit und Erweiterbarkeit Senkung von Kosten für Erweiterungen ccd2013@claudioaltamura.de 10
Mögliche Refactorings Refactoring Abstraktion Code in mehr logische Einheiten unterteilen Name und Ort von Code ccd2013@claudioaltamura.de 11
Risiken Refactoring Risiko ungewünschter Änderungen und Fehler große Änderungen erschweren die Ursachenanalyse Unit-Tests senken lediglich die Risiken ccd2013@claudioaltamura.de 12
Continuous Integration Praktiken Automatisierte Übersetzung Kontinuierliche Test-Entwicklung Häufige Integration Kurze Testzyklen Gespiegelte Produktionsumgebung Einfacher Zugriff Automatisiertes Reporting Automatisierte Verteilung ccd2013@claudioaltamura.de 13
Vorteile Continuous Integration Integrations-Probleme werden laufend gefixt frühe Warnungen, Feedback-Zyklus Unit-Tests entdecken Fehler zeitnah ständige Verfügbarkeit eines lauffähigen Standes ccd2013@claudioaltamura.de 14
Continuous Integration ccd2013@claudioaltamura.de 15
Reviews Reviewarten Informelles Review Walkthrough Inspektion Lightweight Reviews Over the Shoulder Pair Programming ccd2013@claudioaltamura.de 16
Vorteile Reviews Kostengünstige Behebung von Fehlern Identifizierung von Verbesserungsmöglichkeiten Wissentransfer Erfolgsfaktoren Konstruktive Kritik üben Kultur von Lernen und Prozessverbesserung Taktgefühl des Reviewers ccd2013@claudioaltamura.de 17
Reviews Gerrit ccd2013@claudioaltamura.de 18
Coding Standards Why Have Code Conventions? Code conventions are important to programmers for a number of reasons: 80% of the lifetime cost of a piece of software goes to maintenance. Hardly any software is maintained for its whole life by the original author. Code conventions improve the readability of the software, allowing engineers to understand new code more quickly and thoroughly. Code Conventions for the Java Language Was sind Coding Standards? ccd2013@claudioaltamura.de 19
Coding Standards Beispiele für Coding Standards Naming Conventions, Anweisungen, White Space Deklarationen, Kommentare, Einrückung Dateiorganisation, Praktiken, Prinzipien und Regeln Vorteile Erleichterung der Arbeit Steigerung der Lesbarkeit, Verständlichkeit und Wartbarkeit Elimierung von vermeidbaren Fehlerquellen ccd2013@claudioaltamura.de
Coding Standards Prozess Basis Language Coding Conventions Festlegung in einem Dokument Schrittweise Justierung der Regeln, z.b. Tools für die statische Codeanalyse Codeformatter ccd2013@claudioaltamura.de 21
Coding Dojos Dojo = Trainingsraum Kata = vorgegebener Bewegungsablauf Code Kata = vorgegebene Programmieraufgabe viele Male hintereinander ausgeführt es geht nicht um die Lösung, sondern um den Weg Muster sollen in Fleisch und Blut übergehen Ziel: besserer Entwickler zu werden ccd2013@claudioaltamura.de 22
Ablauf Coding Dojos zwei Entwickler im Team an einem Rechner restliche Teilnehmer schauen auf den Beamer nach einer Zeitspanne Wechsel eines Entwickler bis nichts mehr zu verbessern ist am Ende Retrospektive ccd2013@claudioaltamura.de 23
Coding Dojos Für was eignen sich Coding Katas? TDD zu lernen Neue Sprache oder Sprachfeatures zu lernen besser zu programmieren ccd2013@claudioaltamura.de 24
Fragen & Antworten ccd2013@claudioaltamura.de
Links Statische Codeanalyse SonarSource (http://www.sonarqube.com) Continuous Integration Martin Fowler CI (http://www.martinfowler.com/articles/continuousintegration.html) TDD Introduction to TDD (http://www.agiledata.org/essays/tdd.html) Refactoring Refactoring to Patterns Catalog (http://industriallogic.com/xp/refactoring/catalog.html) Reviews Best Kept Secrets (http://smartbear.com/smartbear/media/pdfs/best-kept-secrets-of-peer-code-review.pdf) Coding Standards Code Conventions for the Java Programming Language (http://www.oracle.com/technetwork/java/codeconv-138413.html) Coding Dojos CodersDojo (http://codersdojo.org) ccd2013@claudioaltamura.de 26
Vielen Dank für eure Aufmerksamkeit. www.claudioaltamura.de ccd2013@claudioaltamura.de