Methode
cards+ ist eine agile Methode
cards+ unterstützt eine Projektorganisation, Wissensmanagement in einem agilen Entwicklungsprojekt richtig zu organisieren. Der Produktverantwortliche setzt cards+ ein, um zielgerichtet und inkrementell sein Produkt angemessen zu dokumentieren, unterstützt durch ein selbstorganisiertes Team.
Es gilt die Prämisse, dass eine angemessene Produktdokumentation notwendig ist. Eine solche Produktdokumentation wächst mit dem Produkt. Sie ist ein Ergebnis des agilen Entwicklungsprozesses. Sie muss daher mit dem gleichen Maßstab für die Qualität, mit dem gleichen Ansatz für empirische, inkrementelle und iterative Arbeitsweise und mit den gleichen Werten hergestellt wird, wie auch das Produkt entwickelt wird. An diesem Punkt kommt die Methode cards+ ins Spiel.
Dokumente werden agil entwickelt.
cards+ tritt mit dem Versprechen an, die Erstellung und Pflege einer qualitativ hochwertigen Produktdokumentation in einem Wiki zu ermöglichen. Viele Prinzipien und Praktiken der Entwickler gelten auch für Autoren in einem Wiki, in den meisten Fällen in nur leicht abgewandelter Form.
cards+ ist kein geschlossenes Vorgehensmodell, kein isolierter Prozess. Aus diesem Grund kann cards+ sehr gut in bestehende Prozesse integriert werden. Autoren im Wiki planen und steuern ihre Tätigkeiten weiterhin mit Techniken aus dem Projektmanagement. Sie verwenden die Methode ihrer Wahl für die Anforderungsanalyse. cards+ ist als zusätzliches Werkzeug für Autoren zu verstehen, mit dem sie ihre Ergebnisse im Wiki organisieren.
Für Leser ist cards+ die Chance, im Wiki jede relevante dokumentierte Information zum Produkt zu finden. Das Wiki unterstützt sie durch die Verknüpfung von Seiten, die Kategorisierung der Seiten mit Stichworten und umfangreiche Suchfunktionen.
Dokumentation agil entwickeln.
Kommentare erfolgreich moderieren.
Praktiken
Kontinuierlich verbessern
Wie beim Programmieren gehört die Anwendung der Pfadfinderregel auch beim Dokumentieren zum Fundament professioneller Arbeit. Leser können jederzeit einen entsprechenden Hinweis als Kommentar in der Seite hinterlassen. Autoren greifen diese Hinweise wertschätzend auf. Nach dem Abschluss der Verbesserung wird der Kommentar gelöscht.
Jeder Autor im Wiki kann bereits beim aktiven lesen einer beliebigen Seite kleine, aber wichtige Korrekturen durchführen. Kleine Korrekturen sind beispielsweise die Verbesserung von Rechtschreibfehlern oder die Verknüpfung von Begriffen im Text mit Einträgen im Glossar. Durch diese ebenfalls recht einfache Maßnahme erkennt der Autor automatisch wiederholt auftretende Erklärungen im Text, die er ohne Verlust von Wissen aus der Seite entfernen kann. Gegebenenfalls ergänzt er Schlagworte in der Seite. Schlagworte sind Begriffe aus einem kontrollierten Vokabular. Bei cards+ wird dieses Vokabular durch das Glossar definiert. Mit dieser Maßnahme wird die Suche im Wiki für Leser deutlich verbessert.
Praktiken
Zielgerichtet verbessern
Code-Reviews sind beim Programmieren nicht mehr wegzudenken. Das Vorgehen eignet sich nicht nur dazu, die Qualität der Software zu verbessern. Es unterstützt auch den Wissenstransfer innerhalb des Teams. Das Gesagte gilt auch für das Dokumentieren mit cards+. Bei der Durchführung eines Reviews einer Seite im Wiki prüft der Reviewer sowohl die Richtigkeit als auch die Vollständigkeit der Inhalte.
Die Richtigkeit der Seite schätzt der Reviewer anhand seines eigenen Wissens ein. Die Verknüpfung von Begriffen im Text mit Einträgen im Glossar unterstützt ihn dabei. Beim Lesen korrigiert er offensichtliche Fehler in der Rechtschreibung. Der Editor des Wiki hilft dabei. Bei allen anderen Fehlern oder Lücken nutzt er die Kommentarfunktion, um Hinweise für den Autor in der Seite zu hinterlassen.
Eine Seite ist vollständig, wenn
- die vorbereitete Seitenvorlage des Bausteins verwendet wurde.
- alle Abschnitte aus der Seitenvorlage des Bausteins ausgefüllt sind.
- passende Schlagworte in der Seite gesetzt sind.
Diese rein formalen Prüfungen sind möglich, weil die Seitenvorlagen einen festen Rahmen für jeden Baustein vorgeben.
Praktiken
Kontinuierlich veröffentlichen
Ein Wiki ist optimal geeignet für die Erfassung, Pflege und vor allem Präsentation von Produktwissen. Die Pflege von Seiten direkt im Wiki kommt dort an seine Grenzen, wo regelmäßig und in kurzen Abständen Veränderungen gemacht werden. Das ist vor allem dort der Fall, wo eine Lösung für eine Fähigkeit der Software von den Entwicklern sehr genau beschrieben wird. Diese Art dokumentierter Informationen sind ganz eng an die Implementierung gekoppelt und werden in der Konsequenz zusammen mit dem Code versioniert.
In einer Spezifikation halten Entwickler die Struktur eines Objektes, Geschäftsregeln und Algorithmen eines Dienstes oder den Aufbau und das Verhalten einer Bedienoberfläche fest. cards+ macht keine Vorgaben für eine Spezifikation. Mit der Freigabe der Software für das Produktinkrement wird jede damit verbundene Spezifikation im Wiki in den Bausteinen Service, Entity, Event oder Layout veröffentlicht.
Eine ähnliche Situation gibt es bei den Testplänen in einer Testpyramide. Die Testfälle eines Systemtests sind sehr gut als zusätzliche Dokumentation geeignet, wenn sie sich an den Fähigkeiten der Software orientieren. cards+ macht keine Vorgaben für einen Testplan. Mit der Freigabe der Software für das Produktinkrement werden die durchgeführten Testfälle im Wiki veröffentlicht. Abhängig vom Aufbau der Testpläne bieten sich die Bausteine Epic oder Case an.
Sowohl Spezifikationen als auch Testpläne sind wie Code Teil des Produktinkrementes und damit ein Ergebnis des Teams. Es ist Aufgabe des Teams, für die dokumentierten Informationen ein geeignetes Format zu wählen, das im Wiki veröffentlicht werden kann. Am besten automatisierbar.
Praktiken
Kontinuierlich schätzen
Der Produktverantwortliche hat eine Vision des Produktes. Den Baustein Epic gibt einer angeforderten Funktionalität des Produktes einen eindeutigen Namen und gruppiert die neuen Fähigkeiten der Software. Den Baustein Case legt er an, um jeder neuen Fähigkeit der Software einen Titel zu geben und die Ausgangslage kurz zu beschreiben. Die Lösung bleibt auf jeden Fall offen. Kann der Produktverantwortliche mit seiner Vision einen Auftraggeber begeistern, bekommt er häufig die Frage gestellt, was das den ungefähr kostet. Agil hin oder her, er braucht eine realistische Zahl, an die er selbst glaubt. Für eine Expertenschätzung durch sein Team muss er sehr viel Arbeit in das Backlog investieren. Und selbst dann ist die Schätzung in der Regel mit einer hohen Ungenauigkeit verbunden.
cards+ eröffnet eine neue Option mit dem Einsatz der Schätzmethode »Use-Case-Points« von Stephan Frohnhoff. Der Baustein Case erfüllt alle Bedingungen als Eingangsgröße für die Schätzmethode. Jeder Case wird auf einer Skala von einfach, normal oder komplex mit Punkten bewertet. Die Punkte aller Fähigkeiten der Software werden addiert und mit Faktoren gewichtet. Es gibt Faktoren für technische Komplexität, das Projektumfeld und die Produktivität des Teams. Das Ergebnis sind Personenstunden. Der geschätzte Wert ist natürlich mit einer Ungenauigkeit verbunden. Mit der Realisierung von Fähigkeiten kann die Schätzung kalibriert werden.
Der Produktverantwortliche wird in die Lage versetzt, die die Schätzung kontinuierlich zu aktualisieren. Fügt er einen neuen Baustein Case hinzu, ergänzt er die Schätzung um eine Bewertung der neuen Fähigkeit der Software. Er orientiert sich dabei an den bereits vorhandenen Fähigkeiten. Der Auftraggeber bekommt in sehr kurzer Zeit eine erste grobe Indikation der Kosten für die Realisierung.
Dokumentation nachhaltig organisieren.
Methode
Professionell zusammmenarbeiten
Jede an einem IT-System interessierte Partei hat ihre eigene Vorstellung von guter Dokumentation. Diese Vorstellung ist ganz maßgeblich von ihren persönlichen Schwerpunkten bestimmt. »Viele Köche verderben den Brei« ist ein Sprichwort, das wahr wird, wenn jede an der Produktdokumentation beteiligte Person so schreibt, wie sie es aus persönlicher Sicht für richtig hält. Leser und Autoren brauchen ein Grundgerüst, an dem sie sich orientieren können. cards+ bietet dafür die feste Struktur mit den Bereichen Systembeschreibung, Systemstruktur und Architekurentwurf. In jedem Bereich gibt es vordefinierte Bausteine mit festem Aufbau.
cards+ unterscheidet drei Rollen, die wesentlich zum Gelingen einer Produktdokumentation beitragen: Leser, Autoren und Gärtner. Aufgrund der Trennung von Dokumentation im Wiki und Spezifikation durch das Team im Code-Repository bezieht sich die Definiton der Rollen von cards+ nur auf die Personen, die direkt im Wiki arbeiten.
Alle Gärtner und Vertreter der Autoren sind Teil einer Expertenrunde (engl. community of practice) und Sprecher der Zielgruppen der Produktdokumentation.
Leser
Leser ist jede am Produkt interessierte Partei. Ein Leser nutzt das Wiki als Hilfsmittel zur Erfüllung seiner Aufgaben im agilen Entwicklungsprozess. Das Wiki ist für ihn eine unverzichtbare Quelle für Produktwissen. Jeder Leser ist berechtigt, im Wiki Seiten zu lesen und zu kommentieren.
Autor
Der Produktverantwortliche ist Autor. Analysten, IT- und UX-Experten, Redakteure und Vertreter des Teams unterstützen ihn als Co-Autoren. Ein Autor ist berechtigt, neue Seiten im Wiki anzulegen und bestehende Seiten zu ändern oder zu löschen. Seine Aufgabe ist es, Seiten im Wiki inkrementell mit Produktwissen zu füllen.
Gärtner
Ein Gärtner ist Experte für Dokumentation und Administrator für das Wiki. Er ist verantwortlich für die Auswahl der Werkzeuge für die Autoren. Als Trainer für cards+ ist er für Autoren und Leser greifbar und hilft ihnen bei der Bewältigung von alltäglichen wie auch speziellen Problemen im Zusammenhang mit Dokumentation.
Methode
Dokumentation agil entwickeln
Die Werte aus dem Manifest für agile Software-Entwicklung bilden das Fundament agiler Entwicklung. Mit cards+ kann auch Dokumentation agil entwickelt werden. Agil Dokumentieren bezeichnet ein schrittweises Erfassen von Entscheidungen und Wissen in einem agilen Entwicklungsprozess. Die Struktur der Produktdokumentation ist so gestaltet, dass Ergebnisse schrittweise mit einem geeigneten Baustein gesichert werden kann. Autoren schreiben nur das auf, was sie jetzt wissen. Keine Wünsche. Keine Vermutungen.
Aufgrund der maßgeschneiderten Struktur können Autoren trotzdem jeden Baustein in kurzer Zeit abschließen. Eine wichtige Bedingung für ein agiles Entwicklungsprojekt, um Dokumentation als ein weiteres Ergebnis einer Iteration zu fordern. Bei agiler Entwicklung mit Scrum kann ein Produktverantwortlicher die Regeltermine von Scrum nutzen, um Feedback auch zur Produktdokumentation einzusammeln. Mit dem Einsatz von cards+ gilt:
Dokumentation wird wie Code entwickelt!
Eine Produktdokumentation hat eine innere Struktur. Sie besteht aus Bausteinen mit einem klar formulierten und prüfbaren Inhalt. Es bietet sich ganz einfach an, die Produktdokumentation im gleichen agilen Prozess zu schreiben, in dem auch das Produkt programmiert und getestet wird.
Eine Produktdokumentation wird über die gesamte Lebenszeit eines Produktes gebraucht. Bei sehr erfolgreichen Produkten sind das Jahrzehnte. Ein Produkt entsteht oder wächst, indem Visionen und Ideen eines Produktverantwortlichen durch sein Team in Software transformiert werden. Testpläne, organisiert in einer Testpyramide, sichern die Qualität der Software ab. Handbücher geben Einblick in die Fähigkeiten der Software, erklären den Nutzern, wie sie verwendet werden. In den Bausteinen der Systembeschreibung wird der Problemraum des Produktes beschrieben. Sie geben Antwort auf die Fragen wer, wann und warum etwas mit dem Produkt tut. Die Bausteine der Systembeschreibung beantworten hingegen die Frage, wie das Produkt realisiert wurde. Zusammen mit den Bausteinen des Architekturentwurfs beschreiben sie den Lösungsraum.
Eine Produktdokumentation hat das Ziel, den Zustand eines Produktinkrementes so exakt wie möglich zu beschreiben. Sie existiert im Wiki und wird genutzt, um Spezifikationen und Testpläne zu veröffentlichen. Sie bildet das zentrale Verzeichnis der für das Produkt relevanten Dokumente.
Methode
Dokumente nach ihrer Art unterscheiden
Eine einigermaße komplexe Software ohne Dokumentation ist für mich nicht vorstellbar. Ein Produktverantwortlicher kann oder besser muss sich über den Prozess der Erstellung einer Produktdokumentation Gedanken machen. Im allgemeinen Sprachgebrauch werden Dokumente geschrieben. Mit cards+ werden Dokumente entwickelt. Das geht aber nicht mit jeder Art von Dokument.
Eine Produktdokumentation ist unverzichtbar für das Aufrechterhalten des agilen Entwicklungsprozesses und unterstützt die Kommunikation in der Projektorganisation. Sie beschreibt Ergebnisse. Abstimmungen führen zu Entscheidungen. Anforderungen werden analysiert und umgesetzt oder abgelehnt. Aufgaben werden erledigt, damit ein neues Produktinkrement entsteht.
Der Begriff Projektdokumentation fasst jene dokumentierte Informationen zusammen, die für das Aufrechterhalten von Prozessen, also Planung und Steuerung von Aufgaben, notwendig sind. cards+ bietet für die Projektdokumentation keinen Baustein! Die Artenvielfalt ist einfach zu groß. Die Bedürfnisse der interessierten Parteien sind zu unterschiedlich. Die Lebensdauer der Dokumente ist oft zu gering für einen wirtschaftlich vertretbaren Ansatz zur Standardisierung.
Methode
Kommentare erfolgreich moderieren
Die Methode cards+ verfolgt ein sehr wichtiges Ziel. Eine lebendige Produktdokumentation. Sie lebt u.a. durch das Feedback der Leser. Feedback als Kommentare in den Seiten des Wiki ist für alle sichtbar, auch eventuell daraus entstehende Diskussionen. Feedback ist jederzeit willkommen. Die Erstellung und Pflege von Inhalten im Wiki ist Aufgabe der Autoren. Dazu gehört auch die Moderation der Kommentare der Leser in den Seiten. Im Sinne der Nachhaltigkeit entfernt der Autor einer Seite Kommentare, die bereits zur Korrektur der Dokumentation verwendet wurden. Nicht mehr relevante oder sachlich nicht korrekte Kommentare löscht er nach Abschluss der Klärung mit dem Ersteller des Kommentars. Durch dieses aktive Management der Kommentare schaffen wir Transparenz bei den Änderungen der Inhalte. Autoren können Kommentare auch als Indikator für die Qualität der Dokumentation heranziehen.
Eine Seite im Wiki, die keine Kommentare enthält, ist darum eine gute Seite.
Andererseits ist eine Seite im Wiki mit Kommentaren schlicht und einfach nicht fertig. Sehr viele Kommentare aus einer von mehreren Lesern kontrovers geführten Diskussion sind ein klares Indiz für den Autor, das Thema der Seite noch einmal intensiver zu betrachten.
Methode
Der Gärtner trägt Verantwortung
Es gibt das Phänomen, dass intelligente Menschen gegen Regeln verstoßen, obwohl sie von ihrer Wirksamkeit im Allgemeinen überzeugt sind. Trotzdem verteidigen sie die Abweichung von der Regel mit dem Argument, dass es eine notwendige Verbesserung oder gar Innovation ist. Manche tun es sogar im guten Glauben, dass ihr Weg besser ist, diese Änderung schon lange notwendig war. Das ist eine Gefahr für die Qualität einer Produktdokumentation. Individuell gestaltete Seiten sind praktisch nicht prüfbar. Es ist schwerer, die Bearbeitung einer Seite an einen anderen Autor zu übergeben. Die Bausteine bilden ein abgestimmtes Konzept. Abweichungen gefährden die Konsistenz. Abgrenzung ist eine hilfreiche Methode, um diesem Problem zu begegnen.
Die Goldene Regel der Gärtner besagt, dass eine Information, für die es keinen Baustein in der Produktdokumentation gibt, ganz automatisch zur Projektdokumentation gehört — und damit anderen Regeln unterliegt. Natürlich mit allen Konsequenzen bezüglich Nachhaltigkeit und Qualität. Eine Herausforderung für einen Gärtner ist, Stärke zu zeigen. Stärke, Autoren auf die Einhaltung der Regeln der Produktdokumentation einzuschwören.
Der Gärtner ist verantwortlich für die Auswahl der Werkzeuge und der technischen Infrastruktur für das Wiki. Das ist sozusagen die Entwicklungsumgebung für die die Autoren. Er ist Experte im Zusammenhang mit Dokumentation. Seine Aufgaben sind die Formulierung und Durchsetzung von Dokumentationsrichtlinien, ähnlich den Programmierrichtlinien der Entwickler. Er sorgt für die Einhaltung der Regeln der Methode cards+, vergleichbar dem Scrum-Master als Hüter des Scrum-Prozesses oder einem IT-Experten für den Architekturstil. Aus dieser Argumentation heraus ergibt sich zwangsläufig, dass für die Pflege einer Produktdokumentation ein Gärtner in der Art eines IT-Experten für Dokumentation gebraucht wird.
Der Gärtner ist Trainer für die Methode cards+. Er ist greifbar für Autoren und Leser und hilft bei der Bewältigung von alltäglichen wie auch speziellen Problemen im Zusammenhang mit der Dokumentation. Ähnlich wie beim Verhältnis von IT-Experte und Entwickler (Stichwort Elfenbeinturmarchitekt) ist es für einen Gärtner sehr hilfreich, selbst auch Autor zu sein. Zumindest muss er aktiver Leser sein.
Robert Bruckbauer beantwortet Fragen und unterstützt als Gärtner.
Methode
Schutz vor Wissensverfall
Eine große Gefahr für die Leistungsfähigkeit eines Teams sind Kopfmonopole und Wissensinseln. Eine Person sammelt über lange Zeit wertvolles Wissen über das Produkt. Er nutzt dieses Wissen, um erfolgreich seine Aufgaben im Team zu erfüllen. Dann verlässt er das Team. Wichtiges, nicht schriftlich erfasstes Wissen geht unwiderbringlich verloren. Selbst bei einem gut vorbereiteten Ausstieg mit Übergabe oder einer schriftlichen Nachdokumentation gehen Informationen verloren.
Ein Grund für Wissensverfall ist die Trägheit des menschlichen Gehirns und das damit verbundene Vergessen von Informationen.
Ein Mensch erinnert sich gut an die aktuellen Aufgaben. Aber an alle länger zurückliegenden, in der Regel abgeschlossene Aufgaben kann er sich weniger gut erinnern. Wichtige Details bleiben unerwähnt.
Die Vergemeinschaftung von Wissen (engl. shared knowledge) ist eine Maßnahme, die diesem Verfall entgegenwirkt. Jeder im Team teilt sofort sein Wissen. Er tut dies nachhaltig, also schriftlich. Mit cards+ ist das Erfassen sehr einfach. Durch das Wiki gibt es keine Hürden. Internet und ein Browser reicht.
Methode
Fachliche Schulden
Das Manifest für agile Software-Entwicklung verlangt nicht den Verzicht auf Dokumentation, sondern will, dass das eigentliche Ziel, ein funktionierendes Produkt, nicht darunter leidet. Dokumentieren im Allgemeinen wird trotzdem von so manchem Entwickler als Aufgabe abgelehnt. Sie wollen nur das dokumentieren, was für ihre Arbeit als Entwickler oder Tester einen Wert darstellt. Dokumentieren wird in besonderen Situationen gerne auch auf später verschoben. Andere Entwickler dokumentieren in der “heißen” Phase der Realisierung sehr gerne und ausgiebig ihre aktuelle Lösung. Es entstehen sehr genaue Beschreibungen und detailgetreue Bilder. Sobald aber die Software eine gewisse Reife erreicht, sinkt die Motivation, diese Dokumente zu aktualiseren.
Beide Vorgehensweisen führen zu fachlichen Schulden. Das Produkt ist unvollständig. Die Produktdokumentation enthält sprichwörtlich “verdorbene” Dokumente. Leider können Leser die “faulen” Stellen in der Dokumentation nicht immer erkennen. Sie werden in die Irre geführt und verlieren das Vertrauen in die Dokumentation. Damit beginnt ein Teufelskreis. Weniger Leser bedeutet weniger Feedback für die Autoren. Fehlendes Feedback führt zu sinkender Qualität. Sinkende Qualität vertreibt weitere Leser.
Methode
Spezifikation ist Teamaufgabe
Mit cards+ wird mit den Begriffen Systembeschreibung, Systemstruktur, Spezifikation und Testplan eine klare Aufgabenteilung zwischen Produktverantwortlichen und seinem Team angestrebt.
Der Produktverantwortliche bewegt sich im Wiki. Er nutzt die Bausteine der Systembeschreibung, um seine Vision bis hinunter zu einer konkreten Fähigkeit der Software zu dokumentieren. Er nutzt die Bausteine der Systemstruktur, um Diensten und Objekten in Abstimmung mit dem Team eindeutige Namen und einen fachlichen Zweck zu geben. Für jede geforderte Fähigkeit schreibt er einen Arbeitsauftrag (engl. story) für die Entwickler. Dort konkretisiert er einen unvollständigen Baustein Case durch Akzeptanzkriterien. Unvollständig heißt in diesem Fall ohne Lösung.
Das Team nimmt entsprechend der Priorisierung des Produktverantwortlichen einen Arbeitsauftrag an. Es ist vollkommen unstrittig, dass Programmieren und Testen beides Aufgaben des Teams sind. Sie suchen eine Lösung für die geforderte Fähigkeit der Software im Rahmen des gewählten Architekturstils. Die Akzeptanzkriterien im Arbeitsauftrag sind Grundlage für die Testpläne. Die Ergebnisse des agilen Entwicklungsprozesses, also Code, code-nahe Artefakte, Testpläne und Spezifikationen, werden in einer quelltext-basierten Versionsverwaltung nachvollziehbar gespeichert.
In der Methodik von cards+ ergeben die Bausteine im Wiki als auch die Ergebnisdokumente der Entwickler und Tester zusammen eine vollständige Produktdokumentation. Eine Dokumentation wirkt aber nur dann vollständig, wenn alle dokumentierten Informationen in einem Medium präsentiert wird. Das ist im Fall von cards+ das Wiki. Dort befinden sich bereits die Bausteine. Durch geeignete Konvertierung werden Spezifikationen der Entwickler und Testpläne der Tester im Wiki veröffentlicht.