Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix minor errors in week 11. #74

Open
wants to merge 4 commits into
base: main
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
38 changes: 19 additions & 19 deletions docs/week11/agile.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,10 @@ die im vorigen Video diskutierten Qualitätsmerkmale. Ein Nachteil dieser tradit
Für kleine bis mittelgrosse Projekte führen diese Methoden zu einem gewissen Overhead. Viel Zeit wird damit verbracht zu entscheiden, wie das System entwickelt wird, und verhältnismässig wenig Zeit mit der eigentlichen Entwicklung und dem Testen der Software. Wie wir bereits gesehen haben, ist es beim Wasserfallmodell auch nur schwer möglich, auf Veränderungen zu reagieren.*

*Durch das Internet ist in den 90er Jahren ein sehr dynamisches Umfeld entstanden, in dem sich Anforderungen an Anwendungen innerhalb kurzer Zeit
radikal ändern konnten. Es ist also nicht erstaunlich, dass sich in dieser Zeit eine Gegenbewegung entwickelt hat, die die Flexibilität in der Entwicklung, aber auch die Rolle der Entwickler, wieder in den Vordergrund gestellt hat. Es sind dabei verschiedene Methodologien, wie Extreme Programming, Kanban oder Scrum entstanden. Alle diese Methodologien werden als *Agile* Methodologien bezeichnet.*
radikal ändern konnten. Es ist also nicht erstaunlich, dass sich in dieser Zeit eine Gegenbewegung entwickelt hat, die die Flexibilität in der Entwicklung, aber auch die Rolle der Entwickler, wieder in den Vordergrund gestellt hat. Es sind dabei verschiedene Methodologien, wie Extreme Programming, Kanban oder Scrum, entstanden. Alle diese Methodologien werden als *Agile* Methodologien bezeichnet.*

## Das Agile Manifest
Im Jahre 2001 haben sich eine Gruppe von Vertretern von verschiedenen Agilen Methodologien getroffen und versucht, die Werte die
Im Jahre 2001 hat sich eine Gruppe von Vertretern von verschiedenen Agilen Methodologien getroffen und versucht, die Werte die
all diesen Methoden zugrunde liegen in einem Manifest festzuhalten. Dabei ist das *Agile Manifest* entstanden.

Die deutsche Übersetzung lautet wie folgt:
Expand All @@ -29,7 +29,7 @@ Die deutsche Übersetzung lautet wie folgt:

## Methodologien

Es gibt ganz verschiedene Methodologien, die diese Werte so umsetzen. Ein früher, und sehr einflussreicher Ansatz ist *Extreme Programming*.
Es gibt ganz verschiedene Methodologien, die diese Werte so umsetzen. Ein früher und sehr einflussreicher Ansatz ist *Extreme Programming*.
Die heute am weitesten verbreitete Methodologie ist sicherlich *Scrum*. Wir werden uns Scrum später in dieser Vorlesung noch genauer anschauen.

Um einen kurzen Eindruck zu erhalten, was für Methoden eingesetzt werden können, um die Werte im Agilen Manifest umzusetzen, schauen wir uns hier aber als erstes kurz einige Methoden von Extreme Programming an:
Expand All @@ -43,49 +43,49 @@ Um einen kurzen Eindruck zu erhalten, was für Methoden eingesetzt werden könne

Zusammen mit dem Kunden, der im Extreme Programming immer vor Ort sein sollte, werden in einem Plannungsspiel die wichtigsten Anforderungen identifiziert.
Wie wichtig eine Anforderung ist, wird daran gemessen, wie viel Wert sie dem Kunden bringt. Die Anforderungen werden mithilfe von *User-Stories* ermittelt.
*User Stories* sind Use-Cases sehr ähnlich, sind aber vom Umfang her deutlich kleiner. Jede User Story soll in 2-3 Sätzen eine Anforderung beschreiben und dabei erklären, wie eine Interaktion eines Nutzers mit dem System von sich geht und welchen Wert sie dem Kunden bringt. Wenn alle Stories geschrieben sind, werden diese
*User-Stories* sind Use-Cases sehr ähnlich, sind aber vom Umfang her deutlich kleiner. Jede *User-Story* soll in 2-3 Sätzen eine Anforderung beschreiben und dabei erklären, wie eine Interaktion eines Nutzers oder einer Nutzerin mit dem System von sich geht und welchen Wert sie dem Kunden bringt. Wenn alle Stories geschrieben sind, werden diese
priorisiert und daraus werden die Anforderungen für den nächsten Release bestimmt. Im Gegensatz zu traditionellen Methoden wird hier also kein detailliertes Pflichtenheft verfasst.

