Weekly Calendar

January 6

Title: Bugs are everywhere
Reading material: page 1-2, 4-6 of the textbook
Slides: lecture1.pdf

January 8

Title: Testing on steriods
Reading material: JUnit website
Slides: lecture2.pdf
Handout: handout1.pdf, handout2.pdf
Code: ColorTest.java

January 10

Title: More testing on steroids
Reading material: JUnit website
Slides: lab1.pdf
Lab: Lab 1

January 13

Title: Space exploration
Reading material: page 3, 7-8, 11-16 of the textbook
Slides: lecture3.pdf
Handout: handout3.pdf
Code: OneChoice.java, TwoChoices.java, ManyChoices.java, ManyChoices.java

January 15

Title: Check models
Reading material: Section 1 and Section 5.1-5.3 of The Birth of Model Checking, Java PathFinder: a translator from Java to Promela
Slides: lecture4.pdf
Handout: handout4.pdf
Code: PrintRandom.java, PrintRandom.jpf

January 17

Quiz: Quiz 1

January 20

Title: State space traversals
Reading material: Chapter 5 of notes.pdf
Slides: lecture5.pdf
Handout: handout5.pdf
Code: RunTest.java, RunTest.jpf, RunJPF.java, Traversal.java

January 22

Title: Listen
Reading material: The Java Tutorials: Writing Event Listeners
Slides: lecture6.pdf
Handout: handout6.pdf
Code: Generator.java, Main.java, Listener.java, ListenerAdapter.java, PlusPrinter, StarPrinter.java, ValuePrinter.java, SumPrinter.java

January 24

Reading material: Chapter 1 and 2 of notes.pdf
Project: Part 1 of project

Reading material: Chapter 5 of notes.pdf
Lab: Lab 2

January 27

Title: Listen
Reading material: Chapter 7 up to Section 7.5 of notes.pdf, JPF API
Slides: lecture7.pdf
Handout: handout7.pdf
Code: SearchEvents.java, Traversal.java, Traversal.jpf, StateSpaceText.java, Traversal.jpf, StateSpaceDot.java, StateSpaceDot.java (version with colours)

January 29

Title: Listen
Reading material: The remainder of Chapter 7 of notes.pdf, JPF API
Slides: lecture8.pdf
Code: Garbage.java (first version), Garbage.java (second version), GarbageTest.java, GarbageTest.jpf, Mnemonics.java, Profiler.java

January 31

Quiz: Quiz 2

February 3

Title: Search
Reading material: Chapter 9, up to and including Section 9.6, of notes.pdf
Slides: lecture9.pdf
Handout: handout9.pdf
Code: DFSearch.java

February 5

Title: Search
Reading material: the remainder of Chapter 9 of notes.pdf
Slides: lecture10.pdf
Handout: handout10.pdf
Code: BFSearch.java, Generate.java, Sample.java (generated app), SearchNotificationRecorder, CompareSearchRecordings, test.sh

February 7

Reading material: Chapter 9 of notes.pdf
Lab: Lab 3

February 10

Title: Linear Temporal Logic
Reading material: pages 229-236 of the textbook
Slides: lecture11.pdf
Handout: handout11.pdf

February 12

Title: Temporal Logics
Reading material: pages 174-175, 248-249, 271-272, 313-327 and 334-340 of the textbook
Slides: lecture12.pdf
Handout: handout12.pdf

February 14

Quiz: Quiz 3
Project: Part 2 of project

February 24

Project: Part 3 of project

Title: Computational Tree Logic
Reading material: pages 341-351 of the textbook
Slides: lecture13.pdf
Handout: handout13df

February 26

Title: Testing JPF
Reading material: notes on testing JPF components,TestJPF
Slides: lecture14.pdf
Handout: handout14.pdf
Code: BasicTest.java, CallMonitorTest.java

February 28

Lab: Lab 4

March 2

Midterm a solution

March 4

