Skip to content

kurtfairfield/course

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

35 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Title Subtitle Author
Documenting and Understanding Software Systems
CRN 2366{2,3,4} - SENG 480A/CSC485A/CSC578B - A01
Neil Ernst

Schedule and Topics - Spring 2017

The following schedule is subject to change, and will change.

Class Topics Other Resources Readings Deadlines
Jan 4 Intro; introductions; Project outlined. What is Software Architecture? text chapter 1
Jan 8 Software arch overview. text chapter 2
Jan 11 Reading Code. chapter 3 text, source code of web crawler
Jan 15 Architecture Stakeholders and Requirements. Team kickoff text chapter 16 M0 due
Jan 18 More on Requirements and Scenarios • Project work
Jan 22 Views on Architecture - Modules text chapter 18 M1 due
Jan 25 Views part 2 - C&C text chapter 4
Jan 29 Architecture and Design text chapter 17
Feb 1 Documenting behavior SEI behavior tech report M2 due
Feb 5 API and Interface documentation. User centric docs. Technical writing skills (30 mins) Interface documentation
Feb 8 Mid-term project status updates assignment 1 due
Feb 12 Reading Break
Feb 15 Reading Week
Feb 19 Group work in class - Omar leads M3 due
Feb 22 Class cancelled - Neil away
Feb 26 Midterm Midterm
Mar 1 Industry lecture - model driven development
Mar 5 Microservice styles. M4 due
Mar 8 (float)
Mar 12 Documenting Ops
Mar 15 Architecture analysis ch 21
Mar 19 Architecture analysis ch 21 M5 due
Mar 22 Industry lecture - agile teams and architecture
Mar 26 Technical debt
Mar 29 (float)
Apr 2 Project presentation
Apr 5 Project presentation M6 and M7 due in repo
Apr 10 No class Grad report due

Syllabus

Software is a long-lived and complex thing. This course is about understanding software in the large. We use the SEI text as a framework for understanding large-scale software systems. Topics include

  • what is architecture? Who are architects?
  • what structures are important to understand?
  • views on software systems
  • software quality attributes
  • architecture analysis and recovery
  • architecture-driven design
  • agile architecture
  • design, architecture, and technical debt

(the official course syllabus is distributed via HEAT (SENG480a link))

Required Text:

SEI Software Architecture in Practice, Len Bass, Paul Clements, Rick Kazman. 3rd Edition. 2013.

Other texts

  • Design It! From Programmer to Software Architect, by Michael Keeling, Pragmatic Programmers 2017.
  • Just Enough Software Architecture, by George Fairbanks, Marshall and Brainerd, 2010.
  • Documenting Software Architectures, by Paul Clements et al., Addison-Wesley, 2011.
  • Designing Software Architecture, A Practical Approach, by Humberto Cervantes and Rick Kazman, Addison-Wesley 2017.
  • Software Systems Architecture: Working with Stakeholders Using Viewpoints and Perspectives, by Nick Rosanski and Eoin Woods, Addison-Wesley, 2011.
  • Applied Software Architecture, Christine Hofmeister, Rod Nord, Dilip Soni, Addison-Wesley, 2000.
  • Essential Software Architecture, by Ian Gorton, Springer, 2011.
  • Software Architecture: Perspectives on an emerging discipline, Mary Shaw and David Garlan, Prentice-Hall, 1996.
  • Architecture of Open-Source Applications, Amy Brown and Greg Wilson, eds. http://aosabook.org

Past versions:

Instructors

  • Neil Ernst, instructor. Office ECS 560, office hours TBD.
  • Omar Elazhary, teaching assistant

Course Overview

After the course, students are able to:

  • begin to reason about and evaluate software design tradeoffs
  • capture software architecture in modern documentation approaches
  • work together in teams, with modern software tools.
  • use a views and beyond approach to capture software architecture.
  • compare and contrast different architectural styles, including product lines, microservices, MVC.
  • explain and recognise technical debt.

Deliverables

The class will use Github and Slack to work on the project. Students will have to register their Github username (either a permanent one or a throwaway) with the instructors. Those with an objection to using Github please contact the instructor for workarounds. All Github activity is private to the class organization. Please see the privacy notice on the Connex site.

Slack will be the primary mechanism used for communication in the class. My rationale (apart from being tools used in practice) is to expose the class as a whole to questions about projects, assignment, and lectures.

University and department policies on professional conduct and integrity are applicable. Feel free to see me in person, or via UVic email, for personal questions.

Overview

There is one assignment, a midterm, and a substantial group project. Grad students have one extra assignment to conduct.

Assignment

Undergrads: One individual assignment worth 25% of final mark. Due dates as below.

  • for one of the projects in the course, pick a quality attribute, create a quality attribute scenario, and document how the project source code realizes this scenario. Provide discussion on how the project can handle changes in this scenario in the future.

Grads: the undergrad assignment, plus

  • a documentation review session on the student document, with report detailing how well the documentation has been completed (e.g., can we answer key stakeholder questions).

Group Project

The primary deliverable is a group project. You and your team will select a software project (OSS on Github), and document important views on the software. The end result will be a set of documentation about the software system and a deep understanding of how it is constructed. 60% of final mark. Students will be assigned to teams and document an open source software system. Due dates in calendar below. See the Project outline.

Midterm

One midterm, worth 15%. Tentatively scheduled for Feb 26.

Final

No final.

Resources

  1. Slack
  2. Github site
  3. Github help pages
  4. Github bootcamp

About

Notes, outlines, etc.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published