Skip to content

Latest commit

 

History

History
584 lines (424 loc) · 49.2 KB

README.md

File metadata and controls

584 lines (424 loc) · 49.2 KB

CPSC 310 Software Engineering

UBC CPSC 310 - Software Engineering

September 4, 2018 -> December 4, 2018 (2018T1). These are the official resources for both sections.

Waitlist: See Here

Note: Expect frequent updates to this page as the course progresses.

This is a development-heavy four-credit course. Plan your timetable accordingly. If you are not familiar with TypeScript, please start looking at it now.

About the labs

This is a pair-programming course: If you want to work with someone specific for your project, be sure that both of you register for the SAME lab section. We do not have the ability to move people around between labs; please either monitor the SSC for space in your preferred lab sections, move to another lab with space, or find a partner in the lab you are registered in. Teams must be firm by the time of your lab the week of the add/drop deadline. If you do not have a partner, it is your responsibility to notify the TA in lab that week so you can be paired up. If you do not have a partner at the end of your lab that week, you will not be able to complete the project (40% of your final grade). Finding a partner is your responsibility and is key to your having a great term, please take the time to do this right.

Overview

The world runs on software and CPSC 310 is all about taking the skills and knowledge you learned in CPSC 210 (Software Construction) and extending your abilities to design and build non-trivial software systems. The course will involve a significant challenging project that we will start working on in the first lecture and will continue to evolve until the last week of class; do not underestimate the engineering effort this project will require.

The lecture time slot will be highly interactive and will involve working with your project partner (and sometimes teaming up with other groups as well). Only the first and last lecture slots of the course will be 'traditional' lectures. Tuesday lectures will be activity-driven to reinforce the materials from each week's readings and videos. Thursdays lectures will focus on tying the lecture material to the course project. One important implication of this is that all course material will be fully covered in the videos, readings, and project. You can base your Tuesday attendance on your own assessment of your mastery of the material for that week. For Thursdays, your can decide if you need to come based on how the project is progressing. Your attendance in lecture has no bearing on your participation grade, as long as you submit your weekly reflection (which is submitted online).

Each module will have reading materials and videos posted online; no slides will be posted. In-class material will be designed to support the readings, not replace them, and will not be available electronically. We have chosen to take a reading-based approach for this course instead of a slide-based approach to enable more class time to be available for hands-on activities while still providing a comprehensive reference of the background materials for the course.

Some of the topics we will cover in 310 this term include:

  • Software specifications
  • Agile development
  • High and low-level design (this is the primary course focus)
  • Automated testing
  • Refactoring
  • Information security
  • REST
  • Async development

Course Goals

Our primary goal in this course is to help you learn how to design and build non-trivial modern software systems. This requires deliberate practice and experience. Being able to effectively build real systems depends upon flexibility in domain, abstraction, tools, languages, frameworks, and environments. To this end, the project has been tightly integrated with the course materials and will involve a significant development effort.

The course project embodies an experiential learning environment: we have constrained several aspects to mimic the kinds of reasonable constraints you would likely encounter on a real team. As with real systems, requirements will seem clear at a high level, but will provide broad latitude for how you implement them. Your choices of languages and frameworks have also been fixed. It is expected you will not be familiar with these; being able to quickly learn and adapt to different toolsets is a fundamental skill in modern development. Finally, our use of AutoTest can be considered a form of acceptance testing, which is an industry norm used to validate that software performs as expected.

CPSC 310 will be a challenging course that we have designed to integrate many of the ideas and concepts from your prior courses in order to help you to learn how to apply them to engineering modern software systems.

Contact

Instructors:

TAs:

  • Nicholas Bradley (GTA)
  • Felix Grund (GTA)
  • Xinhong (Sam) Liu (GTA)
  • Christopher Satterfield (GTA)
  • Shuanglin Cao
  • Yi Cheng Ding
  • Harman Gakhal
  • Braxton Hall
  • Cindy Hsu
  • Yehee Kim
  • Catherine Leung
  • Ada Yu Ying Li
  • Brian Neumann
  • Tassilo von Gerlach
  • Zhenpeng Wu
  • Haochen Yu
  • Lucas Zamprogno

TA Office Hours:

