Download presentation
Presentation is loading. Please wait.
Published byJulia Douglas Modified over 9 years ago
1
1 Intro to Java Week 12 (Slides courtesy of Charatan & Kans, chapter 8)
2
2 Software Quality Learning objectives By end of this lecture you should be able to: document your code so that it is easy to maintain; distinguish between compile-time errors and run-time errors; test a program using the strategies of unit testing and integration testing; generate test data using the strategies of black box testing, white box testing and stress testing; document your test results professionally using a test log; explain the meaning of a Java program throwing an exception; format your output to improve the usability of your programs.
3
3 Measuring quality There are many desirable features of a piece of software. We will concentrate on the following: maintainability; reliability; robustness; usability.
4
4 Maintainability The requirements of an application often change over time. Maintaining a system refers to the need to update an existing system to reflect these changing requirements. Code should be designed in such a way as to make these changes easier rather than harder.
5
5 Documentation For a software system to be easy to maintain, the software design also needs to be clearly documented. When developing object-oriented programs, this design documentation should include: complete class diagrams; clear method definitions (parameter & return types, plus pseudocode when appropriate).
6
6 Reliability When attempting to run a program two kinds of errors could occur: compile time errors; run-time errors.
7
7 Compiler errors
8
8 Testing Testing can never show the absence of errors, only the presence of them. The aim therefore of any testing strategy is to uncover these errors. Two areas of testing: validation (making sure you are building the right product); verification (making sure you are building the product right).
9
9 Verification A Java application typically consists of many classes working together. Testing for such errors will start with a process of unit testing (testing individual classes) followed by integration testing (testing classes that make up an application together).
10
10 Unit testing All applications require a class with a main method before they can be run. Two possibilities add a main method into the class you are testing; writing a separate class especially to contain the main method. This new class then acts as the driver for the original class.
11
11 Dummy classes Testing the StudentList class requires the Student class to be available. You can develop your own dummy class in place of the missing class. // a dummy student class class Student { // no code in class }
12
12 Adding dummy methods to dummy classes public double findStudentAverage (int i) { return student[i-1].calculateAverageMark( ); } class Student // ammended dummy class { // additional dummy method public double calculateAverageMark() { return 50.5; }
13
13 Integration testing When the individual classes in a program have been tested they can be integrated and tested together. If compiler errors occur during integration then check the following:
14
14 All methods called should have an implementation in the receiving class Student Student (…) getName( ) setName(…) StudentList x = student[i-].calculateAverageMark( ) ?
15
15 Names of method calls should match exactly names of methods in receiving class Student double calculateAverageMark( ) StudentList x = student[i-1].CalculateAverageMark() ?
16
16 Parameter list of method call should match exactly parameter list of methods in the receiving class StudentList x = student[i-1].calculateAverageMark(2) ? Student double calculateAverageMark( )
17
17 The expected type of values returned from the method calls should match the return types of these methods in the receiving class. Student double calculateAverageMark( ) StudentList int x; x = student[i-1].calculateAverageMark(); ?
18
18 Black box testing component to test ? inputsexpected outputs
19
19 Testing the method getGrade
20
20 Test data produced grade 'A' grade 'B' grade 'C' grade 'D' grade 'E' grade 'F' "mark too low" "mark too high" 79, 64, 55, 46, 33, 25, -40, 120
21
21 Testing the boundaries If the code still fails to produce the correct result often the error lies on the boundaries of such equivalent groups. In this case the following boundary values should all be tested as well as the sample from each equivalent group identified earlier: -1, 0, 1, 29, 30, 31,39, 40, 41,49, 50, 51,59, 60, 61, 69, 70, 71, 99, 100, 101
22
22 White box testing component to test inputs based on code expected outputs topMark = 70; // more code here while(!valid) { if (mark > topMark) grade = 'A'; //more code here else valid = false; }
23
23 The test log
24
24 Robustness A program is said to crash when it terminates unexpectedly. A robust program is one that doesn't crash even if it receives unexpected input values. Generally, whenever a value is received to be processed, it should be checked before processing continues; if an unexpected value could cause the program to crash.
25
25 A program will crash if an illegal array index is used PushToLimitSalesStaff for (int i = 1; i<=3; i++) { System.out.println ("enter sales for employee "+ i); value = EasyIn.getInt(); cars4U.setFigure(i, value); } SalesStaff public void setFigure(int numberIn, int valueIn) { staff[numberIn-1] = valueIn; } 'i' set to 3 last time round the loop an attempt will be made to access index 2
26
26 Dealing with the problem public boolean setFigure(int numberIn, int valueIn) { if (numberIn <= staff.length) { staff[numberIn-1] = valueIn; return true; // method succesful } else { return false; // method unsuccessful }
27
27 Adapting the driver program for (int i = 1; i<=3; i++) { System.out.println ("enter sales for employee "+ i); value = EasyIn.getInt(); boolean ok = cars4U.setFigure(i, value); if (!ok) // unable to set figure succesfully { System.out.println ("ERROR:last figure not entered "); }
28
28 Usability The usability of a program refers to the ease with which users of your application can interact with your program. A user-manual can help make your programs easier to follow.
29
29 Adding a "HELP" option *** REACTOR SYSTEM *** [1] Get current temperature [2] Increase temperature [3] HELP [4] Quit enter choice [1,2,3,4]: _
30
30 Escape sequences Special formatting characters, known as escape sequences, can be added into strings.
31
31 The DecimalFormat class The DecimalFormat class can be used to format the display of decimal numbers. This class resides in the java.text package import java.text.*; Once you have access to this class you can create DecimalFormat objects in your program.
32
32 Creating DecimalFormat objects The DecimalFormat constructor has one parameter, the format string. DecimalFormat df = new DecimalFormat( "000,000.000");
33
33 Using a DecimalFormat object Use the format method of the DecimalFormat class to format a given number: DecimalFormat df =new DecimalFormat( "000,000.000"); double someNumber = 12345.6789; System.out.println("before\t" + someNumber); System.out.println("after\t"+ df.format(someNumber)); before12345.6789 after 012,345.679
34
34 Optional digits Replacing a zero in a format string with a hash (#) would mean that the digit was optional, not compulsory. DecimalFormat df = new DecimalFormat( "#00,000.000"); double someNumber = 12345.6789; System.out.println("before\t" + someNumber); System.out.println("after\t" + df.format(someNumber)); before12345.6789 after 12,345.679
35
35 Graphical user interfaces
Similar presentations
© 2024 SlidePlayer.com. Inc.
All rights reserved.