SOFTWARETECHNIK WISE 2018/2019 - UMSETZUNG EINES QWIRKLE-SPIELS

Die Seite wird erstellt Franz Weiss
 
WEITER LESEN
Softwaretechnik WiSe 2018/2019

       Umsetzung eines Qwirkle-Spiels

     Product Vision & Vorgaben

                      Auftraggeber
Eric Bodden, Manuel Benz, Johannes Geismann, Stefan Krüger
     Fachgruppe Softwaretechnik, Heinz Nixdorf Institut
   Fakultät für Elektrotechnik, Informatik und Mathematik
   Universität Paderborn, Fürstenallee 11, 33102 Paderborn

                        Version 1.1

              Paderborn, den 20. Oktober 2018
Changelog
Version 1.1:

   • 1.2.3: Konfiguration hinsichtlich Farben- und Symbolanzahl auf zwölf beschränkt.

   • 1.2.3: Konfiguration hinsichtlich Anzahl von Steinen, die ein Spieler auf der Hand haben
     darf, erweitert.

   • 1.3: Zahl der Farben und Symbole auf zwölf beschränkt.

   • 1.3: Satz entfernt, wie getauschte Steine in den Stapel zurückgelegt werden.
Inhaltsverzeichnis

Inhaltsverzeichnis
1 Product Vision                                                                                                                         1
  1.1 Einleitung . . . . . . . . . . . . .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   1
  1.2 Nutzergruppen und Funktionalität       .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   1
      1.2.1 Beobachter . . . . . . . .       .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   1
      1.2.2 Spieler . . . . . . . . . .      .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   1
      1.2.3 Ausrichter . . . . . . . . .     .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   2
  1.3 Spielregeln . . . . . . . . . . . .    .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   3

2 Organisatorische & Technische Vorgaben                                                                                                 4
  2.1 Deliverables . . . . . . . . . . . . . . . . .             .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   4
  2.2 Ablauf des Praktikums . . . . . . . . . . .                .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   5
  2.3 Protokoll-Komitee . . . . . . . . . . . . .                .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   6
  2.4 Praktikumsturnier . . . . . . . . . . . . . .              .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   6
  2.5 Technologien und Entwicklungswerkzeuge                     .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   .   7

                                             II
1 Product Vision

1 Product Vision
1.1 Einleitung
Wir, die FG Softwaretechnik beauftragen Sie mit der Entwicklung eines Qwirkle-Spiels, wel-
ches als Software unter Mac OS X, Ubuntu, Windows und Android (Version 5.0.1 und höher)
lauffähig ist.
Dieses Dokument beschreibt unsere Wünsche an das zu entwickelnde Produkt und den Pro-
jektablauf.

1.2 Nutzergruppen und Funktionalität
In diesem Kapitel wird die gewünschte Funktionalität aus Benutzersicht beschrieben. Unter-
schieden wird zwischen Beobachtern, Spielern und Ausrichtern.

1.2.1 Beobachter
Beobachter nutzen einen Beobachter-Client, der sowohl für PC- als auch für Android-Geräte
verfügbar ist. Mit diesem Client melden sich Beobachter an einem Spielserver an, der sich
sowohl im lokalen Netzwerk (LAN) als auch im Internet befinden kann. Auf einem Spielserver
können sich eine unbegrenzte Anzahl von Beobachtern anmelden. Nach erfolgter Anmeldung
befinden sich Beobachter zunächst in einer Lobby. Dort können sie übersichtlich erkennen,
welche Spiele gerade laufen, in Kürze starten und vor Kurzem beendet wurden. Aus dieser
Übersicht heraus können Beobachter jedes der dort gelisteten Spiele betreten, um das Spiel in
Echtzeit nachzuverfolgen. Sämtliche für das Spiel relevanten Aspekte sind sinnvoll erkennbar.
Dazu gehören u.a. die verbleibende Bedenkzeit der Spieler, die bisher gespielten Steine, Art
und Anzahl der Steine auf dem Stapel, und sämtliche Spielsteine auf den Händen aller aktiven
Spieler. Bei Spielende werden die Beobachter über das Ergebnis des Spiels benachrichtigt.
Beobachter haben keine Möglichkeit, das Spiel zu beeinflussen.