Date/Time Location TA
Mon 0900-1000 DLC Table 4 Alice
Mon 1000-1100 DLC Table 4 Cindy
Mon 1100-1200 DLC Table 4 Alice
Mon 1200-1300 DLC Table 4 Cindy
Mon 1400-1500 DLC Table 6 Brian
Mon 1400-1500 DLC Table 6 Tassi
Mon 1500-1600 DLC Table 4 Brian
Mon 1500-1600 DLC Table 4 Ada
Mon 1600-1700 DLC Table 4 Brian
Mon 1600-1700 DLC Table 4 Ada
Tues 1300-1400 DLC Table 3 Harman
Tues 1400-1500 DLC Table 3 Tassi
Wed 1400-1500 DLC Table 6 Henry
Wed 1500-1600 DLC Table 6 Henry
Wed 1600-1700 DLC Table 6 Zhenpeng
Thurs 1500-1600 DLC Table 5 Cindy
Thurs 1500-1600 DLC Table 5 Braxton
Thurs 1600-1700 DLC Table 5 Cindy
Thurs 1600-1700 DLC Table 5 Braxton
Fri 1400-1500 DLC Table 5 Zhenpeng
Fri 1400-1500 DLC Table 5 Susan
Fri 1500-1600 DLC Table 5 Zhenpeng
Fri 1500-1600 DLC Table 5 Lucas
Fri 1500-1600 DLC Table 5 Alice
Fri 1600-1700 DLC Table 5 Lucas
Fri 1600-1700 DLC Table 5 Alice

Piazza

Piazza has been configured for this term. Please see the instructor in person in class if you want to discuss course materials; only TAs will monitor Piazza. Please be mindful of our Derivative Code policy with respect to sharing or using other student's code. It is extremely helpful if your Piazza name corresponds to your name in the SSC in the advent we need to help you with a problem with your project, repositories, or grades.

When posting to Piazza please be sure to include a link to your team's GitHub repository so the TAs can find your group's code in order to help you more effectively. Also, when asking TAs about failing tests in particular, the TAs will often want to see your own test for similar cases (usually this will take several tests) so you can demonstrate to them why you think your code is correct.

Getting help

By far the most effective mechanism for content and exam help is to actually attend and participate in lectures. While the videos are available, the literature strongly shows that skipping class has a strong negative impact on grades, one that watching videos alone cannot compensate for [Edwards & Clinton 2018].

For project / language help, there will be at least 24 hours of labs and 24 hours of TA office hours per week. TA office hours closer to the deadline are likely to be much busier than others (which may not be attended at all); to accommodate this we have scheduled most of the office hours prior to deadlines, but seeking help at other times and in your lab will likely be less busy.

Schedule

This is a high-level overview of what the course will be about. Expect this list to change, although we will commit to freezing the schedule and videos for each upcoming week by the end of the previous Thursday so you will be able to watch the correct videos and complete the survey for that week.

Week Topic & Readings Survey
Week 0: Sept 3 Introduction, Teamwork, Languages, & Async Week 0 Survey - Expired
Week 1: Sept 10 Testing Week 1 Survey - Expired
Week 2: Sept 17 Process & Agile Week 2 Survey - Expired
Week 3: Sept 24 Specifications & User Stories Week 3 Survey - Expired
Week 4: Oct 1 Testability & Assertions Week 4 Survey - Expired
Week 5: Oct 8 High Level design: Week 5 D1 Survey - Oct 8 @ 1900 (Mandatory!) - Expired
Week 6: Oct 15 High-level design: Week 6 - Oct 15 @ 0800 - Expired
Week 7: Oct 22 Midterm (Tuesday in class) & High-level design (Thurs) No survey this week
Week 8: Oct 29 Low-level design D2 Survey - Oct 29 @ 1900 (Mandatory!) - Expired
Week 9: Nov 5 Week 9 Survey - Nov 5 @ 0800
Week 10: Nov 12 InfoSec, IP, & Ethics Week 10 Survey - Nov 12 @ 0800 - Expired
Week 11: Nov 19 REST Week 11 D3 Survey - Nov 19 @ 1900 (Mandatory!) - Expired
Week 12: Nov 26 Construction, Automation, & Refactoring Week 12 Survey - Nov 26 @ 0800
Wed Dec 19 Final exam @ 1530. OSBO A.  

It is expected that you will watch the videos for a week prior to coming to class. This will greatly increase your understanding of what will be happening in lecture and make it much easier for you to participate in any hands-on activities we will be doing. The videos below will be annotated with week indicators (W0, W1, etc.) once we know when each should be watched to prepare for lecture that week.

NOTE: The videos below are ordered conceptually, although course constraints cause us to do many topics out of order (so you can use them in the project, etc.), so make sure you check the full list to make sure you have covered all the videos for a given week.

Course Videos

W0: Course Introduction
W0: Capstone Project Overview

Process

W2: Why Process?
W2: Waterfall
W2: Spiral
W2: Extreme Programming
W2: Test Driven Development
W2: Scrum

