working software

37
1 Working Software (Testing) Guest lecturer: Alex Groce Today’s Topic Testing Today is a look ahead to CS 362

Upload: softwarecentral

Post on 12-Jul-2015

224 views

Category:

Documents


1 download

TRANSCRIPT

Page 1: Working software

1

Working Software (Testing)

Guest lecturer: Alex Groce

Today’s Topic• Testing

Today is a look ahead to CS 362

Page 2: Working software

2

Before we start

What do I know about testing, anyway?• I’ve written programs and tested them

• So have most of you, I would bet• Split my time at Jet Propulsion Lab between

model checking & testing research• E.g., testing the file systems that will be used in

the Mars Science Laboratory – JPL’s next big Mars mission

Page 3: Working software

3

Basic Definitions: Testing

What is software testing?• Running a program• Generally, in order to find faults (bugs)

• Could be in the code• Or in the spec• Or in the documentation• Or in the test…

Page 4: Working software

4

Faults, Errors, and Failures

Fault: a static flaw in a program• What we usually think of as “a bug”

Error: a bad program state that results from a fault• Not every fault always produces an error

Failure: an observable incorrect behavior of a program as a result of an error• Not every error ever becomes visible

Page 5: Working software

5

Bugs

“It has been just so in all of my inventions. The first step is an intuition, and comes with a burst, then difficulties arise—this thing gives out and [it is] then that 'Bugs'—as such little faults and difficulties are called—show themselves and months of intense watching, study and labor are requisite. . .” – Thomas Edison

“an analyzing process must equally have been performed in order to furnish the Analytical Engine with the necessary operative data; and that herein may also lie a possible source of error. Granted that the actual mechanism is unerring in its processes, the cards may give it wrong orders. ” – Ada, Countess Lovelace (notes on Babbage’s Analytical Engine)

Hopper’s“bug” (mothstuck in arelay on anearly machine)

Page 6: Working software

6

Terms: Test (Case) vs. Test Suite

Test (case): one execution of the program, that may expose a bug

Test suite: a set of executions of a program, grouped together• A test suite is made of test cases

Tester: a program that generates tests

Line gets blurry when testing functions, not programs – especially with persistent state

Page 7: Working software

7

Terms: Black Box Testing

Black box testing• Treats a program or system as a • That is, testing that does not look at source

code or internal structure of the system• Send a program a stream of inputs, observe the

outputs, decide if the system passed or failed the test

• Abstracts away the internals – a useful perspective for integration and system testing

• Sometimes you don’t have access to source code, and can make little use of object code

• True black box? Access only over a network

Page 8: Working software

8

Terms: White Box Testing

White box testing• Opens up the box!

• (also known as glass box, clear box, or structural testing)

• Use source code (or other structure beyond the input/output spec.) to design test cases

• Brings us to the idea of coverage

Page 9: Working software

9

Terms: Coverage

Coverage measures or metrics• Abstraction of “what a test suite tests” in a

structural sense• Common measures:

• Statement coverage• A.k.a line coverage or basic block coverage• Which statements execute in a test suite

• Decision coverage• Which boolean expressions in control structures

evaluated to both true and false during suite execution• Path coverage

• Which paths through a program’s control flow graph are taken in the test suite

• Mutation coverage• Ability to detect random variations to the code

Page 10: Working software

10

Terms: Coverage Measures

In general, used to measure the quality of a test suite• Even in cases where the suite was designed for

some other purpose (such as testing lots of different use scenarios)

• Not always a very good measure of suite quality, but “better than nothing”

• We “open the box” in white box testing partly in order to look at (and design tests to achieve) coverage

We’ll cover coverage in much more detail in 362

Page 11: Working software

11

Terms: Regression Testing

Regression testing• Changes can break code, reintroduce old bugs

• Things that used to work may stop working (e.g., because of another “fix”) – software regresses

• Usually a set of cases that have failed (& then succeeded) in the past

• Finding small regressions is an ongoing research area – analyze dependencies

“. . . as a consequence of the introduction of new bugs, program maintenance requires far more system testing. . . . Theoretically, after each fix one must run the entire batch of test cases previously run against the system, to ensure that it has not been damaged in an obscure way. In practice, such regression testing must indeed approximate this theoretical idea, and it is very costly." - Brooks, The Mythical Man-Month

Page 12: Working software

12

Terms: Functional Testing

