Exercise 11: Testing with JUnit
This week’s lab work is intended give you practice testing and writing assertions.
Pre Lab
Please bring these exercises printed out or written out or in digital form with you to lab.
P1. Write down six test cases for Day and Appointment that were not given in the book. Give each test case (and the ones from the lecture) a name.
P2. What assertions do you need in order to be able to automate the tests?
Post-Lab, AKA What To Turn In
- A report of your completed assignment, submitted in Moodle as a pdf
- Your BlueJ project as a zip file
- For the tests you need to record what worked, what didn’t, and perhaps make an occasional screenshot.
Lab assignments are due on Thursday at 22:00.
Assignment
Diary
A diary is a system for keeping track of appointments on specific days and specific hours. We are going to work with a diary that only can take one appointment per hour, starting at 9 a.m. with the last appointment going from 5 p.m. to 6 p.m. You will be given an implementation that could contain errors. Your job is to find the errors. You are only to develop tests and to find and describe errors, not to fix them.
This lab concerns chapter 9 in the book.
- Install the diary project in the lab - switch to the branch of the current term first to see the changes we did in class. Create a test method in DayTest to check that findSpace returns the value of 10 for a one-hour appointment, if a day already has a single one-hour appointment at 9 a.m. In essence, you need to perform similar steps to those used to create testFindSpace9 in the lecture but and use makeAppointment for the first appointment and findSpace for the second appointment. If you want to add an assertion for the result of the makeAppointment call, you should do so in a separate test method as each one should only have one assertion.
- Create a test to check that findSpace returns a value of -1, if an attempt is made to find an appointment in a day that is already full.
- Create a test class that has Appointment as its reference class. Record, using the record button control, separate test methods within it, that check that the description and duration fields of an Appointment object are initialized correctly following its creation.
- Create a negative test in the DayTest class. For example, try and set up a one-hour appointment, and then put in a two-hour appointment at the same time. What happens when you run the test? Include a screenshot in your report.
- Set up a fixture for an additional test case from your pre-lab. What did you have to do?
- Add further automated tests (positive and negative) to theDayTest class, until you are reasonably confident of the correct operation of the classes. If you discover any errors, be sure to record tests that guard against recurrence of these errors in later versions.
- (For the bored) Correct any errors that you find and run a regression test. Document what you have to change and how you ran the regression test!
- (For the bored) Expand the diary to accept appointments on the half-hour. Test.
- (For the exceedingly bored) Expand the diary to permit overlap of appointments. Test.