Specification

W3: Introduction to Specifications
W3: Requirements Process
W3: Requirements Properties
W3: Requirements Elicitation
W3: Additional Requirements
W3: Validating Requirements

User stories

W3: User Stories
W3: INVEST Guidelines
W3: User Story and INVEST Example
W3: Decomposing User Stories: Part 1
W3: Decomposing User Stories: Part 2
W3: Decomposing User Stories: Part 3
W3: Decomposing User Stories: Part 4
W3: Decomposing User Stories: Part 5

Testing

W1: Why Test?
W1: Terminology
W1: Properties of Tests
W1: Kinds of Tests
W1: Unit and System Properties
W1: Red Green Refactor

Black Box Testing

W1: Equivalence Class Partitioning
W1: Input Partitioning
W1: Output Partitioning
W1: Boundary Value Analysis
W1: Assertions
W1: Assertions Example

White Box Testing

W4: Introduction to Coverage
W4: Line and Statement Coverage
W4: Branch and Path Coverage
W4: Coverage Wrap-Up

Testability

W4: Introduction to Testability
W4: Controllability
W4: Observability
W4: Isolateability: Part 1
W4: Isolateability: Part 2
W4: Automatability
W4: Testability Wrap-Up

High-Level Design

W5: Introduction to Abstraction
W5: Structured Programming
W5: Decomposition
W5: Encapsulation
W5: Information Hiding
W5: Constant Change

Design representations

W5: Technical Representations
W5: Diagrams
W5: Views
W5: Static Vs. Dynamic
W5: Deployment Diagrams
W5: State Machine Diagrams

API Design

W5: Introduction to APIs
W5: High Level API Design
W5: Low Level API Design
W5: API Design Process
W5: API Usability
W5: API Platforms and Summary

Coupling & Cohesion

W6: Coupling: Part 1
W6: Coupling: Part 2
W6: Cohesion: Part 1
W6: Cohesion: Part 2

Design principles

W6: Design Guidance and Symptoms
W6: Single Responsibility Principle
W6: Open/Closed Principle
W6: Liskov Substitution Principle
W6: Interface Segregation Principle
W6: Dependency Inversion Principle

Low-Level Design

W8: Introduction to Low Level Design
W8: Design Patterns Overview
W8: Singleton
W8: Strategy
W8: State
W8: State and Strategy
W9: Facade
W9: Decorator
W9: MVC
W9: MVP
W9: MVC and MVP

Construction

W12: Introduction to Construction
W12: Non-Structural Properties: Readability
W12: Static Analysis and Linters
W12: Automation
W12: Code Smells
W12: Refactoring

REST

W11: REST Development: Part 1
W11: REST Development: Part 2
W11: REST Development: Part 3

Languages & Concurrency

W0: Programming Language Introduction
W0: Introduction to Concurrency and Asynchronous Development: Part 1
W0: Introduction to Concurrency and Asynchronous Development: Part 2
W0: Introduction to Concurrency and Asynchronous Development: Part 3

Information Security

W10: Information Security Introduction
W10: Information Security: Understanding
W10: Information Security: Analysis
W10: Information Security: Mitigation Part 1
W10: Information Security: Mitigation Part 2
W10: Information Security: Validation
W10: Information Security Summary

Ethics

W10: Ethics Introduction
W10: Ethics: Privacy
W10: Ethics Summary

Intellectual Property

W10: Intellectual Property Introduction
W10: Intellectual Property: Trade Secrets
W10: Intellectual Property: Trademarks
W10: Intellectual Property: Copyright
W10: Intellectual Property: Patents
W10: Intellectual Property: Licenses
W10: Intellectual Property Summary

Labs

If you are on the waitlist, please attend any lab that works for you until you are able to get in the course. Lab sections must be finalized by the add/drop date. If you have course conflicts in your schedule that prevent you taking labs with available seats, please talk to the CS advisors; unfortunately the course staff is not able to control who is in the lab or lecture.

Lab Time
L1N Tue 0900-1100
L1M Tue 1530-1730
L1E Tue 1700-1900
L1H Wed 0900-1100
L1B Wed 1100-1300
L1D Wed 1300-1500
L1C Wed 1500-1700
L1G Thu 1030-1230
L1F Thu 1400-1600
L1J Thu 1700-1900
L1K Fri 0900-1100
L1L Fri 1100-1300
L1A Fri 1400-1600

You will not have to specify your team until the week of Sept 15. Both team members will be required to attend each lab. During the week each deliverable is due, lab attendance will be verified by the TAs during the Oral Question process; absence will result in a grade of 0 for the deliverable.