Functional testing is a related term• Tests a program from a “user’s” perspective – does it

do what it should?• Sometimes opposed to unit testing, which often

proceeds from the perspective of other parts of the program

• Module spec/interface, not user interaction• Sort of a fuzzy line – consider a file system – how different is

the use by a program and use of UNIX commands at a prompt by a user?

• Building inspector does “unit testing”; you, walking through the house to see if its livable, perform “functional testing”

• Kick the tires vs. take it for a spin?

Page 13: Working software

13

Why Testing?

Ideally: we’d prove codecorrect, using formalmathematical techniques (with a computer, not chalk)

• Extremely difficult: for some trivial programs (100 lines) and many small (5K lines) programs

• Simply not practical to prove correctness in most cases – often not even for safety or mission critical code

• Advances in automation may improve this!

Page 14: Working software

14

Why Testing?

Nearly ideally: use symbolic or abstract model checking to prove the system correct• Automatically extracts a mathematical abstraction from

a system• Proves properties over all possible executions

• In practice, can work well for very simple properties (“this program never crashes in this particular way”), of some programs, but can’t handle complex properties (“this is a working file system”)

• Doesn’t work well for programs with complex data structures (like a file system)

Page 15: Working software

15

As a last resort…

… we can actually run the program, to see if it works

This is software testing• Always necessary, even when you can prove

correctness – because the proof is seldom directly tied to the actual code that runs

“Beware of bugs in the above code; I have only proved it correct, not tried it” – Knuth

Page 16: Working software

16

Why Does Testing Matter?

NIST report, “The Economic Impacts of Inadequate Infrastructure for Software Testing” (2002)

• Inadequate software testing costs the US alone between $22 and $59 billion annually

• Better approaches could cut this amount in half

Major failures: Ariane 5 explosion, Mars Polar Lander, Intel’s Pentium FDIV bug

Insufficient testing of safety-critical software can cost lives: THERAC-25 radiation machine: 3 dead

We want our programs to be reliable• Testing is how, in most cases, we find out if

they are

Mars PolarLander crashsite?

THERAC-25 design

Ariane 5:exception-handlingbug : forced selfdestruct on maidenflight (64-bit to 16-bitconversion: about370 million $ lost)

Page 17: Working software

17

NOT a last resort…

Testing is a critical part of every software development effort

Can too easily be left as an afterthought, after it is expensive to correct faults and when deadlines are pressing• The more code that has been written when a fault

is detected, the more code that may need to be changed to fix the fault

• Consider a key design flaw: better to detect with a small prototype, or after implementation is “finished”?

• May “have to ship” the code even though it has fatal flaws

Page 18: Working software

18

Test-Driven Development

One way to make sure code is tested as early as possible is to write test cases before the code• Idea arising from Extreme Programming and often used

in agile development• Write (automated) test cases first• Then write the code to satisfy tests

• Helps focus attention on making software well-specified• Forces observability and controllability: you have to be

able to handle the test cases you’ve already written (before deciding they were impractical)

• Reduces temptation to tailor tests to idiosyncratic behaviors of implementation

Page 19: Working software

19

Test-Driven Development

How to add a feature to a program, in test-driven development• Add a test case that fails, but would succeed

with the new feature implemented• Run all tests, make sure only the new test fails• Write code to implement the new feature• Rerun all tests, making sure the new test

succeeds (and no others break)

Page 20: Working software

20

Test-Driven Development Cycle

Page 21: Working software

21

Test-Driven Development Benefits

Results in lots of useful test cases• A very large regression set

As noted, forces attention to actual behavior of software: observable & controllable behavior

Only write code as needed to pass tests• And may get good coverage of paths through the

program, since they are written in order to pass the tests

Testing is a first-class activity in this kind of development

Page 22: Working software

22

Test-Driven Development Problems

Need institutional support• Difficult to integrate with a waterfall development• Management may wonder why so much

time is spent writing tests, not code

Lots of test cases may create false confidence• If developers have written all tests, may be blind

spots due to false assumptions made in coding and in testing, which are tightly coupled

Page 23: Working software

23

Stages of Testing

Unit testing is the first phase, done by developers of modules

Integration testing combines unit-tested modules and tests how they interact

System testing tests a whole program to make sure it meets requirements

Acceptance testing by users to see if system meets actual use requirements

Page 24: Working software

24

