Lecture 8 -Ch8-Software Testing
Lecture 8 -Ch8-Software Testing
Ian Sommerville,
Software Engineering, 9 th Edition
Development testing
Test-driven development
Release testing
User testing
Validation testing
▪ To demonstrate to the developer and the system customer that
the software meets its requirements
▪ A successful test shows that the system operates as intended.
Defect testing
▪ To discover faults or defects in the software where its behaviour
is incorrect or not in conformance with its specification
▪ A successful test is a test that makes the system perform
incorrectly and so exposes a defect in the system.
Verification:
"Are we building the product right”.
The software should conform to its specification.
Validation:
"Are we building the right product”.
The software should do what the user really requires.
A setup part, where you initialize the system with the test
case, namely the inputs and expected outputs.
A call part, where you call the object or method to be
tested.
An assertion part where you compare the result of the
call with the expected result. If the assertion evaluates to
true, the test has been successful if false, then it has
failed.
Lecture 2
Interface misuse
▪ A calling component calls another component and makes an
error in its use of its interface e.g. parameters in the wrong order.
Interface misunderstanding
▪ A calling component embeds assumptions about the behaviour
of the called component which are incorrect.
Timing errors
▪ The called and the calling component operate at different speeds
and out-of-date information is accessed.
Code coverage
▪ Every code segment that you write has at least one associated
test so all code written has at least one test.
Regression testing
▪ A regression test suite is developed incrementally as a program
is developed.
Simplified debugging
▪ When a test fails, it should be obvious where the problem lies.
The newly written code needs to be checked and modified.
System documentation
▪ The tests themselves are a form of documentation that describe
what the code should be doing.
Chapter 8 Software testing 46
Regression testing
Alpha testing
▪ Users of the software work with the development team to test the
software at the developer’s site.
Beta testing
▪ A release of the software is made available to users to allow
them to experiment and to raise problems that they discover with
the system developers.
Acceptance testing
▪ Customers test a system to decide whether or not it is ready to
be accepted from the system developers and deployed in the
customer environment. Primarily for custom systems.