TA Office Hours

There will not be any office hours during the first week of class. Also, these hours are all subject to change, always check back here!

In addition to the 12 hours of labs per week, there are also ~12 hours of TA office hours per week. These have been clustered later in the week, but some are available on each day, to better meet anticipated demands.

Project

The project is an integral part of this course. The project will be difficult and time consuming. Projects will be completed in pairs (everyone must have a partner, and you must work with the same partner for the duration of the term). Your partner needs to be in the same lab section as you. The project will proceed in 5 2-3 week sprints; the requirements for each sprint is detailed in a deliverable document. You should expect the project to take ~6 hours / week / person (13 weeks * 2 people * 6 hours = 156 hours). It is extremely important you not leave project deliverables until the last moment. It is impossible to stress strongly enough how important this is; 36h over three weeks is no problem, but over a weekend is impossible. These time estimates are based on effective effort, if you are multitasking or just randomly trying to cobble something together without a plan or tests, the project may take much longer.

The project will rely heavily on self-learning. The course content is necessarily broad to provide coverage that will be applicable to most software development projects. It is important to remember that the project is a single software project that will utilize only a subset of the in-class material; the lectures will not serve as a tutorial for the project, it is expected that you will have to use your own creativity to reason about the project requirements, design a solution, and build and validate it yourself.

The intent of this project is to give you the opportunity to concretely apply the course concepts on a real system, but with fewer constraints than were possible in CPSC 210. At the same time, the system does have some constraints to simulate a real system specified by real clients. A strong test emphasis reinforces the importance (and difficulty) of building high-quality software in practice.

Engineers use automated test suites to validate that their software is working as expected. We will evaluate your project deliverables similarly using AutoTest. In addition to AutoTest, each team member will be independently asked a small number of questions in the lab to assess their understanding of the solution. While it is reasonable for team members to be more knowledgeable about different parts of the system, it is expected that you will understand your entire solution at a high level and be able to provide specific in-depth insight to some meaningful components of your solution.

See the full project description for complete details about the project, the lab, project grading, and finding partners.

Project Sprint Schedule

Each deliverable has a deadline; we have also added a one week grace period for and final submissions if needed. Full TA support will be given to any group prior to the deadline; during the grace period, priority will be given to struggling teams or groups working on the next deliverable. (D0 is exempt from this schedule and has only one final deadline)

During the grace week, TAs will only help groups with AutoTest scores below 80%. In the three days prior to the final submission date, only groups with less than 50% AutoTest scores will be helped. We encourage all groups to submit by the deadline, the final submission date is really only for those groups who need a little more time for polish. Regardless of your grade, your TAs will always help you during your own lab section; this restriction applies only to Piazza, Office Hours, and labs other than your own.

Also, be aware that waiting until the last minute will greatly degrade AutoTest latency; while you can expect to receive results in < 5 minutes for the majority of the term, this has historically been much slower on the last day:

AutoTest Latency

Note: Even when AutoTest is heavily loaded your requests are queued and processed in turn; the timestamps we use for the deadline comes from the GitHub push event, not when AutoTest is able to process the request or when the commit was made locally.

  • September 17 @ 1800: (Deliverable 0) This will be an individual deliverable and will be graded before the Add/Drop date. You should aim to exceed 70% on this deliverable if you want to succeed at the project.

  • October 1 (Oct 8 @ 1800 final sub): Sprint 1 The first project deliverable will be extremely challenging; it is important that you start working on this early.

  • October 23: Midterm (sample midterms are available through the CSSS)

  • October 22 (Oct 29 @ 1800 final sub): Sprint 2

  • November 12 (Nov 19 @ 1800 final sub): Sprint 3

  • November 19: Project Quality Check. There is nothing to submit for this deliverable. It will be computed on the version of your code as it exists at the Sprint 3 deadline (not the commit associated with the Sprint 3 maximum).

Grading

To pass the course and receive credit you must achieve a passing grade on both the overall project grade and the overall exam grade. Sample exams are available through the CSSS.

The project grade component is weighted as follows:

Project Component Proportion
Deliverable 0 (d0) 20 %
Project Sprint 1 (d1) 20 %
Project Sprint 2 (d2) 20 %
Project Sprint 3 (d3) 15 %
Project Quality Check (d4) 15 %
Participation 10 %

The exam component is weighted as follows:

Exam Component Proportion
Midterm Exam 30 %
Final Exam 70 %

The final grade for the course will be computed as follows:

final grade = (project grade * .5) + (exam grade * .5)