##### Kleine Releases
Eine wichtige Methode um schnelle Feedback Loops zu erreichen ist es, dass wir nur kleine Releases machen. Im Extreme Programming verfolgen wir also ein
Eine wichtige Methode um schnelle Feedback Loops zu erreichen ist, dass wir nur kleine Releases machen. Im Extreme Programming verfolgen wir also ein
inkrementelles oder iteratives Prozessmodell. In jedem Release wird die Software einen Schritt in Richtung Gesamtsystem erweitert.

##### Metapher
Das Team einigt sich auf deine gemeinsame Vision, wie das System funktionieren soll. Um diese Vision zu unterstützen, wird eine entsprechende Metaphor gesucht
(also zum Beispiel, das System funktioniert wie ein Bienennest). Auch wenn keine so bildliche Metaphor gefunden wird, sollte sich das Team zumindest auf
gemeinsame Terminologie einigen, damit alle Teammitglieder genau wissen, wie die Teile vom System funktionieren, und keine Kommunikationsprobleme auftauchen.
Das Team einigt sich auf eine gemeinsame Vision, wie das System funktionieren soll. Um diese Vision zu unterstützen, wird eine entsprechende Metapher gesucht
(also zum Beispiel, dass das System funktioniert wie ein Bienennest). Auch wenn keine so bildliche Metapher gefunden wird, sollte sich das Team zumindest auf
gemeinsame Terminologie einigen, damit alle Teammitglieder genau wissen, wie die Teile vom System funktionieren und keine Kommunikationsprobleme auftauchen.

##### Einfaches Design

Das Design soll so einfach wie möglich gehalten werden. Es wird immer das im Moment einfachst mögliche Design gewählt, ohne bereits mögliche zukünftige Änderungen
miteinzubeziehen. Die Philosophie dahinter ist, dass wenn wir bereits für die Zukunft designen, wird unser System schnell komplex und enthält Funktionalität, die
miteinzubeziehen. Die Philosophie dahinter ist, dass wenn wir bereits für die Zukunft designen, unser System schnell komplex wird und Funktionalität enthält, die
wir nie brauchen werden. (Das ist auch unter dem Akronym YAGNI, *You aint gonna need it* bekannt).

##### Test First Ansatz

Bevor eine Funktionalität implementiert wird, müssen immer zuerst Testfälle geschrieben werden. Damit wird der Kunde gezwungen, die Anforderungen genau
zu spezifizieren. Das Ziel des Entwicklers ist es dann, das einfachstmögliche System, welches die Tests erfüllt, zu implementieren.
zu spezifizieren. Das Ziel der Entwickelnden ist es dann, das einfachstmögliche System, welches die Tests erfüllt, zu implementieren.

##### Refactoring

Während das System wächst, ändern sich die Anforderungen an das System zwangsläufig. Da man in Extreme Programming nur immer das
einfachste Design wählt, ohne die Möglichkeit von künftigen Anforderungen miteinzubeziehen, muss das gewählte Design häufig verändert werden. Das *Code refactoring*, also das überarbeiten und verbessern des bestehenden Codes, ohne die Funktionalität zu ändern,
einfachste Design wählt, ohne die Möglichkeit von künftigen Anforderungen miteinzubeziehen, muss das gewählte Design häufig verändert werden. Das *Code refactoring*, also das überarbeiten und verbessern des bestehenden Codes ohne die Funktionalität zu ändern,
ist deshalb ein wichtiger Teil vom Projekt. Refactoring sollte in kleinen Schritten durchgeführt werden. Durch die Umfangreiche Testabdeckung wird sichergestellt, dass auch nach dem Refactoring die Anforderungen noch immer erfüllt sind.


##### Pair Programming

