-
Notifications
You must be signed in to change notification settings - Fork 6
/
syllabus.tex
188 lines (159 loc) · 6.52 KB
/
syllabus.tex
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
\documentclass{article}
\usepackage{fullpage}
\usepackage{url}
\usepackage{enumitem}
\setlist{nosep}
\begin{document}
\title{Software Testing, Quality Assurance and Maintenance\\SE465, Winter 2019, version 0}
\author{Patrick Lam}
\renewcommand{\today}{}
\maketitle
\vspace*{-2em}
\section*{Brief Overview}
As you have no doubt discovered, software never works right from the
start. A key technique for getting more acceptable software is
testing. Organized testing can help identify problems in software
systems, enabling developers to fix these problems. This course will
introduce software testing techniques; while it's not my goal
to produce testers, you should at least be conversant
with up-to-date testing methodologies and techniques. And easier-to-test
software is better software.
In this class, we will also touch on software maintenance. While we
greatly (over?) emphasize design in engineering school, maintenance
consumes a large fraction of today's software development resources.
\section*{General Information}
\noindent
\begin{tabbing}
{\bf github repo:}~~~\= \url{[email protected]:patricklam/stqam-2019.git}\\
{\bf Lectures:} \> MW 2:30-3:50, MC 4020\\
{\bf Tutorials:} \> not generally used, but scheduled for M 10:30-11:20, MC 4020
\end{tabbing}
\noindent
{\bf Instructor:} \\
\noindent
\hspace*{2em} \begin{minipage}{.6\textwidth}
Prof. Patrick Lam\\
Office: DC-2539\\
Drop-in Hours: W 11:30-12:20 (or by appointment)\\
Email: {\tt [email protected]}\\
Phone: Use email instead!
\end{minipage} \\[1em]
\noindent {\bf Teaching Assistants:} \\
\noindent
\hspace*{2em}\begin{tabular}{l@{\hspace*{3em}}ll}
Meet Bhavsar &
{\tt [email protected]}&
SE 2019 \\
Jason Milasincic &
{\tt [email protected]} &
SE 2019 \\
Parsa Pourali&
{\tt [email protected]}&
PhD student\\
Michael Socha &
{\tt [email protected]}&
SE 2019
\end{tabular}
\section*{Course Description}
\paragraph{Objectives.}
We hope that you will learn how to test as a developer, thus making
you a better developer. Good software systems are easy to test and
we'll talk about how testability affects design.
\begin{itemize}
\item You will be able to create and evaluate test suites for reasonably-sized
software systems.
\item You will learn how to use and write tools for software maintenance and
verification (particularly automated testing tools).
\end{itemize}
\paragraph{Topics.}
This course is a moving target and this may be the last time the course
is taught like this. I think this course will be quite similar to the
2017 offering, although I would like to go more SE 212-like in the tools
unit, so that might change. As usual, exams may be different from other offerings,
but 2017 is a good bet.\\
\begin{itemize}
\item Introduction and definitions (defects, faults, failures) (1 week)
\item \emph{Defining Test Suites}---finding interesting inputs and knowing when to stop looking (4 weeks)\\
How do you generate test suites?
\begin{itemize}
\item open-ended exploratory testing;
\item statement/branch coverage;
\item graph-based models of program state; integrating design documentation;
\item automatically generating inputs: grammars, fuzzing.
\end{itemize}~\\[-1em]
How good is your test suite?
\begin{itemize}
\item coverage
\item mutation
\end{itemize}
\item \emph{Engineering Test Suites} (3 weeks)
\begin{itemize}
\item JUnit (unit testing, end-to-end testing, regression testing)
\item Selenium and other web-based testing
\item mock objects
\item refactoring tests
\item refactoring code to be testable
\item continuous integration
\item flaky tests
\end{itemize}
\item \emph{Tools for Verification \& Validation} (3 weeks)\\
I plan to include some intuition for why these tools work. I hope to go more formal-verification-ish here than the things listed below.
\begin{itemize}
\item concept: static vs. dynamic analysis
\item static approaches: type systems, immutability, compiler warnings, software model checking, JML tools. Coverity, Facebook Infer, FindBugs, aComment
\item dynamic approaches: valgrind/Clang address sanitizer, assertions, concurrency detectors: races, missing locks
\item human-based approaches: code review, bug reporting
\end{itemize}
\item Bonus: debugging and the scientific method (1 week) \\
(reference: Andreas Zeller. \emph{Why Programs Fail: a Guide to Systematic Debugging.})
\end{itemize}
\section*{Reference Material}
Course notes (posted to the git repository) are your best bet.
\newpage
\section*{Evaluation}
This course includes assignments, a midterm, a course project, and a final
examination.
\begin{tabular}{lrl}
3 individual assignments & 20\% & (6 2/3\% each) \\
Course project (in groups, up to 3/group) & 15\% \\
Midterm & 15\% \\
Final exam & 50\% \\
\end{tabular}
\noindent The midterm and final exams will be open-book, open-notes.
\paragraph{Schedule.} Assignment handin will be done through the git server at {\tt git.uwaterloo.ca}.\\[-1em]
\begin{center}
\begin{tabular}{ll}
January 14 &A1 out\\
January 28 &A1 due, A2 out\\
February 25 &A2 due, A3 out\\
February 28 &Midterm (6:30-8:20PM, RCH 301/307)\\
March 25 &A3 due\\
April 5 &Last day of lectures; project due\\
Exam period &Final exam
\end{tabular}~\\
\end{center}
%You can also find the dates on the following Google calendar:\\
%\hspace*{3em}\url{[email protected]}
\section*{Policies}
\paragraph{Group work.} The project will be done in groups.
You may discuss assignments with others, but I expect each of
you to do the assignment independently. I will follow UW's Policy 71
if I discover any cases of plagiarism. I will not use turnitin.
\paragraph{Lateness.} You have 2 days of lateness to use on assignment
submissions throughout the term. Each day you hand in an assignment
late consumes one of the days of lateness. If you consume all of your
late days, assignments that are still late will get 0. Missed assignments get 0.
e.g. you may hand in A1 one day late and A2 one day late if
you hand in A3 on time. Or you can hand in A1-A2 on time and
A3 two days late.\\[1em]
\noindent \begin{tabular}{ @{\hspace{0.25in}}l l }
Academic integrity: & \url{http://uwaterloo.ca/academicintegrity/}\\
Petition \& Grievance:
& \url{http://secretariat.uwaterloo.ca/Policies/policy70.htm}\\
Discipline: & \url{http://secretariat.uwaterloo.ca/Policies/policy71.htm} \\
Penalties:
& \url{http://secretariat.uwaterloo.ca/guidelines/penaltyguidelines.htm}\\
Appeals: & \url{http://secretariat.uwaterloo.ca/Policies/policy72.htm} \\
AccessAbility: & \url{https://uwaterloo.ca/disability-services/}
\end{tabular}
\end{document}