Title: Peers and Native Peers
Reading material: Chapter 10 of notes.pdf
Slides: lecture15.pdf
Handout: handout15.pdf
Code: TeleTYpewriter.java, Main.java, my_util_TeleTypewriter.h, my_util-TeleTYpewriter.c, TeleTYpewriter.java (peer class), Main.jpf (using peer class), JPF_my_util_TeleTYpewriter.java (native peer class), Main.jpf (using native peer class), Main.jpf (using jpf-nhandler

March 6

Lab: Lab 5

March 9

Project: Part 4 of project

Title: Concurrency
Reading material: The Java Tutorials: Concurrency
Slides: lecture16.pdf
Handout: handout16.pdf
Code: Printer.java (using Thread), TwoPrinters.java (using Thread). Printer.java (using Runnable). TwoPrinters.java (using Runnable), TwoPrinters.java (using anonymous class)Incrementer.java, TwoIncrementers.java, TwoIncrementers.jpf

March 11

Title: Concurrency
Reading material: The Java Tutorials: Concurrency
Slides: lecture17.pdf
Handout: handout17.pdf
Code: Counter.java, Resource.java, User.java, MultipleUsers.java

March 13

Lab: Lab 6

March 16

Title: Concurrency
Reading material: The Java Tutorials: Concurrency, Section 3.1 of the textbook
Slides: lecture18.pdf
Handout: handout18.pdf
Code: Reader.java, Writer.java, ReadersAndWriters.java, Database.java, Philosopher.java, Table.java, DiningPhilosophers.java
Recording: recording

March 18

Title: Concurrency
Reading material: The Java Tutorials: Concurrency
Slides: lecture19.pdf
Code: Scheduling.java, Philosopher.java, Table.javaLeftHandedPhilosopher.java, RightHandedPhilosopher.java, DiningPhilosophers.java (left and right handed), Philosopher.java, Table.java, DiningPhilosophers.java (philosophers sits down before picking of the forks), Philosopher.java, DiningPhilosophers.java (states)
Recording: recording

March 20

Lab: Lab 7

March 23

Project: Part 5 of project

Title: Undecidability
Slides: lecture20.pdf
Recording: recording

March 25

Title: Data races
Slides: lecture21.pdf
Handout: handout21.pdf
Code: Code: Account.java, Account.java, Search.java
Recording: recording

March 27

Lab: Lab 8

March 30

Slides of sample presentation Recording of sample presentation

Presentation schedule:

  1. Rajvi Chavada and Connor Dear
  2. Syed Usman
  3. Connor Ahearn and Jeremy Winkler
  4. Damanveer Bharaj
  5. Sara Attalla and Sean Doyle

Recording: recording

April 1

Presentations

  1. Gagen Benipal and Zaeem Israr
  2. Kevin Banh and Andrew Maywapersaud
  3. Anji Tong
  4. Aya Abu Allan and Mark Savin
  5. Dong Jae Lee
  6. Bradley Booth and Akbar Khan

Recording: recording

April 3

Lab: Lab 9

April 8

Final exam at 7pm

April 20

Project: final report and code

May 9

Drop deadline: last date to drop the course without receiving a grade for it.

Updates from York University Senate

<!--   ===== January 23 =====   //Title:// Mini models\\ //Slides:// {{:lecture5.pdf|lecture5.pdf}}\\ //Handout:// {{:handout5.pdf|handout5.pdf}}\\ //Code:// {{:nosomanychoices.txt|NoSoManyChoices.java}}, {{:choice.txt|Choice.java}}   {{:statespacewithouthtreadinfo.png?200x50|state space diagram}}\\   //Code:// {{:statespacewiththreadinfo.txt|StateSpaceWithThreadInfo.java}}     ===== March 18 =====   //Title:// Concurrency\\ //Reading material:// [[https://docs.oracle.com/javase/tutorial/essential/concurrency/|The Java Tutorials: Concurrency]]\\ //Slides:// {{:lecture17.pdf|lecture17.pdf}}\\ //Handout:// {{:handout17.pdf|handout17.pdf}}\\ //Code:// {{:public:AbstractPhilosopher.txt|Philosopher.java}}, {{:public:table.txt|Table.java}}{{:public:LeftHandedPhilosopher.txt|LeftHandedPhilosopher.java}}, {{:public:RightHandedPhilosopher.txt|RightHandedPhilosopher.java}}, {{:public:LeftRightDiningPhilosophers.txt|DiningPhilosophers.java}}, {{:public:Room.txt|Room.java}}, {{:public:RoomPhilosopher.txt|Philosopher.java}}, {{:public:PhilosopherWithState.txt|Philosopher.java}}   ===== March 20 =====   //Title:// Concurrency\\ //Reading//: [[https://docs.oracle.com/javase/tutorial/essential/concurrency/|The Java Tutorials: Concurrency]]\\ //Slides:// {{:lecture18.pdf|lecture18.pdf}}\\ //Handout:// {{:handout18.pdf|handout18.pdf}}\\ //Code:// {{:public:RaceAndCondition.txt|Account.java}}, {{:public:ConditionAndNoRace.txt|Account.java}} , {{:public:RaceAndNoCondition.txt|Search.java}}   ===== March 22 =====   //Lab:// work on your project   ===== March 29 =====   //Lab:// work on your project\\ //Slides:// {{:lab12.pdf|lab12.pdf}}   //Project:// [[project5|Part 5 of project]]   ===== April 3 =====   //Title:// Symbolic model checking\\ //Reading material:// [[http://dx.doi.org.ezproxy.library.yorku.ca/10.1145/1390630.1390635|Combining unit-level symbolic execution and system-level concrete execution for testing NASA software]]\\ //Slides:// {{:lecture22.pdf|lecture22.pdf}}   ===== April 8 =====   //Office hours:// 14:00-16:00   ===== April 9 =====   //Office hours:// 10:00-12:00   ===== April 10 =====   [[final|Final exam]], {{:final.pdf|a solution}}: 14:00-17:00 in LAS 1004.   ===== April 22 =====   [[project6|Project]]   -->