To make software performs as expected, we have to do two thing well:

  1. Verification - "Are we building the software (product) right?" Software should conform to its specifications.
  2. Validation - "Are we building the right software (product)?" Software should do what the user really requires. Maybe our requirements are wrong and doesn't meet the user's needs.

Examples:

Techniques for getting the software right:

<aside> 💡 We focus on software testing. And why are we focusing on this area of verification and validation rather than all the others? Well, software testing is the only defect detection technique that can check the whole system.

</aside>

But testing is always incomplete, and our goal is to make it effective despite incompleteness.

V&V techniques that we have in our toolbox that are related to testing on one square.

V&V techniques that we have in our toolbox that are related to testing on one square.

Netflix/chaosmonkey

The Problem with Software Testing

It only samples a set of possible behaviors, and unlike physical systems most software systems are discontinuous. There is no sound basis for extrapolating from tested to untested cases. So we need to consider all possible states of the system.