1.2.2 Spieler
Spieler können menschliche Spieler und nichtmenschliche Spieler sein.
Menschliche Spieler nutzen einen Teilnehmer-Client, der auf Android-Smartphones oder Desktop-
Computern (Windows, Mac OS X, Ubuntu) lauffähig ist. Mit diesem Client melden sich
menschliche Spieler analog wie die Beobachter am Spielserver an. Nach erfolgter Anmeldung
sehen sie, genau wie die Beobachter, die gerade laufenden Spiele, die in Kürze startenden
Spiele und die vor Kurzem beendeten Spiele. Sie können einem Spiel als Beobachter beitreten
oder einem noch nicht gestarteten Spiel als Teilnehmer beitreten. Alternativ können sie auch
vom Spielserver einem Spiel als Teilnehmer zugeordnet werden. Wenn menschliche Spieler
einem Spiel als Teilnehmer angehören, können sie Spielzüge ausführen.

                                             1
1 Product Vision

Nichtmenschliche Spieler sind Programme, die anstelle eines menschlichen Spielers Spielzü-
ge berechnen und ausführen. Ein solches Programm heißt Engine-Teilnehmer. Engine-Teil-
nehmer können auf dem PC via Kommandozeile gestartet werden (z.B. durch Aufruf einer
Jar-Datei) und funktionieren ohne grafische Oberfläche. Beim Aufruf wird die IP-Adresse und
der Port des Servers mitgeteilt, bei dem sich angemeldet werden soll. Der Engine-Teilnehmer
enthält einen Algorithmus, der den nächsten Spielzug berechnet und dem Spielserver mitteilt.
Nur wenn ein Teilnehmer in einem Spiel am Zug ist, kann dieser einen gültigen Zug ausfüh-
ren. Der Spielserver stellt sicher, dass Teilnehmer nur die eigenen Spielsteine und die bereits
gespielten Steine sehen können. Spielsteine der gegnerischen Spieler und die des Stapels sind
nicht erlaubt einzusehen. Darüber hinaus prüft er auch, ob der Zug des Spielers den Spielregeln
entspricht. Die Konsequenz eines ungültigen Zugs ist konfigurierbar. Alle Spieler werden vom
Server über jede gültige Spielaktion informiert. Ferner teilt der Spielserver bei jeder punkt-
bringenden Aktion und auch auf Nachfrage durch Clients den aktuellen Punktestand mit. Der
Spieleserver erkennt auch das Spielende, führt dann die endgültige Punktberechnung durch,
legt das Ergebnis fest und teilt die Beendingung des Spiels und das Ergebnis den betreffenden
Clients mit.
Spieler haben eine festgelegte Bedenkzeit zur Ausführung eines Spielzugs. Die Bedenkzeit
eines Spielers beginnt abzulaufen sobald der Spieler am Zug ist. Die Bedenkzeit wird pro
Spiel am Server festgelegt und ist für alle Teilnehmer gleich. Überschreitet ein Spieler seine
Bedenkzeit, hat er verloren. Die Kontrolle der Bedenkzeit obliegt dem Server. Clients erfahren
auf Nachfrage die ihnen verbleibende Bedenkzeit vom Server.

1.2.3 Ausrichter
Ausrichter starten, konfigurieren und bedienen den Spielserver. Folgende Parameter können
Ausrichter am Spielserver mindestens konfigurieren:

    • Die Anzahl der Farben u. Symbole (Muss der gleiche Wert sein und darf zwölf nicht
      übersteigen)
    • Die Häufigkeit je Spielstein (Ein Wert für alle Steine)
    • Maximale Anzahl der Steine, die ein Spieler auf der Hand haben kann
    • Die Bedenkzeit für jeden Spieler pro Spielzug
    • Die Zeit für Visualisierung
    • Die Konsequenzen für einen regelwidrigen Spielzug. Zur Auswahl stehen: Nichts, Punkt-
      abzug, Auschluss vom Spiel (Kick).

Eine einmalig erstellte Spiel-Konfiguration ist wiederverwendbar. Hierzu kann die Konfigura-
tion in einem vom Protokoll-Komitee definierten Format gespeichert werden. Der Ausrichter
kann eine Konfiguration in einer Datei speichern und bei Bedarf aus einer Datei laden. Der
Ausrichter kann jedes Spiel unabhängig von den anderen Spielen konfigurieren. Zum Erstel-
len, Laden und Speichern von Konfigurationen nutzt der Ausrichter eine grafische Oberfläche,

                                               2
1 Product Vision

