Häufig bekomme ich die Frage, wie der Bericht zu einem (von mir betreuten) Praxisprojekt (PP) im AI-, MI- oder WI-Bachelor aussehen sollte. Deshalb dazu ein paar Gedanken und Hilfestellungen. Disclaimer: Der nachfolgende Text gibt lediglich meine persönliche Meinung wieder und stellt keine rechtsverbindliche Grundlage einer Bewertung dar.
PP/BA: Wie dokumentiere ich Designentscheidungen für Microservices sinnvoll?
Dokumentation ist in der Regel ein ungeliebtes Thema. Die agile Community hat dieses Thema entformalisiert und pragmatischer gemacht, kämpft aber immer noch mit der richtigen Mischung aus „Der Code ist die Dokumentation“ und „Wir pflegen ein Extra-Architektur-Dokument“. ThoughtWorks hat LightWeight Architecture Decision Record in den Status „Adopt“ seines Technology Radars erhoben. Was heißt das konkret und in der gelebten Praxis? Ziel der Arbeit ist eine umfassende Literatur-, Technologie- und Empiriestudie (Expertenbefragungen). Am Ende sollte ein Vorschlag mit einem oder mehreren sinnvollen Varianten zur Dokumentation stehen. Ein praktischer Anwendungsfall, in dem die gewählte Lösung anhand eines Beispiels (als Prototyp) in einem Produktivsystem umgesetzt wird, sollte die Arbeit abrunden. Als Produktivsystem kann dabei die konsequent und kompromisslos als System von Microservices ausgelegte Lehr- und Lernplattform ArchiLab darstellen.
BA: Kriterienbasierter Ansatz zur Technologiewahl bei der Entwicklung mobiler Web Clients
Bei der Implementierung von Clients ist ein Mobile Client heutzutage in der Regel gesetzt. Allerdings steht man immer vor der Entscheidung, ob es eine native App sein muss, oder ob auch ein Responsive Web Client genügt. Bestimmte Anwendungen funktionieren nur mit nativen Apps, beispielsweise gewisse Zugriffe auf Systemfunktionen. Allerdings handelt man sich unter Umständen einen signifikanten Entwicklungs- und Wartungsaufwand ein. Eine Responsive Web App ist einfacher zu realisieren, bietet aber nicht ganz den gleichen Standard in Punkto User Experience und Funktionsumfang. In dieser Arbeit sollen Technologien und Designpatterns für Mobile Clients verglichen werden, um zu einer möglichst allgemeinen Aussage bezüglich der obigen Problemstellung zu kommen. Idealerweise kann im Sinne einer Methodik ein Satz von „wenn – dann“ Regeln formuliert werden, gepaart mit Technologieempfehlungen.
Interesse an ArchiLab-Projekten (Focus: Microservices)?
Wir machen eine Info-Veranstaltung mit Vorstellung von möglichen Themen im Bereich Microservices und ArchiLab am Fr 2.3. um 14:00 in Raum 1522.
PP/BA: Auswahl eines geeigneten UML-Editors für die Softwaretechnikausbildung an der Hochschule
Für die Module Softwaretechnik 1 und 2 werden die Studierenden an die Unified Modeling Language(UML) herangeführt. Zum jetzigen Zeitpunkt wird von den Studierenden die Open Source Software Modelio für diese Aufgabe verwendet. Erfahrung aus vergangenen Semestern zeigt, dass Modelio nicht alle Anforderungen ausreichend erfüllt. Die Bachelorarbeit befasst sich damit, für ausgewählte Editoren die Erfüllungsgrade der wichtigsten Anforderungen zu überprüfen. Am Ende steht eine Auswahlempfehlung für das beste Tool.
PP/BA/MA: Online-Quiz für Bloom’sche Taxonomiestufen höher als 2
Die Lehr-/Lernplattform ArchiLab versucht, ein umfassendes Angebot für das Erlernen von Softwarearchitektur zu machen. Für die Weiterentwicklung des Selbsttest-/Quizmoduls soll diese Arbeit Möglichkeiten definieren, auch die höheren Taxonomiestufen 3-5 der Revised Bloom’s Taxonomy online zu prüfen. Dies sind „Apply“, „Analyze“ und „Evaluate“. Ein einfaches Abfragen von Wissen genügt hier nicht mehr.
BA: Technologieentscheidung und Proof-of-Concept für einen grafischen Editor am Beispiel des Anlagenvisualisierungsystems UniWare
Die Arbeit untersucht, welche Technologie sich anbietet, um einen grafischen Editor für Anlagemodelle zu realisieren. Es soll entschieden werden, ob eine Eigenentwicklung nötig ist, oder ob Standard-Frameworks verwendet werden können.
BA: Untersuchung der Anbieter(un)abhängigkeit im Umfeld von AWS Lambda und Azure Functions
Die Arbeit untersucht, wodurch sich populäre Serverlessdienste, insbesondere „Lambda“ von AWS und „Functions“ von Microsoft Azure, voneinander unterscheiden. Sie gibt Hinweise, wie die Architektur von vorne herein so zu planen ist, dass man möglichst anbieterunabhängig bleibt.
BA: Continuous Delivery auf einer SaaS-Plattform am Beispiel von Salesforce
Die Arbeit untersucht, wie sich ein Continuous Delivery Prozess auf einer SaaS-Plattform umsetzen lässt, am Beispiel von Salesforce Cloud.
BA: Eine Microservice-Referenzarchitektur für studentische Softwareprojekte in der Hochschullehre
In diesem Praxisprojekt mit Option auf anschließende Bachelorarbeit geht es darum, die Eignung des Architekturstils „MicroServices“ für die Plattform ArchiLab auszuloten. Im Rahmen des Projekts / der Arbeit(en) sollen dann konkrete Regeln, Empfehlungen, Architekturmuster etc. erarbeitet werden. Diese sollen als Architektur-Leitlinie für die weitere Arbeit an ArchiLab dienen.