An der Entwicklung von jeder Funktionalität sind immer zwei Entwickler beteiligt. Dabei sitzen diese immer vor demselben Computer und teilen sich eine Tastatur.
Damit wird nicht nur die Code-qualität verbessert, sondern es wissen auch immer mehrere Personen bescheid, wie ein Stück software funktioniert. Wenn immer ein
erfahrenerer Entwickler mit einem weniger erfahrenen Entwickler zusammenarbeitet, kann Pair Programming auch als Ausbildungprozess und Wissenstransfer gesehen werden.
An der Entwicklung von jeder Funktionalität sind immer zwei Entwickelnde beteiligt. Dabei sitzen diese immer vor demselben Computer und teilen sich eine Tastatur.
Damit wird nicht nur die Code-qualität verbessert, sondern es wissen auch immer mehrere Personen bescheid, wie ein Stück software funktioniert. Wenn immer eine
erfahrenere Person mit einer weniger erfahreneren Person zusammenarbeitet, kann Pair Programming auch als Ausbildungprozess und Wissenstransfer gesehen werden.

##### Kollektive Verantwortung (Ownership)

Im Extreme Programming kann jeder Programmieren jeden Teil vom Programm ändern. Es gibt also keine Programmieren, die für nur einen Teil vom Programm verantwortlich sind.
Im Extreme Programming kann jeder Programmierer und jede Programmiererin jeden Teil vom Programm ändern. Es gibt also keine Programmierenden, die für nur einen Teil vom Programm verantwortlich sind.

##### Kontinuierliche Integration

Damit schnelle Feedback loops möglich sind, sollte es immer möglich sein eine lauffähige (und getestete) Version eines Systems innerhalb kurzer Zeit zu erstellen.
Damit schnelle Feedback loops möglich sind, sollte es immer möglich sein, eine lauffähige (und getestete) Version eines Systems innerhalb kurzer Zeit zu erstellen.
Dazu werden Systems genutzt, die automatisiert die Module integrieren und die entsprechenden Integrationstests ausführen.

##### Nachhaltiges Arbeitstempo
Expand All @@ -99,15 +99,15 @@ Kunde kann auch Input und Feedback geben, wie das System getestet werden kann.

##### Entwicklungsstandards

Damit alle Entwickler im Team reibungslos zusammenarbeiten können, werden im Extreme Programming klar definierte Coding Standards eingesetzt. Das Ziel ist,
Damit alle Entwickelnden im Team reibungslos zusammenarbeiten können, werden im Extreme Programming klar definierte Coding Standards eingesetzt. Das Ziel ist,
dass obwohl ein System von vielen Leuten in enger Kooperation entwickelt wird, der Code aussehen sollte, als wäre er von einer Person entwickelt worden.


## Agil oder traditionell

Wir haben nun einige mögliche Methoden gesehen, wie man agile Prinzipien und Werte umsetzen kann. Extreme Programming ist nur eine von vielen Möglichkeiten, und wir werden sehen, dass zum Beispiel Scrum, zum Teil abweichende Methoden propagiert. Allen agilen Methoden ist aber gemeinsam, dass die Flexibilität im Vordergrund steht und insbesondere die Dokumentation eine viel kleinere Rolle einnimmt als in traditionellen Entwicklungsprozessen.
Wir haben nun einige mögliche Methoden gesehen, wie man agile Prinzipien und Werte umsetzen kann. Extreme Programming ist nur eine von vielen Möglichkeiten und wir werden sehen, dass zum Beispiel Scrum zum Teil abweichende Methoden propagiert. Allen agilen Methoden ist aber gemeinsam, dass die Flexibilität im Vordergrund steht und insbesondere die Dokumentation eine viel kleinere Rolle einnimmt als in traditionellen Entwicklungsprozessen.

Wie so häufig, wenn etwas als Gegenreaktion auf etablierte Strukturen und Abläufe entwickelt wird, gibt es die Tendenz, dass das
Pendel zu sehr auf die Gegenseite ausschwingt, und auch die guten Seiten der traditionellen Methoden mit über Bord geworfen werden. Entsprechend gibt es auch kritische Stimmen zu diesem Ansatz. Wir werden im nächsten Artikel eine solche Kritik lesen.
Pendel zu sehr auf die Gegenseite ausschwingt und auch die guten Seiten der traditionellen Methoden mit über Bord geworfen werden. Entsprechend gibt es auch kritische Stimmen zu diesem Ansatz. Wir werden im nächsten Artikel eine solche Kritik lesen.