die vom Spieleserver bereitgestellt wird. Nachdem der Ausrichter den Spielserver gestartet
hat, können sich andere Nutzer als Teilnehmer oder Beobachter mit ihren Clients anmelden.
Aus der Liste angemeldeter Teilnehmer kann der Ausrichter die Teilnehmer für verschiedene
Spiele auswählen. Der Ausrichter kann entweder selbst oder durch fairen Zufall festlegen, in
welcher Reihenfolge die Teilnehmer ziehen und welcher Teilnehmer zuerst am Zug ist.
Der Ausrichter kann ein Spiel starten, pausieren, fortsetzen und abbrechen. Bei Abbruch des
Spiels entscheidet der Ausrichter über die Wertung des Spiels.
Zur Verwaltung von Turnieren kann der Ausrichter eine Menge von nacheinander auszufüh-
renden Spielen planen und ausführen. Um den Überblick während eines Turniers zu wahren,
zeigt die Oberfläche des Spielservers die Ergebnisse der abgelaufenen Spiele und die aktuelle
Rangfolge der Spieler an.

1.3 Spielregeln
Die Regeln des Spiels sind hier zu finden. Es gibt jedoch folgende Änderungen:

    • Die Spielsteine werden von einem zufällig gemischten, verdeckten Stapel gezogen. Der
      Stapel wird zu Spielbeginn durch den Server gemischt. Um neue Steine zu ziehen, kön-
      nen Spieler eine Anzahl von Steinen beim Server anfordern. Jeder Spieler zieht zu Be-
      ginn seines Spielzugs einen oder mehrere Spielsteine vom Stapel bis er wieder sechs
      Steine auf der Hand hat.

    • Spieler können mehr als sechs Steine auf der Hand haben (siehe Konfigurationsmög-
      lichkeiten)

    • Spieler dürfen Spielsteine tauschen. Wenn ein Spieler nicht legen kann, muss er/sie
      wenigstens einen Stein tauschen. Der/die Spieler/in darf in diesem Zug keine Steine
      mehr legen.

    • Die Anzahl der einzelnen Farben und Symbole ist konfigurierbar und entspricht somit
      nicht notwendigerweise der Verteilung in oben angegebener Anleitung. Die Maximal-
      zahl an Farben und Symbole ist zwölf.

    • Ein Qwirkel (Vervollständigung einer Reihe) ergibt nicht feste sechs Sonderpunkte, son-
      dern Punkte in Höhe der Anzahl der Steine dieser Reihe.

                                             3
2 Organisatorische & Technische Vorgaben

2 Organisatorische & Technische Vorgaben
In diesem Kapitel wird beschrieben, welche organisatorischen und technischen Vorgaben wir
als Auftraggeber an Sie während des Praktikums stellen.

2.1 Deliverables
Im Rahmen des Softwaretechnikpraktikum (SWTPra) entwickeln Sie, entsprechend der Pro-
duct Vision (Kapitel 1), ein netzwerkfähiges Qwirkle-Spiel inklusive entsprechender Clients
für PC und Android. Während des Praktikums wird auf der Webseite der Veranstaltung ein
Abgabeplan veröffentlicht1 . Entsprechend dem veröffentlichten Abgabeplan sind zu den ge-
gebenen Deadlines folgende Dokumente bzw. Implementierungen abzugeben:
      • Angebot
      • Product Backlog
      • Quality-Assurance-Dokument
      • Protokoll-Dokument
      • DevOps-Dokument
      • Endabgabe: Präsentation, Implementierung, Test-Report, Website
Verspätete Abgaben werden sanktioniert. Sämtliche abzugebenden Dokumente können auf
Deutsch verfasst werden. Details zum Inhalt der Abgaben finden Sie auf der Webseite der
Veranstaltung. Der Code selbst und Codekommentare werden auf Englisch verfasst.
Es wird zwei Arten von Teams geben: DS und SD. Die Zuweisung wird nach der Gruppen-
findungsphase zufällig geschehen. Abhängig davon, in welchem Team Sie sind, sind unter-
schiedliche Komponenten zu entwickeln. Da Sie außerdem einige Komponenten im Verlauf
des Projektes von anderen Teams erwerben und erweitern, wird Ihr finales Produkt folgende
Komponenten enthalten:
      • Das von allen Gruppen abzugebende Produkt besteht jeweils aus Spielserver, und Engine-
        Teilnehmer.
      • DS-Teams geben zusätzlich einen PC-Beobachter und einen Smartphone-Teilnehmer
        ab.
      • SD-Teams geben zusätzlich einen Smartphone-Beobachter und PC-Teilnehmer ab.
