Architecture Tactics Assignment
Table of Contents
1 About This Sprint
In this sprint you identify architecture tactics for the most relevant quality attributes for your system.
2 User Stories covered in this Sprint
- As a software architect I want to start my design with a well known structure so that I can be sure that I am addressing my quality requirements in the best way.
3 Learning Material
Please revise the sprints on
4 Experiential Learning
4.1 Assignment: Architecture Tactics
Explore architectural solutions (in terms of architecture tactics) for your quality attribute scenarios.
Tasks:
- For each quality attribute scenario, identify which architectural tactics (from Bass et al.) that might help you achieve the desired response measure.
- Explore how you would design the architecture of your system to make use of the identified tactics.
- Also consider what support you would need on the design level (in terms of classes and interactions between classes).
Document Structure:
The title for this Assignment Document is: Software Architecture and Architecture Tactics for System <system name>
.
The assignment document shall contain the following items:
- Title Page, according to the Title Page Instructions (Link)
System Description
A brief description (2-3 paragraphs) of your interpretation of what the goal of the system is.
- Architecture Tactics
Tactics for Quality Attribute Scenario 1: <quality attribute name>
For each scenario:
- List and describe the tactics that may be relevant.
- Briefly discuss how you would use the tactic (or why you decide not to use this particular tactic).
- Identify key components and classes in your design that are affected by applying your selected tactics.
- Tactics for Quality Attribute Scenario 2: <quality attribute name>
- Tactics for Quality Attribute Scenario 3: <quality attribute name>
- Tactics for Quality Attribute Scenario 4: <quality attribute name>
- Tactics for Quality Attribute Scenario 5: <quality attribute name>
Updated Architecture
Present an updated architecture (with as many views that are necessary) that includes the tactics you decided to use. Try to mark, in your architecture, which entities are involved in each tactic, and the responsibilities the entity have in relation to the tactic.
Commit and push this document to your project repository.
Conditions of Satisfaction:
When marking this part of the assignment we are looking for the following:
- Does the title page contain a table with authors and author contribution?
- Size of assignment: Are two to three tactics explored for each of the five quality attribute scenarios?
- Will the discussed tactics address the challenges in each quality attribute scenario?
- Are the tactics adequately translated into a workable architecture and design for the particular system?
- Does the updated architecture have a reasonable potential to address the quality attribute scenarios?
5 Sprint Acceptance Tests
You are done with this sprint when:
- You have explored architecture tactics that address your quality attribute scenarios.
- You have updated your software architecture according to the tactics.
- You have committed/pushed these documents to your project repository.
You may also have
- Updated your Sprint Test Plan
- Updated your Course Backlog