Purpose

  • To verify the specification of a unit.
  • To verify the internal structure of a unit.

Role:  Implementer 
Frequency: As required, typically multiple times per iteration, especially in Construction, Transition, and Elaboration phases.
Steps

Input Artifacts: 

 

Resulting Artifacts:   
Tool Mentors: 
More Information: 


Workflow Details: 

 

 

Getting Started

To top of page

Purpose To prepare for implementing the test. 

Unit means not only a class in an object-oriented language, but also free subprograms, such as functions in C++.

For testing each unit (implemented class), perform the following steps:

 

Execute Unit Test

To top of page

Purpose To execute the test procedures, or test scripts if testing is automated. 

To execute unit test, the following steps should be followed:

  1. Set up the test environment to ensure that all the needed elements, such as hardware, software, tools, data, and so on, have been implemented and are in the test environment.
  2. Initialize the test environment to ensure all components are in the correct initial state for the start of testing.
  3. Execute the test procedures.

Note: Executing the test procedures will vary depending on whether testing is automated or manual, and whether test components are needed as either drivers or stubs. 

  • Automated testing: The test scripts created during the Implement Test step are executed.
  • Manual execution: The structured test procedures developed during the Structure Test Procedure activity are used to manually execute the test.

 

Evaluate Execution of Test

To top of page

Purpose To determine whether the tests completed successfully and as desired.
To determine if corrective action is required. 

The execution of testing ends or terminates in one of two conditions:

  • Normal: all test procedures (or scripts) execute as intended.

If testing terminates normally, then continue with the step Verify Test Results.

  • Abnormal or premature: the test procedures, or scripts, did not execute completely or as intended. When testing ends abnormally, the test results may be unreliable. The cause of termination must be identified, corrected, and the tests re-executed before additional test activities are performed.

If testing terminates abnormally, continue with the step Recover from Halted Tests.

 

Verify Test Results

To top of page

Purpose To determine if the test results are reliable.
To identify appropriate corrective action if the test results indicate flaws in the test effort or artifacts. 

When testing is complete, review the test results to ensure the test results are reliable and reported failures, warnings, or unexpected results were not caused by external influences (to the target-of-test), such as improper setup or data.

If the reported failures are due to errors identified in the test artifacts or due to problems with the test environment, take the appropriate corrective action to recover from halted tests and then execute the testing again.

If the test results indicate the failures are genuinely due to the target-of-test, then this activity is essentially complete and typically either the Activity: Submit Change Request or the Activity: Analyze Runtime Behavior should now be performed.

 

Recover From Halted Tests

To top of page

Purpose To determine the appropriate corrective action to recover from a halted test.
To correct the problem, recover, and execute the tests again. 

There are two major types of halted tests:

  • Fatal errors-the system fails; for example, network failures, hardware crashes, and the like.
  • Test Script Command Failures-specific to automated testing, this is when a test script cannot execute a command or a line of code.

Both types of abnormal termination to testing may exhibit the same symptoms:

  • Unexpected actions, windows, or events occur while the test script is executing.
  • Test environment appears unresponsive or in an undesirable state, such as hung or crashed.

To recover from halted tests, perform these steps:

  1. Determine the actual cause of the problem.
  2. Correct the problem.
  3. Set up the test environment again.
  4. Initialize the test environment again.
  5. Execute the tests again.


Rational Unified Process  

2003.06.13