Stages of Testing: Unit Testing

Unit testing is the first phase, mostly done by developers of modules• Typically the earliest type of testing done• Unit could be as small as a single

function or method• Often relies on stubs to represent other

modules and incomplete code• Tools to support unit tests available for

most popular languages, e.g. Junit (http://junit.org)

Page 25: Working software

25

Stages of Testing: Integration Testing

Integration testing combines unit-tested modules and tests how they interact• Relies on having completed units• After unit testing, before system testing• Test cases focus on interfaces between

components, and assemblies of multiple components

• Often more formal (test plan presentations) than unit testing

Page 26: Working software

26

Stages of Testing: System Testing

System testing tests a whole program to make sure it meets requirements• After integration testing• Focuses on “breaking the system”• Defects in the completed product, not just

in how components interact• Checks quality of requirements as well as

the system• Often includes stress testing, goes

beyond bounds of well-defined behavior

Page 27: Working software

27

Stages of Testing: Acceptance Testing

Acceptance testing by users to see if system meets actual use requirements• Black box testing• By end-users to determine if the system

produced really meets their needs• May revise requirements/goals as much

as find bugs in the code/system

Page 28: Working software

28

Exhaustive vs. Representative Testing

Can we test everything?

File system is a library, called by other components of the flight software

Operation Result

mkdir (“/eng”, …) SUCCESS

mkdir (“/data”, …) SUCCESS

creat (“/data/image01”, …) SUCCESS

creat (“/eng/fsw/code”, …) ENOENT

mkdir (“/data/telemetry”, …) SUCCESS

unlink (“/data/image01”) SUCCESS

/

/eng /data

image01 /telemetry

File system

Page 29: Working software

29

Example: File System Testing

Easy to detect many errors: we have access to many working file systems, and can just compare results

Choose operation F

Perform F on Tested FSPerform F on Reference

(if applicable)

Compare return values

Compare error codes

Compare file systems

Check invariants

(inject a fault?)

Page 30: Working software

30

Example: File System Testing

How hard would it be to just try “all” the possibilities?

Consider only core 7 operations (mkdir, rmdir, creat, open, close, read, write)• Most of these take either a file name or a

numeric argument, or both• Even for a “reasonable” (but not provably safe)

limitation of the parameters, there are 26610

executions of length 10 to try• Not a realistic possibility (unless we have 1012

years to test)

Page 31: Working software

31

“The Testing Problem”

Cannot execute all possible tests (exhaustive testing): must choose a smaller set • How do we select a small set of executions out

of a very large set of executions?

• Fundamental problem of software testing research and practice

• An open (and essentially unsolvable, in the general case) problem

Page 32: Working software

32

Not Testing: Code Reviews

Not testing, exactly, but an important method for finding bugs and determining the quality of code

• Code walkthrough: developer leads a review team through code

• Informal, focus on code• Code inspection: review team checks

against a list of concerns• Team members prepare offline

in many cases• Team moderator usually leads

Page 33: Working software

33

Not Testing: Code Reviews

Code inspections have been found to be one of the most effective practices for finding faults• Some experiments show removal of 67-85% of

defects via inspections

• Some consider XP’s pair programming as a kind of “code review” process, but it’s not quite the same

• Why?

• Can review/walkthrough requirementsand design documents, not just code!

Page 34: Working software

34

Testing and Reviews in Processes

Waterfall

Requirements analysis

Design

Implementation

Operation

Testing

Prototyping

Page 35: Working software

35

Testing and Reviews in Processes

Spiral

Draft a menu ofrequirements

EstablishrequirementsPlan

Analyze risk &prototype

Draft a menu ofarchitecture designs

Analyze risk &prototype

Analyze risk &prototype

Draft a menu ofprogram designs

Establisharchitecture

Establishprogram design

ImplementationTestingOperation

Plan

Page 36: Working software

36

Testing and Reviews in Processes

Agile

Customer provides “stories”(short requirement snippets)

System and acceptance tests

Do “spike” to evaluate & control risk

Prioritizestories and plan

Implement

Operation

Write/run/modifyunit tests

Page 37: Working software

37

Testing and Reviews in Processes

Key differences?• More integrated in agile

• Part of the “inner loop”• More formal, external, “barrier” in waterfall

• In practice, how much testing is done by developers will vary beyond just process

• Agile methods tend to encourage heavy unit testing