Als ich 2000 das erste Mal von Extreme Programming (oder kurz XP) hörte, gab es das Agile Manifest noch nicht. Ich war CTO der Business Media AG und meine Aufgabe war es, einen Marktplatz für Wertvolle Inhalte im Web zu schaffen. Hierfür suchte ich Entwickler. Ich war geprägt von den Gewaltmärschen der New Economy und wollte in meinem eigenen Team eine gesunde, nachhaltige Produktivität ohne Ausbrennen oder überbordende Bürokratie. Da sprach mich Extreme Programming mit seinem Satz einfacher Regeln sehr an. Kent Beck hat seinen Prozess in einigen, nicht zu dicken Büchern gut dokumentiert:
Daneben gibt es in der XP-Serie eine Reihe weiterer Bücher.
Aber auch im Web gibt es hervorragende Ressourcen zu XP. Die Wichtigste ist wohl Extreme Programming: A gentle introduction von Don Wells. Auf dieser Website findet man die Regeln (29 Regeln in den Kategorien Planung, Management, Software Design, Programmieren und Testen) von XP und die Werte, auf denen es basiert. Don betont, dass die Werte, nicht die Regeln der Ausgangspunkt seien. In einem betrieblichen Umfeld gibt es immer ein Zusammenspiel aus persönlichen und betrieblichen Werten. Zusätzlich zu den Werten und Regeln werden 12 Praktiken definiert.
Hier sind die Werte, auf denen Extreme Programming basiert. Um diese Werte an die eigenen Werte anzugleichen, müssen möglicherweise auch die weiter unten aufgelisteten Regeln angepasst oder erweitert werden.
Einfachheit. Das tun wonach gefragt wurde, aber nicht mehr. In kleine Schritten zum Ziel. Fehler gleich beheben, wenn sie auftreten. Etwas bauen, worauf man Stolz ist und es für vernünftige Kosten pflegen.
Kommunikation. Alles sind Teil des Teams und kommunizieren täglich. Alle arbeiten gemeinsam an den Anforderungen und am Code. Alle erschaffen die beste Problemlösung gemeinsam.
Feedback. Die eingegangene Verpflichtung einer Iteration wird ernst genommen; ihr Ergebnis ist funktionsfähige Software. Die Software wird früh und oft demonstriert. Sich aus den Rückmeldungen ergebende, erforderliche Änderungen werden eingearbeitet. Auch der Prozess ist Gegenstand von Gesprächen und kann an das Projekt angepasst werden, nicht anders herum.
Respect. Jedes Team-Mitglied gibt und schätzt den verdienten Respekt. Jeder steuert etwas bei, selbst wenn es nur Begeisterung ist. Entwickler schätzen die Expertise der Kunden und umgekehrt. Das Management schätzt die übernommene Verantwortung und ermächtigt das Team, für die eigene Arbeit verantwortlich zu sein.
Mut. Fortschritt und Schätzungen werden offengelegt. Entschuldigungen für Fehlschläge werden nicht dokumentiert; der Plan ist es, erfolgreich zu sein. Es gibt auch keinen Grund für Angst, da niemand allein arbeitet. Auf Änderungen wird eingegangen, wann immer sie passieren.
Hier sind die 29 Regeln.
Extreme Programming setzt 12 Praktiken, die sich in vier Bereiche gruppieren lassen.