web_AI-5/docs/doku.org

1208 lines
63 KiB
Org Mode
Raw Normal View History

2017-10-29 21:03:20 +01:00
#+TITLE: Casestudy Webtechnologien
#+SETUPFILE: ~/git_repos/notes/settings/html_theme/setup/theme-readtheorg.setup
2017-10-30 07:54:24 +01:00
#+AUTHOR: Ivan Hörler Andreas Zweili
#+LaTeX_CLASS: article
#+LATEX_CLASS_OPTIONS: [a4paper,11pt]
#+LaTeX_HEADER: \input{style}
2018-01-06 15:53:04 +01:00
#+OPTIONS: H:5 todo:t
2018-01-18 20:05:28 +01:00
#+LANGUAGE: de
2018-01-06 15:01:17 +01:00
#+STARTUP: align
2017-10-29 21:03:20 +01:00
2018-01-05 15:04:33 +01:00
* TODO Über dieses Dokument
2017-10-31 21:22:50 +01:00
2017-10-31 20:31:01 +01:00
Im nachfolgenden Abschnitt finden Sie allgemeine Informationen zu
2018-01-05 15:04:33 +01:00
diesem Dokument.
** TODO Titel der Dokumentation
2017-10-31 20:31:01 +01:00
2018-01-05 15:04:33 +01:00
- Note taken on [2018-01-03 Mit 16:30] \\
Müssen wir wohl überarbeiten da wir mal angedacht haben das ein
Musikinstrumene-Shop allenfalls einfacher ist.
2017-10-31 21:22:50 +01:00
2017-10-31 20:31:01 +01:00
Die Gruppe hat verschiedene Varianten gelistet und sich für die
lustigste entschieden.
2017-10-31 22:11:09 +01:00
2017-10-31 20:31:01 +01:00
- Marktplatz
- Shopshop
2017-10-31 22:11:09 +01:00
- Barewahre-Shop
- Didgeridoo-Shop
2017-10-31 20:31:01 +01:00
** Beschreibung
2017-10-31 21:22:50 +01:00
2017-10-31 22:11:09 +01:00
Planung und Erstellung eines konfigurierbaren Web-Shops für
Didgeridoo's.
2017-10-31 20:31:01 +01:00
** Zweck und Inhalt
2017-10-31 21:22:50 +01:00
2017-10-31 20:31:01 +01:00
Zweck dieses Dokuments ist die vollständige und nachvollziehbare
Dokumentation zu unserer Case Study Webtechnologie 3.
** Aufbau
2017-10-31 21:22:50 +01:00
2017-10-31 22:11:09 +01:00
Alle Inhalte sind chronologisch sortiert, vom ältesten zum jüngsten
2017-10-31 20:31:01 +01:00
Ereigniss, und nach Kapiteln getrennt.
2018-01-05 15:04:33 +01:00
** Lizenz
2017-10-31 21:22:50 +01:00
2018-01-05 15:04:33 +01:00
Dieses Dokument sowie der dazugehörige Code wurde von Ivan Hörler und
Andreas Zweili im Rahmen einer Arbeit an der IBZ Schule erstellt und
steht unter einer GPLv3\footcite{gplv3} Lizenz. Dadurch darf die
Arbeit kopiert und weiterverarbeitet unter Einhaltung der Regeln der
GPLv3.
2017-10-31 20:31:01 +01:00
2018-01-05 15:04:33 +01:00
* TODO Projektanalyse und Planung
2017-10-30 22:17:17 +01:00
** Projektziele
2017-10-31 21:22:50 +01:00
2017-10-31 20:31:01 +01:00
Der Student erarbeitet in einer Zweiergruppe einen selbstentwickelten
Web-Shop. Die einzusezenden Technologien sollen Opensource sein. Die
zur verfügungstehende Zeit ist pro Student mit 80h zu veranschlagen.
2017-10-31 22:11:09 +01:00
Am Ende dieser Zeitspanne soll ein funktionaler Web-Shop mit minimalem
2018-01-05 15:04:33 +01:00
graphischen User Interface entstehen, die dazugehörige Dokumentation
2017-10-31 22:11:09 +01:00
umfasst alle Aspekte um die gewählte Lösung nachzuvollziehen.
2018-01-05 15:04:33 +01:00
Die Projekt wurden in der Tabelle: ([[tab:projektziele]]) zusätzlich noch
nach Prioritäten gewichtet.
2017-10-31 20:31:01 +01:00
2017-10-31 22:11:09 +01:00
#+CAPTION: Projektziele
2018-01-05 15:04:33 +01:00
#+ATTR_LATEX: :align |>{\columncolor[HTML]{EFEFEF}}p{0.8cm}|l|p{1.5cm}|
#+NAME: tab:projektziele
2018-01-07 23:46:40 +01:00
|-------+--------------------------------------------------------------------+----------------------|
| <5> | | <20> |
| *Nr.*\cellcolor[HTML]{C0C0C0} | *Beschreibung*\cellcolor[HTML]{C0C0C0} | *Priorität*\cellcolor[HTML]{C0C0C0} |
|-------+--------------------------------------------------------------------+----------------------|
| 1. | Das Datenmodel muss korrekt konzipiert sein. | Hoch |
|-------+--------------------------------------------------------------------+----------------------|
| 2. | Alle Vorgehen müssen in diesem Dokument erläutert werden. | Mittel |
|-------+--------------------------------------------------------------------+----------------------|
| 3. | Die Arbeitsstunden müssen eingehalten werden. | Tief |
|-------+--------------------------------------------------------------------+----------------------|
| 4. | Der Shop muss funktionstüchtig sein. | Mittel |
|-------+--------------------------------------------------------------------+----------------------|
| 5. | Die Applikation muss vor der Übergabe vollständig getestet werden. | Hoch |
|-------+--------------------------------------------------------------------+----------------------|
| 6. | Problemstellungen müssen ersichtlich dokumentiert werden. | Mittel |
|-------+--------------------------------------------------------------------+----------------------|
| 7. | Die Punkte der Bewertung werden erfüllt. | Hoch |
|-------+--------------------------------------------------------------------+----------------------|
2017-10-31 20:31:01 +01:00
** Mittel und Methoden
*** Werkzeuge
2017-10-31 21:22:50 +01:00
2018-01-05 15:04:33 +01:00
Während dem Erstellen dieser Arbeit wurde eine Vielzahl an Werkzeugen
eingesetzt. Nachfolgend werden diese Werkzeuge kurz beschrieben sowie
ihre Verwendung begründet. Wir haben dabei darauf geachtet soviel Open
Source Software wie möglich zu verwenden. Nicht nur für den Web-Shop an
sich sondern generell für alle Tasks im Projekt.
**** Versionkontrolle
Eine Versionskontrollsoftware erschien uns als notwendig um den Code
auf einfache und zuverlässige Weise untereinander austauschen zu
können. Andere Lösungen wie Dropbox, etc. hätten es uns nicht erlaubt
Konflikte zu vermeinden.
Als Software für die Versionskontrolle wurde Git \footcite{git} gewählt.
Git wurde aus diversen Gründen gewählt:
- Ist der de facto Standard bei Versionskontrollsoftware
- Läuft auf allen gängigen Betriebsystemen
- Es gäbe gratis Services die man nutzen könnte (Github, Gitlab)
- Man kann offline arbeiten und Commits erstellen
- Das Team hat bereits einen eigenen Git Server zur Verfügung
- Das Team ist bereits mit Git aus vorhergehenden Projekten vertraut
dadurch muss man keine Ressourcen aufwenden eine neue Software zu lernen.
Zusätzlich hat sich Git in den vorhergehenden Projekten als robuste
und schnelle Software erwiesen.
- Git ist freie Software unter GNU Public License v2.
**** Entwicklungsumgebung
Damit beide Studenten auf der gleichen Basis arbeiten haben wir uns
dazu entschieden den Web-Shop in einer virtuellen Maschine zu
entwickeln. Dies führt jedoch in der Regel zum Problem das die
Änderungen in der virtuellen Maschine miteinander abgesprochen und
ausgetauscht werden müssen. Um dieses Problem zu beheben haben wir uns
dazu entschieden Vagrant\footcite{vagrant} zu verwenden.
Vagrant ist freie Software unter der MIT Lizenz.
Vagrant erlaubt es einem den Zustand einer virtuellen Maschine in
einer Text Datei zu beschreiben und diese dann gemäss der Beschreibung
automatisiert aufzusetzen. Dies hat den Vorteil das die Konfiguration
der virtuellen Maschine auch ohne weiteres mit dem restlichen Code in
der Versionskontrollsoftware gepflegt werden kann.
Desweiteren hilft das automatisierte Aufsetzen das vermeiden von
menschlichen Fehlern. Somit kann davon ausgegangen werden dass, das
System in der virtuellen Maschine immer den korrekten Stand zum
entwickeln sein. Sollte dies nicht mehr der Fall sein lässt sich die
virtuelle Maschine mit einem maxmimal zwei Befehlen wieder in den
Ursprungszustand zurücksetzen.
Als Hypervisor der virtuellen Maschine wurde
Virtualbox\footcite{virtualbox} eingesetzt. Virtualbox ist im Kern
freie Software unter der GNU Public License v2. Das unter einer
proprietären Lizenz erhältliche Erweiterungspacket ist für unser Setup
nicht notwendig.
**** Hostsystem
Als Hostsystem für unseren Web-Shop haben wir uns für die Linux
Distribution Debian\footcite{debian} in der Version 9 (Stretch)
entschieden. Für Debian haben wir uns vor allem aus folgenden Gründen
entschieden:
- Stabiles System
- Sehr guter Packetmanager was einem das Scripting vereinfacht.
- Gilt als sehr sicher
- Hat sich in vorhergehenden Projekten bereits als gute Basis bewiesen
- Enthält in der Grundkonfiguration nur freie Software (nicht freie
Software muss aktiv hinzugefügt werden)
- In der Linux Welt sehr verbreitet
- Im Gegensatz zu Ubuntu nicht von einer Firma abhängig
**** Deployment Software für Produktionsserver
Auch auf dem produktiven Server haben wir uns für Debian entschieden.
Um diesen aufzusetzen hatten wir in etwa die ähnlichen Anforderungen
wie für die Entwicklungsumgebung. Also einen Weg um das System
möglichst automatisch und reproduzierbar aufzusetzen. Die für die
Entwicklungsumgebung verwendete Software Vagrant ist für produktive
System allerdings eher weniger geeignet.
Für solche Fälle bietet sich eine Software Namens
"Ansible"\footcite{ansible} an. Diese bietet einem ähnlich wie Vagrant
die Möglichkeit den Zustand eines Systems in Text Dateien zu
beschreiben. Allerdings bietet einem Ansible noch zusätzliche
Möglichkeiten und bietet einem ein standardisiertes Interface um
unterschiedliche Systeme auf die selbe Weise zu konfigurieren.
Der Vorteil gegenüber anderen System ist vorallem das Ansible mit sehr
wenig Abhängigkeiten für das zu konfigurierende System daherkommt. Auf
einem Linux System ist nur SSH Zugriff und Python notwendig. Einen
Client braucht man nicht zu installieren.
Ansible ist freie Software unter der GNU Public License v3.
**** Framework
Um die Entwicklung der Applikation zu vereinfachen haben wir uns dazu
entschlossen ein Framework einzusetzen. Frameworks bringen einem in
der Entwicklung diverse Vorteile. Unter anderem bieten sie Hilfen bei
sich wiederholenden Programmieraufgaben und bieten je nachdem die
Möglichkeit die Applikation in einer einzigen Sprache zu schreiben da
sich das Framework auch um die Datenbank kümmert. In der
Webentwicklung helfen sie einem insbesondere auch dabei
Sicherheitslücken wie Cross Site Scripting und SQL Injections
abzufangen.
Wir haben uns dabei für das Framework Django\footcite{django}
entschieden. Django ist ein Python basiertest Framework. Django ist
freie Software unter der drei Klausen BSD Lizenz. Wir haben uns aus
folgenden Gründen für ein Python basiertes Framework gegenüber einem
PHP basierten Framework entschieden:
- Python gilt als die Sprache mit der schöneren Syntax
- Wir wollten im Bezug auf das Programmieren etwas neues ausprobieren
was sich im Rahmen einer Case Study sehr gut machen lässt. Da man
ein "realistisches" Szenarium erhält und dieses in einem relativ
kontrollierten Rahmen ausführen kann.
- Python ist in dem von uns gewählten Hostsystem wie in den meisten
Linux Distributionen bereits integriert.
Die verwendete Version war dabei 1.10.7-2 aus dem Debian Stretch Repository.
2018-01-05 15:04:33 +01:00
**** Webserver
Als Webserver verwenden wir ganz klassisch Apache\footcite{apache}.
Dies vorallem aus dem Grund das wir Apache aus diversen vorhergehenden
Projekten bereits sehr gut kennen und sich der Webserver dort sehr gut
bewährt hat. Apache wird dabei auch noch gut von Django unterstützt.
Der Apache Webserver ist freie Software unter der Apache License 2.0
und gehört der gemeinnützigen Organisation "Apache Foundation".
**** Datenbank
Bei der Datenbank haben wir uns für MariaDB\footcite{mariadb}
entschieden. Auch hier hauptsächlich weil wir MariaDB bereits aus
vorhergehenden Projekt kennen. MariaDB ist ein Fork von MySQL welcher
gegenüber MySQL rückwärtskompatibel ist. MariaDB ist dabei jedoch viel
Community näher als MySQL und wird dabei auch sehr demokratisch
entwickelt\footcite{mariadbgov}. MariaDB gehört dabei keiner einzelnen
Firma oder Person sonder der gemeinnützigen Organisation "MariaDB
Foundation". Was für zusätzliche Stabilität sorgen sollte.
MariaDB ist freie Software unter GNU Public License v2.
**** Editoren
Das Hauptwerkzeug von jedem Entwickler ist sein Text Editor. Dabei
hat jeder meistens seine ganz eigene Präferenzen wenn es um die Wahl
des Editors geht.
2018-01-06 15:02:30 +01:00
- Atom :: Ivan hat während der Case Study hauptsächlich mit
Atom\footcite{atom} gearbeitet. Atom wird von Github Inc.
entwickelt und basiert auf dem Electron Framework welches
seinerseit auf Webtechnologien wie Node.js und Chromium
basiert. Atom ist freie Software unter der MIT Lizenz.
- GNU Emacs :: Andreas arbeitet hauptsächlich mit dem Editor GNU
Emacs\footcite{emacs}. GNU Emacs ist mit 32 Jahren
(obwohl seine Wurzeln bis ins Jahre 1976 zurückgehen)
wohl eines der ältesten noch "aktiven" Software
Projekte. Emacs ist freie Software unter der GNU Public
License v3.
2018-01-05 15:04:33 +01:00
**** Dokumentation
Diese Dokumentation wurde in Org-mode\footcite{orgmode} einer
Erweiterung für den Text Editor Emacs geschrieben. Anschliessend wurde
die Dokumentation in LaTeX\footcite{latex} Code konvertiert und
finalisiert. Der Zwischenschritt über Org-mode wurde gewählt weil
Org-mode etwas einfacher zu schreiben ist als reines LaTeX.
LaTeX ist eine Software welche einem die Benutzung des Textsatzsystems
TeXs vereinfacht. Wir haben LaTeX gegenüber einem "What You See Is
What You Get" Editor gewählt weil es einem mit seiner Markup Sprache
erlaubt das Dokument in Text Dateien zu erstellen. Was wir als
Programmierer sehr angenehm finden. Dadurch das LaTeX auch nur aus
reinen Textdateien besteht kann man die Dokumente auch ohne weiteres
in die Versionskontrollsoftware einchecken und somit auf einfache
Weise zusammen daran arbeiten und die Entwicklung im Log
zurückverfolgen kann.
2018-01-06 15:02:39 +01:00
LaTeX ist freie Software unter der LaTeX Project Public License.
2018-01-05 15:04:33 +01:00
Die Grafiken in diesem Dokument wurden hauptächlich mit dem Vektor
Grafik Editor Inkscape\footcite{inkscape} erstellt. Inkscape ist freie
Software unter der GNU Public License v3.
Die Klassen Diagramme haben wir mit der Django Erweiterung
"Django-Extensions"\footcite{django_extensions} erstellt.
Django-Extensions ist freie Software unter der MIT Lizenz.
2017-10-31 20:31:01 +01:00
*** Methoden
2017-10-31 21:22:50 +01:00
2017-10-31 22:11:09 +01:00
Die Methodik die die Gruppe wählt ist Aufgrund der nur zwei Personen
2017-10-31 20:31:01 +01:00
im Team beschränkt. Da jedoch Fehler und Rückschläge erwartet werden
2017-10-31 22:11:09 +01:00
ist eine itterative Methodik unabdingbar. Daher wandte die Gruppe eine
angepasste version von Scrum an. In dieser wird jeweils während
2017-10-31 20:31:01 +01:00
Sitzungen die Position des Product Owners und des Scrum Masters
2017-10-31 22:11:09 +01:00
eingenommen und die Backlog-Tasks dementsprechend erstellt resp.
2017-10-31 20:31:01 +01:00
verteilt. Während der Woche arbeiten beide Team-Mitglieder an der
Arbeit als Team-Kolegen.
*** Vorkenntnisse
2017-10-31 21:22:50 +01:00
2017-10-31 20:31:01 +01:00
Die benötigten Vorkenntnisse wurden in den vorangeganenen Semestern
2017-10-31 22:11:09 +01:00
erarbeitet und sind in der Basis gefestigt. Diese Arbeit wird
vorwiegend weiterführende Elemente wie Frameworks neu einbringen deren
Verhalten letztendlich nicht abgeschätzt werden kann.
2017-10-31 20:31:01 +01:00
2017-10-30 22:17:17 +01:00
** Vision
2017-10-31 21:22:50 +01:00
2017-10-31 22:11:09 +01:00
Wir wollen einen Web-Shop mit geeigneter Software erstellen. Dabei
setzen wir nur freie Software ein (frei im Bezug auf Freiheit nicht
Preis). Wir untersuchen die Anforderung und wählen die uns als
geeignet erscheinenden Frameworks. Jede noch so kleine Zeiteinsparung
durch vorgefertigte Entwicklungen werden angenommen und dennoch wollen
wir keine fertigen Software Produkte einsetzen.
2017-10-31 20:31:01 +01:00
2017-10-31 22:11:09 +01:00
** TODO SWOT-Analyse
2017-10-31 21:22:50 +01:00
2017-10-31 20:31:01 +01:00
Die SWOT-Analyse ist eine Methode, die Stärken, Schwächen, Chancen und
Gefahren zu erkennen, indem eine 4-Felder-Matrix ausgefüllt wird.
Wichtig vor dem Ausfüllen der SWOT-Analyse ist es, ein klares Ziel zu
2018-01-05 15:04:33 +01:00
haben. Die ausegfüllte SWOT-Analyse für dieses Projekt ist in der
Tabelle: ([[tab:swot]]) zu sehen.
2017-10-31 22:11:09 +01:00
#+CAPTION: SWOT-Analyse
2018-01-05 15:04:33 +01:00
#+ATTR_LATEX: :align |p{.22\textwidth}|p{.22\textwidth}|p{.22\textwidth}|p{.22\textwidth}|
#+NAME: tab:swot
2018-01-06 15:01:17 +01:00
|----------------------+----------------------+----------------------+----------------------|
2018-01-07 23:46:40 +01:00
| *Stärken*\cellcolor[HTML]{C0C0C0} | *Schwächen*\cellcolor[HTML]{C0C0C0} | *Chancen*\cellcolor[HTML]{C0C0C0} | *Gefahren*\cellcolor[HTML]{C0C0C0} |
2018-01-06 15:01:17 +01:00
| <20> | <20> | <20> | <20> |
|----------------------+----------------------+----------------------+----------------------|
| Wir als Programmierer haben ein gutes Know-How im Bereich Datenbanken | Wir als Programmierer haben keine Erfahrung im Konsumsegment unseres Nutzers | | |
|----------------------+----------------------+----------------------+----------------------|
| Die Umsetzung der graphischen Anwendungsoberfläche könnte sich als schwierig erweisen. | Die Umsetzungszeit ist knapp bemessen | | |
|----------------------+----------------------+----------------------+----------------------|
2017-10-31 20:31:01 +01:00
2017-10-30 22:17:17 +01:00
** Umweltanalyse
2017-10-31 21:22:50 +01:00
2017-10-31 20:31:01 +01:00
Die Projektumwelt-Analyse ist eine Methode, die Beziehungen,
Erwartungshaltungen und Einflüsse auf das Projekt durch interne und
externe soziale Umwelten zu betrachten und zu bewerten. Auf Grundlage
2017-10-31 22:11:09 +01:00
der Analyseergebnisse werden erforderliche Massnahmen zur Gestaltung
der Umweltbeziehungen abgeleitet. Die Gestaltung der
2018-01-05 15:04:33 +01:00
Projektumweltbeziehungen ist eine Projektmanagementaufgabe. In dieser
Tabelle: ([[tab:umweltanalyse]]) wurden die Anforderungen und Wünsche
mit Einschätzung der Wahrscheinlichkeit der Einflussnahme aufgenommen.
Zusätzlich ist die Beziehung der Stakeholder zum Projekt noch in der
Abbildung: ([[fig:umweltgrafik]]) grafisch dargestellt.
2017-10-31 20:31:01 +01:00
2018-01-07 23:46:40 +01:00
#+LATEX:\newpage
#+LATEX:\begin{landscape}
2018-01-05 15:04:33 +01:00
#+CAPTION: Umwelt-Analyse
#+ATTR_LATEX: :align |>{\columncolor[HTML]{EFEFEF}}p{0.8cm}|l|l|p{8cm}|l|
#+NAME: tab:umweltanalyse
2018-01-07 23:46:40 +01:00
|-------+----------------------+----------------------+-----------------------------------------------+---------------------------------------------|
| <5> | <20> | <20> | | |
| *Nr*.\cellcolor[HTML]{C0C0C0} | *Stakeholder*\cellcolor[HTML]{C0C0C0} | *Einfluss*\cellcolor[HTML]{C0C0C0} | *Anforderung/Wünsche*\cellcolor[HTML]{C0C0C0} | *Warscheinlichkeit*\cellcolor[HTML]{C0C0C0} |
|-------+----------------------+----------------------+-----------------------------------------------+---------------------------------------------|
| 1. | Auftraggeber | hoch | - Innovatives Produkt auf dem Markt anbieten. | hoch |
| | | | - Einhaltung von Terminen und Qualität. | hoch |
|-------+----------------------+----------------------+-----------------------------------------------+---------------------------------------------|
| 2. | Kunden | gering | - Einfache Lösung die anpassungsfähig ist. | hoch |
| | | | - Schnell anfangen können. | hoch |
| | | | - Viele Arbeitsschritte Automatisieren | mittel |
|-------+----------------------+----------------------+-----------------------------------------------+---------------------------------------------|
| 3. | Interessenten | gering | - Intuitiv bedienbare Webseite | hoch |
| | | | - schnell finden was gesucht wird. | hoch |
|-------+----------------------+----------------------+-----------------------------------------------+---------------------------------------------|
| 4. | Projektleiter | hoch | - Gutes Innovatives Produkt erschaffen. | mittel |
| | | | - Anerkennung im fachlichen Umfeld | hoch |
|-------+----------------------+----------------------+-----------------------------------------------+---------------------------------------------|
#+LATEX:\end{landscape}
2017-10-31 21:22:50 +01:00
2017-12-03 22:33:06 +01:00
#+CAPTION: Stakeholder Diagramm
#+ATTR_LATEX: :width .9\textwidth
2018-01-05 15:04:33 +01:00
#+NAME: fig:umweltgrafik
2017-12-03 22:33:06 +01:00
[[file:diagrammes/stakeholder_diagramm.eps]]
2017-10-31 22:11:09 +01:00
** TODO Risikomanagement
2018-01-05 15:04:33 +01:00
*** NEXT Risikobeschreibung
2017-10-31 21:22:50 +01:00
2018-01-05 15:04:33 +01:00
#+CAPTION: Risikobeschreibung
#+ATTR_LATEX: :align |>{\columncolor[HTML]{EFEFEF}}p{0.8cm}|p{5cm}|p{5cm}|p{0.8cm}|p{0.8cm}|
#+NAME: tab:risikobeschreibung
2018-01-07 23:46:40 +01:00
|------------+--------------------------------+--------------------------------+-------------------------------+-------------------------------|
| <10> | <30> | <30> | | |
| *Nr.*\cellcolor[HTML]{C0C0C0} | *Beschreibung*\cellcolor[HTML]{C0C0C0} | *Massnahmen*\cellcolor[HTML]{C0C0C0} | *W^1*\cellcolor[HTML]{C0C0C0} | *A^2*\cellcolor[HTML]{C0C0C0} |
|------------+--------------------------------+--------------------------------+-------------------------------+-------------------------------|
| 1. | Die Datenbank ist schlecht modeliert. | Das ERM nach dessen Erstellung gründlich auf Fehler prüfen, falls nötig extern prüfen lassen. | 2 | 3 |
|------------+--------------------------------+--------------------------------+-------------------------------+-------------------------------|
| 2. | Viel Arbeit an der Arbeitsstelle, dabei bleibt weniger Zeit für die Casestudy. | Die Zeit die einem zur Verfügung steht nutzen und fixe Tage definieren. Projektplanung machen. | 1 | 2 |
|------------+--------------------------------+--------------------------------+-------------------------------+-------------------------------|
| 3. | Know-How zur Umsetzung ist nicht vollständig vorhanden. | Gute Informationsbeschaffung im Internet, Mitschülern, Arbeitgeber, Dozenten etc. | 2 | 2 |
|------------+--------------------------------+--------------------------------+-------------------------------+-------------------------------|
| 4. | Kommunikation innerhalb des Teams. | Klare Arbeitsaufteilung innerhalb des Teams und alle 2 Wochen Besprechungen über offene Aufgaben oder Problembehandlungen | 1 | 1 |
|------------+--------------------------------+--------------------------------+-------------------------------+-------------------------------|
| 5. | Die Programmierung des Shops benötigt zuviel Zeit | Beider Projektplanung genau definieren was die GUI Applikation beinhalten muss. Ziele definieren, abgrenzungen treffen. | 3 | 1 |
|------------+--------------------------------+--------------------------------+-------------------------------+-------------------------------|
2017-10-31 21:22:50 +01:00
2018-01-05 15:04:33 +01:00
*** NEXT Risikobewertung
2017-10-31 21:22:50 +01:00
2018-01-05 15:04:33 +01:00
#+CAPTION: Risikobewertung Wahrscheinlichkeit
2018-01-16 22:30:51 +01:00
#+ATTR_LATEX: :align l|l :placement [H]
2018-01-05 15:04:33 +01:00
#+NAME: tab:wahrscheinlichkeit
2018-01-07 23:46:40 +01:00
| *Bewertung* | *Beschreibung: Warscheinlichkeit (W)* |
|-------------+---------------------------------------|
| 1 = gering | Unwarscheinlich, <20% |
| 2 = mittel | Mässig warscheinlich, 20-50% |
| 3 = hoch | Hohe warscheinlichkeit > 50% |
2017-10-31 20:31:01 +01:00
2018-01-05 15:04:33 +01:00
#+CAPTION: Risikobewertung Auswirkung
2018-01-16 22:30:51 +01:00
#+ATTR_LATEX: :align l|l :placement [H]
2018-01-05 15:04:33 +01:00
#+NAME: tab:auswirkung
2018-01-07 23:46:40 +01:00
| *Bewertung* | *Beschreibung: Auswirkung (A)* |
|-------------+-------------------------------------------------|
| 1 = gering | geringe auswirkungen auf das Gesammtergebniss |
| 2 = mittel | Arbeitsumstellung oder grösserer Arbeitsaufwand |
| 3 = hoch | Projekt erfüllt nicht alle Anforderungen |
2017-10-31 20:31:01 +01:00
2018-01-05 15:04:33 +01:00
#+CAPTION: Grafische Darstellung der Risikoanalyse
2018-01-16 22:30:51 +01:00
#+ATTR_LATEX: :width 9cm :placement [H]
2018-01-05 15:04:33 +01:00
#+NAME: fig:risk
[[file:diagrammes/risk_analysis.eps]]
2017-10-31 21:22:50 +01:00
2017-10-31 20:31:01 +01:00
** TODO Projektabgrenzung
2017-10-31 21:22:50 +01:00
2017-10-31 20:31:01 +01:00
Am ende des Projekts die nicht lauffähigen teile ausgrenzen. :-)
2017-10-30 22:17:17 +01:00
* Projektmanagement
** Organigram
** Projektstrukturplan
** Varianten erarbeiten
** Architektur vorbereiten
** Arbeitspakete definieren
2017-10-31 21:22:50 +01:00
2018-01-05 15:04:33 +01:00
* TODO Umsetzung
** TODO Spezifikation
2018-01-06 15:03:18 +01:00
*** User Stories
2018-01-05 15:04:33 +01:00
User Stories sind eine in Alltagssprache geschriebenen
Software-Anforderungen. Sie sind bewusst kurzgehalten und beschreiben
die Wünsche und Ziele der Rollen welche die Software verwenden.
2018-01-06 15:03:18 +01:00
**** Auftraggeber/Verwaltung
2018-01-05 15:04:33 +01:00
2018-01-06 15:02:55 +01:00
Als Anbieter möchte ich...
- Artikel in Kategorien strukturieren damit Kunden sich orientieren können.
- Bilder zu meinen Artikeln hinzufügen damit sich Kunden das Produkt
anschauen können.
- Artikel aktiv oder versteckt schalten können damit ich Produkte auch
temporär aus dem Verkauf nehmen kann.
- Lagerbestände verwalten können damit ich rechzeitig nachbestellen kann.
- Nachbestellungen von Artikeln erfassen können damit ich weiss was
bestellt wurde.
- eine komplette Liste meiner Artikel einsehen können damit ich einen
Überblick über meine Produkte habe.
- eine Liste aller Bestellungen einsehen können um allenfalls
Anpassungen vornehmen zu können.
- Produkte und Kategorien in einer Admin Seite editieren können um
diese einfach administrieren zu können.
2018-01-06 15:03:18 +01:00
**** Kunde
2018-01-05 15:04:33 +01:00
2018-01-06 15:02:55 +01:00
Als Kunde möchte ich...
- durch Kategorien zu den Produkten navigieren um diese einfacher zu finden.
- Artikel einem Warenkorb hinzufügen können damit ich ungestört
stöbern kann und erst am Schluss den administrativen Teil erledigen muss.
- meinen Warenkorb anzeigen und editieren können um allenfalls
Korrekturen vornehmen zu können.
- die Artikel in meinem Warenkorb bestellen können.
- vor dem Abschluss des Kaufs eine Zusammenstellung der Bestellung
einsehen um die Richtigkeit der Daten zu überprüfen.
- mich registrieren können damit ich meine Adresse nicht jedes Mal neu
eingeben muss.
- in einem Bereich der Webseite meine Profildaten zur Überprüfung
einsehen können.
- Artikel in meiner bevorzugten Währung kaufen können damit ich die
Preise nicht umrechnen muss.
2018-01-06 15:03:18 +01:00
**** Interessenten
2018-01-05 15:04:33 +01:00
2018-01-06 15:02:55 +01:00
Als Interessent möchte ich...
- die angebotenen Artikel einsehen können um mir ein Bild über das
Angebot machen zu können.
- die Preise in einer anderen Währung anzeigen können um die
Preise in einer mir bekannten Währung vergleichen zu können.
2018-01-18 20:11:56 +01:00
*** Use Cases
2018-01-05 15:04:33 +01:00
Ein Use Case sammelt alle möglichen Szenarien, die eintreten können,
wenn ein Akteur versucht, mit Hilfe des betrachteten Systems ein
bestimmtes Ziel zu erreichen. Dabei beschreibt er was beim Versuch der
Zielerreichung passieren kann. Je nach Ablauf kann auch ein Fehlschlag
ein Ergebnis eines Anwendungsfalls sein (e.g. falsches Pass- wort beim
Login). Dabei wird die technische Lösung nicht konkret beschrieben.
Die Detailstufe kann dabei sehr unterschiedlich sein.\footcite{usecase}
2018-01-13 11:06:25 +01:00
**** Anwendungsfalliagramm
2018-01-05 15:04:33 +01:00
"Ein Anwendungsfalldiagramm ... ist eine der 14 Diagrammarten der
Unified Modeling Language (UML), einer Sprache für die Modellierung
der Strukturen und des Verhaltens von Software- und anderen Systemen.
Es stellt Anwendungsfälle und Akteure mit ihren jeweiligen
Abhängigkeiten und Beziehungen dar."\footcite{usecasediagramm}
2018-01-07 18:52:40 +01:00
Das Anwendungsfalldiagramm für unseren Webshop ist in der Abbildung:
([[fig:usecase]]) zu sehen. Wir haben uns dabei auf die Hauptaspekte des
Webshops beschränkt.
#+LATEX:\newpage
#+LATEX:\begin{landscape}
2018-01-07 11:01:25 +01:00
#+CAPTION: Anwendungsfalldiagramm
2018-01-07 18:52:40 +01:00
#+ATTR_LATEX: :height.9\textwidth
2018-01-07 11:01:25 +01:00
#+NAME: fig:usecase
2018-01-07 18:52:40 +01:00
[[file:diagrammes/use_case.eps]]
#+LATEX:\end{landscape}
#+LATEX:\newpage
2018-01-07 11:01:25 +01:00
2018-01-18 20:11:56 +01:00
**** Use Case Detailbeschreibung
2018-01-05 15:04:33 +01:00
Use Cases werden in der Regel mit Hilfe einer sogenannten Use Case
Schablone im Detail beschrieben damit klar ist wie der Ablauf jeweils
genau aussieht. Die von uns verwendete Schablone wurde von Alistair
Cockburn definiert.
Da ein Web-Shop eine sehr umfangreiche Applikation ist gibt es sehr
viele Use Cases welche beschrieben und umgesetzt werden müssen. Aus
zeitlichen Gründen haben wir nur einen kleinen Teil der Use Cases im
Detail ausgearbeitet. Insbesondere diese welche wir selber
ausprogrammiert haben. Die gesamte Liste an Use Cases sieht wie folgt
aus, die Use Cases mit den Nummern wurden dabei im Detail ausgearbeitet:
#+LATEX: {\footnotesize
| - [[*Artikel durchst%C3%B6bern][1.0 Artikel durchstöbern]] | - Kategorie erfassen (Admin Funktion) |
| - [[Registration][2.0 Registration]] | - Kategorie ändern (Admin Funktion) |
| - [[User Login][2.1 User Login]] | - Kategorie löschen (Admin Funktion) |
| - User Profil ansehen | - Bild hochladen (Admin Funktion) |
| - [[Artikel in Warenkorb legen][3.0 Artikel in Warenkorb legen]] | - Bild ändern (Admin Funktion) |
| - [[W%C3%A4hrung %C3%A4ndern][3.1 Währung ändern]] | - Bild löschen (Admin Funktion) |
| - Währung aktualisieren (Admin Funktion) | - Bestellung erfassen (Admin Funktion) |
| - [[Checkout][3.2 Checkout]] | - [[Bestellung %C3%A4ndern/korrigieren][7.0 Bestellung ändern/korrigieren (Admin Funktion)]] |
| - [[User Passwort %C3%A4ndern][4.0 User Passwort ändern (Admin Funktion)]] | - Bestellung löschen (Admin Funktion) |
| - [[Artikel erfassen][5.0 Artikel erfassen (Admin Funktion)]] | - [[max_pictures Option anpassen][6.0 max_pictures Option anpassen (Admin Funktion)]] |
| - Artikel ändern (Admin Funktion) | - max_pictures Option deaktivieren (Admin Funktion) |
| - Artikel löschen (Admin Funktion) | - User erfassen (Admin Funktion) |
| - Materialbestellung erfassen (Admin Funktion) | - User/Personen Daten ändern (Admin Funktion) |
| - Materialbestellung ändern/korrigieren (Admin Funktion) | - User löschen (Admin Funktion) |
| - Materialbestellung löschen (Admin Funktion) | - User Berechtigungen anpassen (Admin Funktion) |
| - Stadt hinzufügen (Admin Funktion) | |
| - Stadt ändern (Admin Funktion) | |
| - Stadt löschen (Admin Funktion) | |
#+LATEX:}
2018-01-17 22:07:17 +01:00
***** Artikel durchstöbern
#+LATEX:{\footnotesize
2018-01-17 22:07:17 +01:00
#+CAPTION: Use 1.0 Artikel durchstöbern
#+ATTR_LATEX::environment longtable :align |>{\columncolor[HTML]{EFEFEF}}p{.25\textwidth}|p{.7\textwidth}| :placement [H]
2018-01-17 22:07:17 +01:00
#+NAME: tab:browse_article
|---------------------+--------------------------------|
| | <30> |
| *Identifier + Name* | 1.0 Artikel durchstöbern |
|---------------------+--------------------------------|
| *Description* | Durchklicken der verschiedenen Kategorieren und ansehen der Artikel Details und Bilder. |
|---------------------+--------------------------------|
| *Actors* | Kunden, Interessenten |
|---------------------+--------------------------------|
| *Status* | Freigegeben |
|---------------------+--------------------------------|
| *Includes* | - |
|---------------------+--------------------------------|
| *Trigger* | User möchte Artikel einsehen |
|---------------------+--------------------------------|
| *Preconditions* | Website aufgerufen |
|---------------------+--------------------------------|
| *Postconditions* | - |
|---------------------+--------------------------------|
| *Normal Flow* | 1. Website aufrufen |
| | 2. Kategorienen durchsehen |
| | 3. Artikel anklicken |
|---------------------+--------------------------------|
| *Alternative Flow* | - |
|---------------------+--------------------------------|
| *Notes* | - |
|---------------------+--------------------------------|
| *UC History* | 1.0 Darft erstellt durch AZ |
|---------------------+--------------------------------|
| *Author* | A. Zweili & I. Hörler |
|---------------------+--------------------------------|
| *Date* | 16.01.2018 |
|---------------------+--------------------------------|
#+LATEX:}
2018-01-17 22:07:17 +01:00
***** Registration
#+LATEX:{\footnotesize
2018-01-17 22:07:17 +01:00
#+CAPTION: Use Case 2.0 Registration
#+ATTR_LATEX: :environment longtable :align |>{\columncolor[HTML]{EFEFEF}}p{.25\textwidth}|p{.7\textwidth}| :placement [H]
2018-01-17 22:07:17 +01:00
#+NAME: tab:registration
|---------------------+--------------------------------|
| | <30> |
| *Identifier + Name* | 2.0 Registration |
|---------------------+--------------------------------|
| *Description* | Ein User registriert sich einen Account. |
|---------------------+--------------------------------|
| *Actors* | Interessent |
|---------------------+--------------------------------|
| *Status* | Freigebgen |
|---------------------+--------------------------------|
| *Includes* | - |
|---------------------+--------------------------------|
| *Trigger* | User möchte einen Account erstellen. |
|---------------------+--------------------------------|
| *Preconditions* | Email Adresse vorhanden |
|---------------------+--------------------------------|
| *Postconditions* | Account wurde erfolgreich erstellt. |
|---------------------+--------------------------------|
| *Normal Flow* | 1. User klickt auf den Link "Go to registration.". |
| | 2. User füllt das Registrations Formular aus. |
| | 3. User schliesst die Registrierung mit Klick auf "Register" ab. |
| | 4. Die Website leitet ihn in den Login Bereich um. |
|---------------------+--------------------------------|
| *Alternative Flow* | 1. User klickt auf den Link "Go to registration.". |
| | 2. User füllt das Registrations Formular mir falschen Daten aus. |
| | 3. Die Website gibt die entsprechenden Fehler aus. |
| | 4. Der User korrigiert die Angaben. |
| | 5. User schliesst die Registrierung mit Klick auf "Register" ab. |
| | 6. Die Website leitet ihn in den Login Bereich um. |
|---------------------+--------------------------------|
| *Notes* | - |
|---------------------+--------------------------------|
| *UC History* | 1.0 Darft erstellt durch AZ |
|---------------------+--------------------------------|
| *Author* | A. Zweili & I. Hörler |
|---------------------+--------------------------------|
| *Date* | 16.01.2018 |
|---------------------+--------------------------------|
#+LATEX:}
2018-01-17 22:07:17 +01:00
***** User Login
#+LATEX:{\footnotesize
2018-01-17 22:07:17 +01:00
#+CAPTION: Use Case 2.1 User Login
#+ATTR_LATEX: :environment longtable :align |>{\columncolor[HTML]{EFEFEF}}p{.25\textwidth}|p{.7\textwidth}| :placement [H]
2018-01-05 15:04:33 +01:00
#+NAME: tab:login
2018-01-17 22:07:17 +01:00
|---------------------+--------------------------------|
| | <30> |
| *Identifier + Name* | 2.1 User Login |
|---------------------+--------------------------------|
| *Description* | Ein Kunde logt sich auf der Website ein. |
|---------------------+--------------------------------|
| *Actors* | Kunde |
|---------------------+--------------------------------|
| *Status* | Freigeben |
|---------------------+--------------------------------|
| *Includes* | - |
|---------------------+--------------------------------|
| *Trigger* | Ein Kunde möchte sich einloggen. |
|---------------------+--------------------------------|
| *Preconditions* | UC 2.0 erfolgreich abgeschlossen. |
|---------------------+--------------------------------|
| *Postconditions* | User hat sich erfolgreich eingeloggt. |
|---------------------+--------------------------------|
| *Normal Flow* | 1. User klickt in der Navigation auf "Login". |
| | 2. User gibt Zugangsdaten ein. |
| | 3. User beendet Login mit Klick auf "Login". |
| | 4. Die Website leitet ihn auf die Index Seite um und zeigt neu eine "Profil" und "Logout" Schaltfläche. |
|---------------------+--------------------------------|
| *Alternative Flow* | 1. User klickt in der Navigation auf "Login". |
| | 2. User gibt falsche Zugangsdaten ein. |
| | 3. User beendet Login mit Klick auf "Login". |
| | 4. Die Website gibt entsprechende Fehlermeldungen aus. |
|---------------------+--------------------------------|
| *Notes* | - |
|---------------------+--------------------------------|
| *UC History* | 1.0 Darft erstellt durch AZ |
|---------------------+--------------------------------|
| *Author* | A. Zweili & I. Hörler |
|---------------------+--------------------------------|
| *Date* | 16.01.2018 |
|---------------------+--------------------------------|
#+LATEX:}
2018-01-17 22:07:17 +01:00
***** Artikel in Warenkorb legen
#+LATEX:{\footnotesize
2018-01-17 22:07:17 +01:00
#+CAPTION: Use Case 3.0 Artikel in Warenkorb legen
#+ATTR_LATEX: :environment longtable :align |>{\columncolor[HTML]{EFEFEF}}p{.25\textwidth}|p{.7\textwidth}| :placement [H]
2018-01-17 22:07:17 +01:00
#+NAME: tab:cart
|---------------------+--------------------------------|
| | <30> |
| *Identifier + Name* | 3.0 Artikel in Warenkorb legen |
|---------------------+--------------------------------|
| *Description* | Ein Kunde legt einen Artikel in den Warenkorb. |
|---------------------+--------------------------------|
| *Actors* | Kunde |
|---------------------+--------------------------------|
| *Status* | Freigeben |
|---------------------+--------------------------------|
| *Includes* | - |
|---------------------+--------------------------------|
| *Trigger* | Ein Kunde möchte einen Artikel kaufen. |
|---------------------+--------------------------------|
| *Preconditions* | UC2.1 erfolgreich abgeschlossen. |
|---------------------+--------------------------------|
| *Postconditions* | Artikel wurde im Warenkorb gespeichert. |
|---------------------+--------------------------------|
| *Normal Flow* | 1. User klickt einen Artikel an. |
| | 2. User klickt auf "Add to cart". |
| | 3. Die Website speichert den Artikel im Warenkorb. |
|---------------------+--------------------------------|
| *Alternative Flow* | 1. User klickt einen Artikel mit Stock "0.0" an. |
| | 2. User klickt auf "Add to cart". |
| | 3. Die Website meldet "We are sorry but this item is out of stock.". |
|---------------------+--------------------------------|
| *Notes* | - |
|---------------------+--------------------------------|
| *UC History* | 1.0 Darft erstellt durch AZ |
|---------------------+--------------------------------|
| *Author* | A. Zweili & I. Hörler |
|---------------------+--------------------------------|
| *Date* | 16.01.2018 |
|---------------------+--------------------------------|
#+LATEX:}
2018-01-17 22:07:17 +01:00
***** Währung ändern
#+LATEX:{\footnotesize
2018-01-17 22:07:17 +01:00
#+CAPTION: Use Case 3.1 Währung ändern
#+ATTR_LATEX: :environment longtable :align |>{\columncolor[HTML]{EFEFEF}}p{.25\textwidth}|p{.7\textwidth}| :placement [H]
2018-01-17 22:07:17 +01:00
#+NAME: tab:currency
|---------------------+--------------------------------|
| | <30> |
| *Identifier + Name* | 3.1 Währung ändern |
|---------------------+--------------------------------|
| *Description* | Ein User ändert die Währung für die Preise. |
|---------------------+--------------------------------|
| *Actors* | Kunde, Interessent |
|---------------------+--------------------------------|
| *Status* | Freigeben |
|---------------------+--------------------------------|
| *Includes* | - |
|---------------------+--------------------------------|
| *Trigger* | Ein User möchte sich die Preise in einer anderen Währung anzeigen lassen. |
|---------------------+--------------------------------|
| *Preconditions* | - |
|---------------------+--------------------------------|
| *Postconditions* | Die Preise werden in der gewünschten Währung angezeigt. |
|---------------------+--------------------------------|
| *Normal Flow* | 1. Der User wählt im Drop-Down die gewünschte Währung aus. |
| | 2. Die Website aktualisiert und zeigt die neu berechneten Preise an. |
|---------------------+--------------------------------|
| *Alternative Flow* | - |
|---------------------+--------------------------------|
| *Notes* | - |
|---------------------+--------------------------------|
| *UC History* | 1.0 Darft erstellt durch AZ |
|---------------------+--------------------------------|
| *Author* | A. Zweili & I. Hörler |
|---------------------+--------------------------------|
| *Date* | 16.01.2018 |
|---------------------+--------------------------------|
#+LATEX:}
2018-01-17 22:07:17 +01:00
***** Checkout
#+LATEX:{\footnotesize
2018-01-17 22:07:17 +01:00
#+CAPTION: Use Case 3.2 Checkout
#+ATTR_LATEX: :environment longtable :align |>{\columncolor[HTML]{EFEFEF}}p{.25\textwidth}|p{.7\textwidth}| :placement [H]
2018-01-17 22:07:17 +01:00
#+NAME: tab:checkout
|---------------------+--------------------------------|
| | <30> |
| *Identifier + Name* | 3.2 Checkout |
|---------------------+--------------------------------|
| *Description* | User gibt seinen Warenkorb als Bestellung auf. |
|---------------------+--------------------------------|
| *Actors* | Kunde |
|---------------------+--------------------------------|
| *Status* | Freigeben |
|---------------------+--------------------------------|
| *Includes* | - |
|---------------------+--------------------------------|
| *Trigger* | Ein Kunde möchte seine Artikel im Warenkorb bestellen. |
|---------------------+--------------------------------|
| *Preconditions* | UC2.1 und UC3.0 erfolgreich abgeschlossen. |
|---------------------+--------------------------------|
| *Postconditions* | Die Bestellung wurde von der Website gespeichert. |
|---------------------+--------------------------------|
| *Normal Flow* | 1. Der User klickt in der Navigation auf "Cart". |
| | 2. Die Website leitet ihn zum Warenkorb um. |
| | 3. Der User klickt dort auf "Checkout". |
| | 4. Die Website gibt ihm eine komplette Übersicht der Bestellung sowie der Empfängeradresse. |
| | 5. User klickt auf "Send order". |
|---------------------+--------------------------------|
| *Alternative Flow* | 1. Der User klickt in der Navigation auf "Cart". |
| | 2. Die Website leitet ihn zum Warenkorb um. |
| | 3. Der User klickt dort auf "Checkout". |
| | 4. Die Website gibt ihm eine komplette Übersicht der Bestellung sowie der Empfängeradresse. |
| | 5. Der User bricht die Bestellung mit Klick auf "Cancel" ab. |
|---------------------+--------------------------------|
| *Notes* | - |
|---------------------+--------------------------------|
| *UC History* | 1.0 Darft erstellt durch AZ |
|---------------------+--------------------------------|
| *Author* | A. Zweili & I. Hörler |
|---------------------+--------------------------------|
| *Date* | 16.01.2018 |
|---------------------+--------------------------------|
#+LATEX:}
2018-01-17 22:07:17 +01:00
***** User Passwort ändern
#+LATEX:{\footnotesize
2018-01-17 22:07:17 +01:00
#+CAPTION: 4.0 User Passwort ändern
#+ATTR_LATEX: :environment longtable :align |>{\columncolor[HTML]{EFEFEF}}p{.25\textwidth}|p{.7\textwidth}| :placement [H]
2018-01-17 22:07:17 +01:00
#+NAME: tab:password
|---------------------+--------------------------------|
| | <30> |
| *Identifier + Name* | 4.0 User Passwort ändern |
|---------------------+--------------------------------|
| *Description* | Ein Administrator ändert ein User Kennwort. |
|---------------------+--------------------------------|
| *Actors* | Verwaltung |
|---------------------+--------------------------------|
| *Status* | Freigeben |
|---------------------+--------------------------------|
| *Includes* | - |
|---------------------+--------------------------------|
| *Trigger* | Ein Administrator möchte ein Passwort zurücksetzen weil es vergessen wurde. |
|---------------------+--------------------------------|
| *Preconditions* | Account mit Administrationsrechten vorhanden. |
|---------------------+--------------------------------|
| *Postconditions* | Auf dem User Account wurde ein neues Passwort gesetzt. |
|---------------------+--------------------------------|
| *Normal Flow* | 1. Der Administrator loggt sich unter https://didgeridoo.ml/admin ein. |
| | 2. Admin klickt auf "Users". |
| | 3. Admin wählt den passenden Account aus. |
| | 4. Klickt unterhalb des Passwort Hashes auf "this form". |
| | 5. Gibt zweimal das neue Passwort ein und klickt "Change password". |
| | 6. Die Website leitet den Admin zurück zu den User Details. |
|---------------------+--------------------------------|
| *Alternative Flow* | 1. Der Administrator loggt sich unter https://didgeridoo.ml/admin ein. |
| | 2. Admin klicht auf "Users". |
| | 3. Admin wählt den passenden Account aus. |
| | 4. Klickt unterhalb des Passwort Hashes auf "this form". |
| | 5. Gibt zweimal ein invalides Passwort ein und klickt "Change password". |
| | 6. Die Website gibt eine entsprechende Fehlermeldung aus. |
| | 7. Der Admin korrigiert die Passwörter und klickt auf "Change password". |
| | 8. Die Website leitet den Admin zurück zu den User Details. |
|---------------------+--------------------------------|
| *Notes* | - |
|---------------------+--------------------------------|
| *UC History* | 1.0 Darft erstellt durch AZ |
|---------------------+--------------------------------|
| *Author* | A. Zweili & I. Hörler |
|---------------------+--------------------------------|
| *Date* | 16.01.2018 |
|---------------------+--------------------------------|
#+LATEX:}
2018-01-17 22:07:17 +01:00
***** Artikel erfassen
#+LATEX:{\footnotesize
2018-01-17 22:07:17 +01:00
#+CAPTION: 5.0 Artikel erfassen
#+ATTR_LATEX: :environment longtable :align |>{\columncolor[HTML]{EFEFEF}}p{.25\textwidth}|p{.7\textwidth}| :placement [H]
2018-01-17 22:07:17 +01:00
#+NAME: tab:create_article
|---------------------+--------------------------------|
| | <30> |
| *Identifier + Name* | 5.0 Artikel erfassen |
|---------------------+--------------------------------|
| *Description* | Ein Administrator erfasst einen neuen Artikel mit Bildern. |
|---------------------+--------------------------------|
| *Actors* | Verwaltung |
|---------------------+--------------------------------|
| *Status* | Freigeben |
|---------------------+--------------------------------|
| *Includes* | - |
|---------------------+--------------------------------|
| *Trigger* | Um das Sortiment zu erweitern möchte der Administrator einen neuen Artikel erfassen. |
|---------------------+--------------------------------|
| *Preconditions* | Account mit Administrationsrechten vorhanden. |
|---------------------+--------------------------------|
| *Postconditions* | Der Artikel wir im Webshop angezeigt. |
|---------------------+--------------------------------|
| *Normal Flow* | 1. Der Administrator loggt sich unter https://didgeridoo.ml/admin ein. |
| | 2. Admin klickt neben "Articles" auf "+ Add". |
| | 3. Admin füllt das Formular aus und lädt ein Bild hoch. |
| | 4. Klickt unten rechts auf "Save". |
| | 5. Die Website speichert den Artikel in der Datenbank. |
|---------------------+--------------------------------|
| *Alternative Flow* | 1. Der Administrator loggt sich unter https://didgeridoo.ml/admin ein. |
| | 2. Admin klickt neben "Articles" auf "+ Add". |
2018-01-18 19:59:07 +01:00
| | 3. Admin füllt das Formular aus und lädt zuviele Bilder hoch. |
2018-01-17 22:07:17 +01:00
| | 4. Klickt unten rechts auf "Save". |
| | 5. Die Website gibt eine entsprechende Fehlermeldung aus. |
2018-01-18 19:59:07 +01:00
| | 6. Der Admin entfernt die überzähligen Bilder. |
2018-01-17 22:07:17 +01:00
| | 7. Die Website speichert den Artikel in der Datenbank. |
|---------------------+--------------------------------|
| *Notes* | - |
|---------------------+--------------------------------|
| *UC History* | 1.0 Darft erstellt durch AZ |
|---------------------+--------------------------------|
| *Author* | A. Zweili & I. Hörler |
|---------------------+--------------------------------|
| *Date* | 16.01.2018 |
|---------------------+--------------------------------|
2018-01-18 19:58:20 +01:00
#+LATEX:}
***** max_pictures Option anpassen
#+LATEX:{\footnotesize
#+CAPTION: Use Case 6.0 max_pictures Option anpassen
#+ATTR_LATEX: :environment longtable :align |>{\columncolor[HTML]{EFEFEF}}p{.25\textwidth}|p{.7\textwidth}| :placement [H]
#+NAME: tab:max_pictures
|---------------------+--------------------------------|
| | <30> |
| *Identifier + Name* | 6.0 max_pictures Option anpassen |
|---------------------+--------------------------------|
| *Description* | Ein Administrator ändert die max_pictures Option. |
|---------------------+--------------------------------|
| *Actors* | Verwaltung |
|---------------------+--------------------------------|
| *Status* | Freigeben |
|---------------------+--------------------------------|
| *Includes* | - |
|---------------------+--------------------------------|
| *Trigger* | Ein Administrator möchte die maximale Anzahl Bilder pro Artikel anpassen. |
|---------------------+--------------------------------|
| *Preconditions* | Account mit Administrationsrechten vorhanden. |
|---------------------+--------------------------------|
| *Postconditions* | Der neue Wert wurde von der Website gespeichert. |
|---------------------+--------------------------------|
| *Normal Flow* | 1. Der Administrator loggt sich unter https://didgeridoo.ml/admin ein. |
| | 2. Admin klickt auf "Options" und anschliessend auf "max_pictures". |
| | 3. Admin ändert den Wert "Value" zu einer Ganzzahl seiner Wahl. |
| | 4. Klickt unten rechts auf "Save". |
| | 5. Die Website speichert den Wert in der Datenbank. |
|---------------------+--------------------------------|
| *Alternative Flow* | 1. Der Administrator loggt sich unter https://didgeridoo.ml/admin ein. |
| | 2. Admin klickt auf "Options" und anschliessend auf "max_pictures". |
| | 3. Admin ändert den Wert "Value" zu einer Gleitzahl seiner Wahl. |
| | 4. Klickt unten rechts auf "Save". |
| | 5. Die Website gibt eine entsprechende Fehlermeldung aus. |
| | 6. Der Admin korrigiert den Wert und klickt "Save". |
| | 7. Die Website speichert den Wert in der Datenbank. |
|---------------------+--------------------------------|
| *Notes* | - |
|---------------------+--------------------------------|
| *UC History* | 1.0 Darft erstellt durch AZ |
|---------------------+--------------------------------|
| *Author* | A. Zweili & I. Hörler |
|---------------------+--------------------------------|
| *Date* | 16.01.2018 |
|---------------------+--------------------------------|
#+LATEX:}
***** Bestellung ändern/korrigieren
#+LATEX:{\footnotesize
#+CAPTION: Use Case 7.0 Bestellung ändern/korrigieren
#+ATTR_LATEX: :environment longtable :align |>{\columncolor[HTML]{EFEFEF}}p{.25\textwidth}|p{.7\textwidth}| :placement [H]
#+NAME: tab:change_order
|---------------------+--------------------------------|
| | <30> |
| *Identifier + Name* | 7.0 Bestellung ändern/korrigieren |
|---------------------+--------------------------------|
| *Description* | Ein Administrator korrigiert eine Bestellung. |
|---------------------+--------------------------------|
| *Actors* | Verwaltung |
|---------------------+--------------------------------|
| *Status* | Freigeben |
|---------------------+--------------------------------|
| *Includes* | - |
|---------------------+--------------------------------|
| *Trigger* | Administrator ändert auf Wunsch eines Kunden eine Bestellung. |
|---------------------+--------------------------------|
| *Preconditions* | Account mit Administrationsrechten vorhanden. |
|---------------------+--------------------------------|
| *Postconditions* | Die Bestellung hat eine angepasste Artikel Menge. |
|---------------------+--------------------------------|
| *Normal Flow* | 1. Der Administrator loggt sich unter https://didgeridoo.ml/admin ein. |
| | 2. Admin klickt auf "Orders" und anschliessend auf die passende Order ID. |
| | 3. Admin ändert den Wert "Amount" des ersten Artikels zu 0. |
| | 4. Klickt unten rechts auf "Save". |
| | 5. Die Website speichert die Bestellung in der Datenbank. |
|---------------------+--------------------------------|
| *Alternative Flow* | - |
|---------------------+--------------------------------|
| *Notes* | - |
|---------------------+--------------------------------|
| *UC History* | 1.0 Darft erstellt durch AZ |
|---------------------+--------------------------------|
| *Author* | A. Zweili & I. Hörler |
|---------------------+--------------------------------|
| *Date* | 16.01.2018 |
|---------------------+--------------------------------|
#+LATEX:}
2018-01-05 15:04:33 +01:00
*** NEXT Mockup
#+CAPTION: Ein frühes Mockup des Shop
#+ATTR_LATEX: :width \textwidth
#+NAME: mockup
[[./pictures/mockup-full-snipet.png]]
2018-01-05 15:04:33 +01:00
2018-01-16 22:31:40 +01:00
*** TODO Models
\footcite{djangoextensions}
2018-01-05 15:04:33 +01:00
**** NEXT Category
\footcite{tree}
2018-01-16 22:30:51 +01:00
#+ATTR_LATEX: :width 9cm :placement [H]
#+CAPTION: Klassenmodel für Kategorien
2018-01-05 15:04:33 +01:00
#+NAME: fig:category
[[./pictures/class_category.png]]
2018-01-05 15:04:33 +01:00
**** NEXT Option
\footcite{readonly}
\footcite{removeadd}
\footcite{removedelete}
2018-01-16 22:30:51 +01:00
#+ATTR_LATEX: :width 9cm :placement [H]
#+CAPTION: Klassenmodel für Optionen
2018-01-05 15:04:33 +01:00
#+NAME: fig:option
[[./pictures/class_option.png]]
2018-01-05 15:04:33 +01:00
**** NEXT ArticleStatus
2018-01-16 22:30:51 +01:00
#+ATTR_LATEX: :width 9cm :placement [H]
#+CAPTION: Klassenmodel für Artikelstatus
2018-01-05 15:04:33 +01:00
#+NAME: fig:articlestatus
[[./pictures/class_articlestatus.png]]
2018-01-05 15:04:33 +01:00
**** TODO ExchangeRate
\footcite{timezone}
2018-01-16 22:30:51 +01:00
#+ATTR_LATEX: :width 9cm :placement [H]
#+CAPTION: Klassenmodel für Wechselkurse
2018-01-05 15:04:33 +01:00
#+NAME: fig:exchangerate
[[./pictures/class_exchangerate.png]]
2018-01-05 15:04:33 +01:00
**** NEXT Article
2018-01-16 22:30:51 +01:00
#+ATTR_LATEX: :width 9cm :placement [H]
#+CAPTION: Klassenmodel für Artikel
2018-01-05 15:04:33 +01:00
#+NAME: fig:article
[[./pictures/class_article.png]]
2018-01-05 15:04:33 +01:00
**** NEXT OrderStatus
2018-01-16 22:30:51 +01:00
#+ATTR_LATEX: :width 9cm :placement [H]
#+CAPTION: Klassenmodel für Bestellstatus
2018-01-05 15:04:33 +01:00
#+NAME: fig:orderstatus
[[./pictures/class_orderstatus.png]]
2018-01-05 15:04:33 +01:00
**** NEXT OrderOfGoods
2018-01-16 22:30:51 +01:00
#+ATTR_LATEX: :width 9cm :placement [H]
#+CAPTION: Klassenmodel für Warenbestellungen
2018-01-05 15:04:33 +01:00
#+NAME: fig:orderofgoods
[[./pictures/class_orderofgoods.png]]
2018-01-05 15:04:33 +01:00
**** NEXT Picture
\footcite{upload}
\footcite{images}
2018-01-16 22:30:51 +01:00
#+ATTR_LATEX: :width 9cm :placement [H]
#+CAPTION: Klassenmodel für Bilder
2018-01-05 15:04:33 +01:00
#+NAME: fig:picture
[[./pictures/class_picture.png]]
2018-01-05 15:04:33 +01:00
**** NEXT Order
2018-01-16 22:30:51 +01:00
#+ATTR_LATEX: :width 9cm :placement [H]
#+CAPTION: Klassenmodel für Bestellungen
2018-01-05 15:04:33 +01:00
#+NAME: fig:order
[[./pictures/class_order.png]]
2018-01-05 15:04:33 +01:00
**** NEXT ShoppingCart
2018-01-16 22:30:51 +01:00
#+ATTR_LATEX: :width 9cm :placement [H]
#+CAPTION: Klassenmodel für Warenkörbe
2018-01-05 15:04:33 +01:00
#+NAME: fig:shoppingcart
[[./pictures/class_shoppingcart.png]]
2018-01-05 15:04:33 +01:00
**** NEXT City
2018-01-16 22:30:51 +01:00
#+ATTR_LATEX: :width 9cm :placement [H]
#+CAPTION: Klassenmodel für Städte
2018-01-05 15:04:33 +01:00
#+NAME: fig:city
[[./pictures/class_city.png]]
2018-01-05 15:04:33 +01:00
**** NEXT Salutation
2018-01-16 22:30:51 +01:00
#+ATTR_LATEX: :width 9cm :placement [H]
#+CAPTION: Klassenmodel für Anreden
2018-01-05 15:04:33 +01:00
#+NAME: fig:salutation
[[./pictures/class_salutation.png]]
2018-01-05 15:04:33 +01:00
**** NEXT Person
\footcite{usermodel}
2018-01-16 22:30:51 +01:00
#+ATTR_LATEX: :width 9cm :placement [H]
#+CAPTION: Klassenmodel für Personen
2018-01-05 15:04:33 +01:00
#+NAME: fig:person
[[./pictures/class_person.png]]
2017-11-05 11:42:31 +01:00
2017-10-30 22:17:17 +01:00
** Benutzerinterface
*** Mockup skizzieren
*** Frontend Umsetzung
*** Backend Umsetzung
2018-01-05 15:04:33 +01:00
2018-01-16 22:32:26 +01:00
** Testing
*** Fixtures
2018-01-05 15:04:33 +01:00
2018-01-07 23:46:40 +01:00
#+LATEX:\newpage
#+LATEX:\begin{landscape}
2018-01-16 22:32:26 +01:00
*** Testfälle
2018-01-05 15:04:33 +01:00
#+CAPTION: Testfälle
#+ATTR_LATEX: :environment longtable :align |>{\columncolor[HTML]{EFEFEF}}p{1.5cm}|p{2.5cm}|p{2.5cm}|p{2.5cm}|p{2.5cm}|p{2.5cm}|p{2.5cm}|p{2.5cm}| :placement [H]
2018-01-05 15:04:33 +01:00
#+NAME: tab:testcases
2018-01-07 23:46:40 +01:00
|----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------|
| <20> | <20> | <20> | <20> | <20> | <20> | <20> | <20> |
| *Testcase ID*\cellcolor[HTML]{C0C0C0} | *Objective*\cellcolor[HTML]{C0C0C0} | *Precondition*\cellcolor[HTML]{C0C0C0} | *Steps*\cellcolor[HTML]{C0C0C0} | *Testdata*\cellcolor[HTML]{C0C0C0} | *Expected Result*\cellcolor[HTML]{C0C0C0} | *Postcondition*\cellcolor[HTML]{C0C0C0} | *Result*\cellcolor[HTML]{C0C0C0} |
|----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------|
| *TC-01* | | | | | | | |
|----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------|
| *TC-02* | | | | | | | |
|----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------|
| *TC-03* | | | | | | | |
|----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------|
| *TC-04* | | | | | | | |
|----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------|
| *TC-05* | | | | | | | |
|----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------|
| *TC-06* | | | | | | | |
|----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------|
| *TC-07* | | | | | | | |
|----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------|
| *TC-08* | | | | | | | |
|----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------|
| *TC-09* | | | | | | | |
|----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------|
| *TC-10* | | | | | | | |
|----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------|
| *TC-11* | | | | | | | |
|----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------|
| *TC-12* | | | | | | | |
|----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------+----------------------|
#+LATEX:\end{landscape}
#+LATEX:\newpage
2017-10-31 21:22:50 +01:00
2017-10-30 22:17:17 +01:00
* Fazit
** Projektmanagement
** Umsetzung
** Gelerntes
2017-10-29 21:03:20 +01:00
2018-01-03 18:28:09 +01:00
* TODO samples [to be deleted] :noexport:
2017-10-29 21:03:20 +01:00
*** Subsubsection
- List
- List
- List
2017-10-30 22:50:09 +01:00
*** TODO Subsubsection
2017-10-29 21:03:20 +01:00
1. Numbered List
2. Numbered List
3. Numbered List
2017-10-30 22:50:09 +01:00
**** NEXT Subsubsubsection
Diese Section müssten man dann zuerst abschliesen damit die
übergeordnete abgeschlossen werden kann.
2017-10-29 21:03:20 +01:00
*** Table
| Name | Funktion | Beschreibung |
|------+----------+--------------|
| | | |
| | | |
| | | |
*** Code Block
2017-10-30 07:54:24 +01:00
#+CAPTION: Python Code Block
2017-10-29 21:03:20 +01:00
#+BEGIN_SRC python
for var in collection:
while variable = True:
#+END_SRC
2017-10-30 07:54:24 +01:00
#+CAPTION: SQL Code Block
2017-10-29 21:03:20 +01:00
#+BEGIN_SRC sql
create FUNCTION functionname()
RETURNS varchar(100)
AS BEGIN
END
go
#+END_SRC
2017-10-30 22:52:41 +01:00
#+LATEX: \begin{sexylisting}{SQL Code Block}
create FUNCTION functionname()
RETURNS varchar(100)
AS BEGIN
END
go
#+LATEX: \end{sexylisting}