The easiest way to think about this is that the project grade acts as a multiplier on your exam grade. Given the way the project is configured with AutoTest, in past terms we have found the project median to exceed 95%. Any content from the course videos, readings, lectures, and project is examinable.

Participation

Participation marks are given for submitting timely status reports for the lecture component of the class. With the exception of Week 0, these reports MUST be submitted before class and will require watching the videos for that week. These reports are intended to be short; we will use them to tailor the activities during the week based on your comments. Each of the 10 reports is worth 0.5% (totalling 5% of your final grade if you submit all 10). We will not tally this grade until the end of the term so it is your responsibility to make sure you have done these by their deadlines (the forms will be deactivated afterwards) and to keep track of your own participation grade. These surveys will be due at 0800 on Mondays; no extensions can be given.

The three deliverable reports (Week 5, 8, and 11) are not part of your participation report but are instead required for your deliverable submissions (see the grade rubric in the deliverable description for more detail of those). These surveys will be due at 1900 on Mondays; no extensions can be given (this is later to allow you to comment on your finished deliverable as it will be after the 1800 deadline).

Policies

Waitlist

To maximize certainty around getting access to 310 this term, the CS advisors will over-enroll the course by moving as many people as they can from the waitlist into the lecture after the first day of class; only the advisors have the ability to make changes to the class list. At this point, the class composition will be frozen for the rest of the term. There will likely be some natural movement of people leaving the course before the add/drop date, but this will just drop our total size back towards capacity rather than the over-enrolled state we will be in after the first lecture.

Late Submissions

The project late policy is described here.

Accommodation

Lab attendance is mandatory so you have time to meet with your partner. If you must miss a lab, please notify your TA directly If you are sick and unable to write the midterm, please contact Reid as soon as possible -- provide medical documentation. Students who miss the midterm or final exam due to illness should consult the Faculty of Science Policy on missed exams. Students who do not have sufficient standing during the term may not qualify for academic concession if they miss the final. Students who require dispensation based on their unique circumstances should refer to the UBC policy on Academic Concessions. Phones, tablets, calculators, translators, and all other electronic devices are prohibited on desks during exams. They must be turned off and placed in your bag or on the ground. Students who need exam accommodation must make an official request to the Access and Diversity Office.

Derivative Code

Each student is responsible ensuring the code in all of their repositories is their own and is not derived from other students in the class, from past student solutions, or other code resources online. This policy is bidirectional: whether you copied some other code, or your code was copied, the penalties are the same.

All teammates are responsible for all commits made to their repositories and for any sharing of their code with other groups. We carefully examine all commits using automated analyses and the course staff carefully manually examine every case of derivative code and only assess penalties when we are certain that the code derives from, or has been derived within, another repository.

The penalty for using (and/or providing) code to another group is to receive a 0 on the deliverable associated with the violation. Since the project is cumulative, you will also have to reimplement your system to ensure that no future violations take place. All partners are responsible for their team's code and every team member will be assessed the penalty: how you collaborate as a team is your responsibility, we recommend you work closely together so you are aware of the provenance of all of your team's code. If you receive a 0, you do not need to contact us, you are free to just remedy the problem (aka reimplement your solution) and move forward with subsequent deliverables.

If you do wish to appeal our findings and believe your code is your own and was not provided to any other group, you can contact the course instructors and we can launch the appeal process. This process is much more formal and may be managed through the dean's office as they have official processes for adjudicating academic misconduct, which is the most common UBC-level policy pertaining to using (or providing) derivative code.

It is straightforward to avoid violating this policy:

  • Always make sure your work is your own.
  • Never look at or copy at another team's solution, either from this term or past terms.
  • Do not share your code with other teams or post your solution online (see the License below).

Academic Misconduct

The official policies for Academic Misconduct can be found at the following links:

Respectful Environment

Everyone involved with CPSC 310 is responsible for understanding and abiding by UBC's Respectful Environment Statement.

The Statement of Principle of UBC's Respectful Environment Statement is "The best possible environment for working, learning and living is one in which respect, civility, diversity, opportunity and inclusion are valued. Everyone at the University of British Columbia is expected to conduct themselves in a manner that upholds these principles in all communications and interactions with fellow UBC community members and the public in all University-related settings." More details can be found on the department's resource page.

License

The readings for this course are licensed using CC-by-SA. However, it is important to note that the deliverable descriptions, code implementing the deliverables, exams, and exam solutions are considered private materials. We go to considerable lengths to make the project an interesting and useful learning experience for this course. This is a great deal of work, and while future students may be tempted by your solutions, posting them does not do them any real favours. Please be considerate with these private materials and not pass them along to others, make your repos public, or post them to other sites online.