Eine zusammenfassende Übersicht über die Bestandteile des zu liefernden Produkts finden Sie
in Abbildung 1.
Um die Kompatibilität zwischen den Komponenten verschiedener Teams zu gewährleisten,
wird das Kommunikationsprotokoll gemeinschaftlich von allen Teams in einem Protokoll-
Komitee spezifiziert. Mehr dazu im Abschnitt 2.3.
 1
     https://www.hni.uni-paderborn.de/swt/lehre/swtpra/

                                              4
2 Organisatorische & Technische Vorgaben

                       Server
                           Konfiguration           Spiel-Server

                                               Netzwerk

          Clients
              PC-     Smartphone-    PC-    Smartphone-                Engine-
           Beobachter Beobachter Teilnehmer Teilnehmer               Teilnehmer

                     M              M

          Legende:
             entwickelt durch   entwickelt durch     entwickelt im   M auf Messe
                Gruppe DS          Gruppe SD       Protokoll-Komitee   gehandelt

                 Abbildung 1: Übersicht über das zu entwickelnde Produkt

2.2 Ablauf des Praktikums
Nach Abgabe Ihres Angebots, Product Backlog und des Quality Assurance Dokuments, star-
ten Sie mit der Umsetzung des Produkts (Implementierung, Testen, Dokumentation, Sprint
Planung, etc.). In der Rolle des Kunden behalten wir es uns vor ggf. eine Überarbeitung des
Angebots, Product Backlogs, oder Quality-Assurance-Dokuments vor dem Start der Umset-
zung zu verlangen.
Während der Umsetzungsphase wird eine Messe stattfinden, die zur Präsentation sowie zum
Erwerb bzw. Veräußerung der bisher erstellten Komponenten aller Teams dient.

   • Als SD-Team bieten sie den entwickelten Smartphone-Beobachter den DS-Teams zum
     kostenlosen Erwerb an.

   • Als DS-Team bieten sie den entwickelten PC-Beobachter den SD-Teams zum kostenlo-
     ses Erwerb an.

Zusätzlich zur Implementierung stellen Sie dem erwerbenden Team Ihr DevOps-Dokument
bereit, das die Konfiguration und Inbetriebnahme der betreffenden Komponenten beschreibt.
Auch nach der Messe liegt es in Ihrer Pflicht Support für die vertriebenen Komponenten zu
leisten, indem Sie Fehler in Ihrer Software beheben und den Erwerbern neue Versionen zu-
gänglich machen.

                                               5
2 Organisatorische & Technische Vorgaben

Um ein komplettes Produkt zu erhalten, integrieren Sie die auf der Messe erworbenen Kompo-
nenten in Ihre bisherige Implementierung. Wir empfehlen allen Teams die Weiterentwicklung
des von Ihnen eingekauften Beobachters zu einem Teilnehmer und keine vollständige Neuent-
wicklung.
Nach Fertigstellung Ihres Produkts und der dazugehörigen Dokumente, präsentieren Sie Ihr
Produkt in einer Abschlusspräsentation inklusive einer Live-Demonstration. Die Abschluss-
präsentation schließt die Entwicklung einer Webseite ein, auf der Sie Ihr Produkt und Ihre
Dokumente präsentieren2 .
Am Ende des Praktikums werden wir ein Turnier veranstalten, in dem die Engine-Teilnehmer
der Teams gegeneinander antreten. Durch einen noch festzulegenden Turniermodus wird im
Turnier der beste Engine-Teilnehmer ermittelt. Zusätzlich werden nach dem Turnier die Teams
geehrt, die – unabhängig vom Engine-Teilnehmer– im Verlauf des Praktikums die besten Leis-
tungen gezeigt haben.

2.3 Protokoll-Komitee
Um die Kompatibilität der von unterschiedlichen Teams entwickelten Clients und Server zu
gewährleisten, wird ein geeignetes Kommunikationsprotokoll von Ihnen in einem Protokoll-
Komitee entwickelt. Hierzu entsendet jedes Team einen Protokoll-Beauftragten in das Protokoll-
Komitee. In der ersten Sitzung des Protokoll-Komitees wählen die Protokoll-Beauftragten
einen Vorsitzenden, der das Komitee leitet. Entscheidungen des Komitee müssen mit absolu-
ter Mehrheit beschlossen werden. Enthaltungen sind hierbei nicht möglich. Jede Gruppe muss
also an jedem Entscheidungsprozess teilnehmen. Mutwilliges Enthalten einer Gruppe führt
zu Punktabzug für die gesamte Gruppe. Das Komitee wird durch den Programmierbetreuer
unterstützt.
Die Entscheidungen des Protokoll-Komitees und das Protokoll selbst werden durch das Komi-
tee in einem gesonderten Protokoll-Dokument festgehalten und zu einer separat ausgewiese-
nen Deadline abgegeben. Das festgehaltenen Protokoll dient als Grundlage der Implementie-
rungen aller Teams, um deren Kompatibilität untereinander zu gewährleisten. Sollten während
der Implementierung Änderungen am Protokoll notwendig werden, trifft sich das Komitee er-
neut und veröffentlicht eine neue Version des Protokolls und Dokuments.

2.4 Praktikumsturnier
Am Ende des Praktikums findet ein Turnier statt, in dem die von den Teams entwickelten
Engine-Teilnehmer gegeneinander antreten. Der Server für das Turnier wird entweder von den
Auftraggebern gestellt oder es wird ein von den Teams entwickelter Spielserver ausgewählt.
Bei der Auswahl des PC-Beobachters für das Turnier wird analog verfahren. Die Konfigurati-
on für das Turnier wird erst beim Turnier selbst bekannt gegeben. Daher empfiehlt es sich vor
dem Turnier Ihren Engine-Teilnehmer mit verschiedenen Konfigurationen zu testen.

 2
     Eine Facebook-Seite oder Profile auf anderen Social-Media-Seiten genügen nicht.

                                                       6
2 Organisatorische & Technische Vorgaben

2.5 Technologien und Entwicklungswerkzeuge
Zur Anfertigung des Product Backlogs ist die Scrum Online-Platform Taiga.io3 einzusetzen.
Nach einer einmaligen Registrierung können Sie die von uns gehostete Taiga.io Instanz unter
der Adresse https://swtpra.cs.upb.de/ erreichen. Bei Fragen und Problemen bzgl.
Taiga.io können Sie sich an die Programmierbetreuung wenden.

Die Implementierung erfolgt unter Benutzung der Programmiersprache Java. Das fertige Pro-
dukt soll unter der aktuellsten Version von Java SE 8 lauffähig sein. Die Android-Apps sollen
ab Android 5.0.1 (API-Level 21) lauffähig sein.

Das Kommunikationsprotokoll zwischen Server und Clients sowie das Dateiformat zur Spei-
cherung der Konfiguration werden auf der Grundlage von JSON umgesetzt.

Zur Entwicklung und Versionsverwaltung im Team werden innerhalb des Praktikums die Git-
Lab https://git.cs.upb.de/ Server der Universität genutzt. Hierzu werden von uns
Git-Repositories für die einzelnen Gruppen angelegt. Um Zugriff auf das Git-Repository ei-
ner Gruppe zu erhalten, wird ein Git-Client benötigt. Git-Clients mit GUI sind zum Beispiel
TortoiseGit4 oder SourceTree5 .

Um verlässliche und reproduzierbare Builds Ihres entwickelten Produkts und der einzelnen
Komponenten zu realisieren, werden Sie die Build-Systeme Maven bzw. Gradle einsetzen.
Einführungen zu Maven 6 und Gradle 7 finden Sie unter den angegebenen Adressen. Zusätzlich
können Sie sich bei Fragen und Problemen an die Programmierbetreuung wenden.

                                         Optional
Zusätzlich zu den Git-Repositories bietet die Universität Paderborn mit GitLab CI ein System
zur kontinuierlichen Integration Ihrer Implementierung. Mithilfe von GitLab CI kann bsw. bei
pushes in den master-branch automatisiert der Build-Prozess und die Testausführung angesto-
ßen werden. Somit bietet es Ihnen die Möglichkeit bei jedem push automatisiert Ihren Code
zu bauen, zu testen, und bei fehlerhaften Commits sofort Benachrichtigungen per E-Mail zu
erhalten. Dies hilft Ihnen bei der kontinuierlichen Qualitätskontrolle und Koordination. Da
Sie in dieser Veranstaltung entsprechend Scrum nach jedem Sprint ein inkrementelles Produkt
Artefakt entwickeln, können Sie diese mit GitLab CI kontinuierlich bauen und testen. Hil-
fe zu GitLab CI finden Sie unter https://git.cs.upb.de/help/ci/README.md.
Zusätzlich können Sie sich bei Fragen und Problemen an den Programmierberater wenden.
 3
   https://taiga.io/
 4
   https://tortoisegit.org/
 5
   https://www.sourcetreeapp.com/
 6
   https://maven.apache.org/guides/getting-started/maven-in-five-minutes.
    html
 7
   http://www.vogella.com/tutorials/Gradle/article.html

                                             7
Sie können auch lesen