SoftwareTesting:Test Plan And Test Strategy Sample Doc Course Registration System

Course Registration System

Test Plan
for the
Architectural Prototype

Version 1.0

Revision History

Date

Version

Description

Author

7/March/1999 1.0 Initial Release – Prototype Test Plan K. Stone

 

Table of Contents

  1. Objectives
  2. Requirements for Test
  3. Test Strategy
  4. Resources
  5. Project Milestones
  6. Deliverables
  7. Project Tasks

Test Plan

for the

Architectural Prototype

1. Objectives

1.1 Purpose

This document describes the plan for testing the architectural prototype of the C-Registration System. This Test Plan document supports the following objectives:

  • Identify existing project information and the software that should be tested.
  • List the recommended test requirements (high level).
  • Recommend and describe the testing strategies to be employed.
  • Identify the required resources and provide an estimate of the test efforts.
    • List the deliverable elements of the test activities.

1.2 Scope

This Test Plan describes the integration and system tests that will be conducted on the architectural prototype following integration of the subsystems and components identified in the Integration Build Plan for the Prototype [16].

It is assumed that unit testing already provided thorough black box testing, extensive coverage of source code, and testing of all module interfaces.

The purpose of assembling the architectural prototype was to test feasibility and performance of the selected architecture. It is critical that all system and subsystem interfaces be tested as well as system performance at this early stage. Testing of system functionality and features will not be conducted on the prototype.

The interfaces between the following subsystems will be tested:

    1. Course Registration
    2. Finance System
    3. Course Catalog.

The external interfaces to the following devices will be tested:

    1. Local PCs
    2. Remote PCs.

The most critical performance measures to test are:

  • Response time for remote login to the course registration system.
  • Response time to access the Finance System.
  • Response time to access the Course Catalog Subsystem.
  • Student response time when system loaded with 200 logged in students.
    1. Student response time when 50 simultaneous accesses to the Course Catalog database.

1.3 References

Applicable references are:

2.    Requirements for Test The listing below identifies those items (use cases, functional requirements, non-functional requirements) that have been identified as targets for testing. This list represents what will be tested.

(Note: Future release of this Test Plan may use Rational RequisitePro for linking directly to the requirements in the Use Case Documents and Supplementary Specification.)

2.1 Data and Database Integrity Testing

Verify access to Course Catalog Database.

Verify simultaneous record read accesses.

Verify lockout during Course Catalog updates.

Verify correct retrieval of update of database data.

2.2. Function Testing

Vision Document, Section 12.2: “The system shall interface with the existing Course Catalog Database System. C-Registration shall support the data format as defined in [2].”

Vision Document, Section 12.2: “The system shall interface with the existing Billing System and shall support the data format as defined in [1].”

Vision Document, Section 12.2: “The server component of the system shall operate on the College Campus Server and shall run under the UNIX Operating System.”

Supplementary Specification, Section 9.3: “The server component of the system shall operate on the Wylie College UNIX Server.”

Vision Document, Section 12.2: “The client component of the system shall operate on any personal computer with a 486 Microprocessor or better.”

Supplementary Specification, Section 9.3: “The client component of the system shall operate on any personal computer with a 486 Microprocessor or greater.”

Supplementary Specification, Section 9.1: “The system shall integrate with existing legacy system (course catalog database) which operates on the College DEC VAX Main Frame.”

Supplementary Specification, Section 9.2: “The system shall integrate with the existing Course Billing System which operates on the College DEC VAX Main Frame.”

2.3 Business Cycle Testing

None.

2.4 User Interface Testing

Verify ease of navigation through a sample set of screens.

Verify sample screens conform to GUI standards.

Vision Document Section 10: “The System shall be easy-to-use and shall be appropriate for the target market of computer-literate students and professors.”

Vision Document, Section 12.1: “The desktop user-interface shall be Windows 95/98 compliant.”

Supplementary Specification, Section 5.1: “The desktop user-interface shall be Windows 95/98 compliant.”

Supplementary Specification, Section 5.2: “The user interface of the C-Registration System shall be designed for ease-of-use and shall be appropriate for a computer-literate user community with no additional training on the System.”

2.5 Performance Testing

Verify response time to access external Finance system.

Verify response time to access external Course Catalog subsystem.

Verify response time for remote login.

Verify response time for remote submittal of course registration.

Vision Document, Section 12.3: “The system shall provide access to the legacy Course Catalog Database with no more than a 10 second latency.”

Supplementary Specification, Section 7.2: “The system shall provide access to the legacy Course Catalog Database with no more than a 10 second latency.”

2.6 Load Testing

Verify system response when loaded with 200 logged on students.

Verify system response when 50 simultaneous student accesses to the Course Catalog.

2.7 Stress Testing

None.

2.8 Volume Testing

None.

2.9 Security and Access Control Testing

Verify Logon from a local PC.

Verify Logon from a remote PC.

Verify Logon security through user name and password mechanisms.

2.10 Failover / Recovery Testing

None.

2.11 Configuration Testing

Vision Document, Section 12.2: “The client component of the system shall run on Windows 95, Windows 98, and Microsoft Windows NT.”

Supplementary Specification, Section 9.4: “The web-based interface for the C-Registration System shall run in Netscape 4.04 and Internet Explorer 4.0 browsers.

Supplementary Specification, Section 9.5: “The web-based interface shall be compatible with the Java 1.1 VM runtime environment.

2.12 Installation Testing

None.

3.    Test StrategyThe Test Strategy presents the recommended approach to the testing of the software applications. The previous section on Test Requirements described what will be tested; this describes how it will be tested.

The main considerations for the test strategy are the techniques to be used and the criterion for knowing when the testing is completed.

In addition to the considerations provided for each test below, testing should only be executed using known, controlled databases, in secured environments.

The following test strategy is generic in nature and is meant to apply to the requirements listed in Section 4 of this document.

3.1 Testing Types3.1.1 Data and Database Integrity Testing

The databases and the database processes should be tested as separate systems. These systems should be tested without the applications (as the interface to the data). Additional research into the DBMS needs to be performed to identify the tools / techniques that may exist to support the testing identified below.

Test Objective: Ensure Database access methods and processes function properly and without data corruption.
Technique:
  • Invoke each database access method and process, seeding each with valid and invalid data (or requests for data).
  • Inspect the database to ensure the data has been populated as intended, all database events occurred properly, or review the returned data to ensure that the correct data was retrieved (for the correct reasons)
Completion Criteria: All database access methods and processes function as designed and without any data corruption.
Special Considerations:
  • Testing may require a DBMS development environment or drivers to enter or modify data directly in the databases.
  • Processes should be invoked manually.
  • Small or minimally sized databases (limited number of records) should be used to increase the visibility of any non-acceptable events.

 

 

3.1.2 Function Testing

Testing of the application should focus on any target requirements that can be traced directly to use cases (or business functions), and business rules. The goals of these tests are to verify proper data acceptance, processing, and retrieval, and the appropriate implementation of the business rules. This type of testing is based upon black box techniques, that is, verifying the application (and its internal processes) by interacting with the application via the GUI and analyzing the output (results). Identified below is an outline of the testing recommended for each application:

Test Objective: Ensure proper application navigation, data entry, processing, and retrieval.
Technique:
  • Execute each use case, use case flow, or function, using valid and invalid data, to verify the following:
  • The expected results occur when valid data is used.
  • The appropriate error / warning messages are displayed when invalid data is used.
  • Each business rule is properly applied.
Completion Criteria:
  • All planned tests have been executed.
  • All identified defects have been addressed.
Special Considerations:
  • Access to the Wylie College UNIX Server and the existing Course Catalog System and Billing System is required to run some of the identified System Tests on the Prototype.

3.1.3 Business Cycle Testing

This section is not applicable to test of the architectural prototype.

3.1.4 User Interface Testing

User Interface testing verifies a user’s interaction with the software. The goal of UI Testing is to ensure that the User Interface provides the user with the appropriate access and navigation through the functions of the applications. In addition, UI Testing ensures that the objects within the UI function as expected and conform to corporate or industry standards.

Test Objective: Verify the following:

  • Navigation through the application properly reflects business functions and requirements, including window to window, field to field, and use of access methods (tab keys, mouse movements, accelerator keys)
  • Window objects and characteristics, such as menus, size, position, state, and focus conform to standards.
Technique:
  • Create / modify tests for each window to verify proper navigation and object states for each application window and objects.
Completion Criteria: Each window successfully verified to remain consistent with benchmark version or within acceptable standard
Special Considerations:
  • Not all properties for custom and third party objects can be accessed.

3.1.5 Performance Profiling

Performance testing measures response times, transaction rates, and other time sensitive requirements. The goal of Performance testing is to verify and validate the performance requirements have been achieved. Performance testing is usually executed several times, each using a different “background load” on the system. The initial test should be performed with a “nominal” load, similar to the normal load experienced (or anticipated) on the target system. A second performance test is run using a peak load.

Additionally, Performance tests can be used to profile and tune a system’s performance as a function of conditions such as workload or hardware configurations.

NOTE: Transactions below refer to “logical business transactions.” These transactions are defined as specific functions that an end user of the system is expected to perform using the application, such as add or modify a given contract.

Test Objective: Validate System Response time for designated transactions or business functions under a the following two conditions:– normal anticipated volume

– anticipated worse case volume

Technique:
  • Use Test Scripts developed for Business Model Testing (System Testing).
  • Modify data files (to increase the number of transactions) or modify scripts to increase the number of iterations each transaction occurs.
  • Scripts should be run on one machine (best case to benchmark single user, single transaction) and be repeated with multiple clients (virtual or actual, see special considerations below).
Completion Criteria:
  • Single Transaction / single user: Successful completion of the test scripts without any failures and within the expected / required time allocation (per transaction)
  • Multiple transactions / multiple users: Successful completion of the test scripts without any failures and within acceptable time allocation.
Special considerations:
  • Comprehensive performance testing includes having a “background” load on the server. There are several methods that can be used to perform this, including:
  • “Drive transactions” directly to the server, usually in the form of SQL calls.
  • Create “virtual” user load to simulate many (usually several hundred) clients. Remote Terminal Emulation tools are used to accomplish this load. This technique can also be used to load the network with “traffic.”
  • Use multiple physical clients, each running test scripts to place a load on the system.
  • Performance testing should be performed on a dedicated machine or at a dedicated time. This permits full control and accurate measurement.
  • The databases used for Performance testing should be either actual size, or scaled equally.

 

3.1.6 Load Testing

Load testing measures subjects the system-under-test to varying workloads to evaluate the system’s ability to continue to function properly under these different workloads. The goal of load testing is to determine and ensure that the system functions properly beyond the expected maximum workload. Additionally, load testing evaluates the performance characteristics (response times, transaction rates, and other time sensitive issues).

NOTE: Transactions below refer to “logical business transactions.” These transactions are defined as specific functions that an end user of the system is expected to perform using the application, such as add or modify a given contract.

Test Objective: Verify System Response time for designated transactions or business cases under varying workload conditions.
Technique:
  • Use tests developed for Business Cycle Testing.
  • Modify data files (to increase the number of transactions) or the tests to increase the number of times each transaction occurs.
Completion Criteria:
  • Multiple transactions / multiple users: Successful completion of the tests without any failures and within acceptable time allocation.
Special Considerations:
  • Load testing should be performed on a dedicated machine or at a dedicated time. This permits full control and accurate measurement.
  • The databases used for load testing should be either actual size, or scaled equally.

3.1.7 Stress Testing

This section is not applicable to test of the architectural prototype.

3.1.8 Volume Testing

This section is not applicable to test of the architectural prototype.

3.1.9 Security and Access Control Testing

Security and Access Control Testing focus on two key areas of security:

– Application security, including access to the Data or Business Functions, and
– System Security, including logging into / remote access to the system.

Application security ensures that, based upon the desired security, users are restricted to specific functions or are limited in the data that is available to them. For example, everyone may be permitted to enter data and create new accounts, but only managers can delete them. If there is security at the data level, testing ensures that user “type” one can see all customer information, including financial data, however, user two only sees the demographic data for the same client.

System security ensures that only those users granted access to the system are capable of accessing the applications and only through the appropriate gateways.

Test Objective: Function / Data Security: Verify that user can access only those functions / data for which their user type is provided permissions.System Security: Verify that only those users with access to the system and application(s) are permitted to access them.
Technique:
  • Function / Data Security: Identify and list each user type and the functions / data each type has permissions for.
  • Create tests for each user type and verify permission by creating transactions specific to each user type.
  • Modify user type and re-run tests for same users. In each case verify those additional functions / data are correctly available or denied.
  • System Access (see special considerations below)
Completion Criteria: For each known user type the appropriate function / data are available and all transactions function as expected and run in prior Application Function tests
Special Considerations:
  • Access to the system must be reviewed / discussed with the appropriate network or systems administrator. This testing may not be required as it maybe a function of network or systems administration.

3.1.10 Failover and Recovery Testing

This section is not applicable to test of the architectural prototype.

3.1.11 Configuration Testing

Configuration testing verifies operation of the software on different software and hardware configurations. In most production environments, the particular hardware specifications for the client workstations, network connections and database servers vary. Client workstations may have different software loaded (e.g. applications, drivers, etc.) and at any one time many different combinations may be active and using different resources.

Test Objective: Validate and verify that the client Applications function properly on the prescribed client workstations.
Technique:
  • Use Integration and System Test scripts
  • Open / close various PC applications, either as part of the test or prior to the start of the test.
  • Execute selected transactions to simulate user activities into and out of various PC applications.
  • Repeat the above process, minimizing the available conventional memory on the client.
Completion Criteria: For each combination of the Prototype and PC application, transactions are successfully completed without failure.
pecial Considerations:
  • What PC Applications are available, accessible on the clients?
  • What applications are typically used?
  • What data are the applications running (i.e. large spreadsheet opened in Excel, 100 page document in Word).
  • The entire systems, network servers, databases, etc. should also be documented as part of this test.

 

3.1.12 Installation Testing

This section is not applicable to test of the C-Registration architectural prototype.

3.2 ToolsThe following tools will be employed for testing of the architectural prototype:

Tool

Version

Test Management Rational RequisiteProRational Unified Process TBD
Test Design Rational Rose TBD
Defect Tracking Rational ClearQuest TBD
Functional Testing Rational Robot TBD
Performance Testing Rational Visual Quantify TBD
Test Coverage Monitor or Profiler Rational Visual PureCoverage TBD
Other Test Tools Rational PurifyRational TestFactory TBD
Project Management Microsoft ProjectMicrosoft Word

Microsoft Excel

TBD
DBMS tools TBD TBD

 4.    Resources

This section presents the recommended resources for testing the C-Registration architectural prototype, their main responsibilities, and their knowledge or skill set.

4.1 RolesThis table shows the staffing assumptions for the test of the Prototype.

Human Resources

Role

Minimum Resources Recommended

(number of workers allocated full-time)

Specific Responsibilities/Comments

Test Manager 1 – Kerry Stone Provides management oversightResponsibilities:

  • Provide technical direction
  • Acquire appropriate resources
  • Management reporting
Test Designer Margaret CoxCarol Smith Identifies, prioritizes, and implements test casesResponsibilities:

  • Generate test plan
  • Generate Test Suite
  • Evaluate effectiveness of test effort
System Tester Carol Smith Executes the testsResponsibilities:

  • Execute tests
  • Log results
  • Recover from errors
  • Document defects
Test System Administrator Simon Jones Ensures test environment and assets are managed and maintained.Responsibilities:

  • Administer test management system
  • Install / manage worker access to test systems
Database Administration / Database Manager Margaret Cox Ensures test data (database) environment and assets are managed and maintained.Responsibilities:

  • Administer test data (database)
Designer Margaret Cox Identifies and defines the operations, attributes, and associations of the test classesResponsibilities:

  • Identifies and defines the test class(es)
  • Identifies and defines the test packages
Implementer Margaret Cox Implements and unit tests the test classes and test packagesResponsibilities:

  • Creates the test classes and packages implemented in the Test Suite.

4.2 System

The following table sets forth the system resources for the testing the C-Registration prototype.

System Resources

Resource

Name / Type / Serial No.

Wylie College Server Serial No: X179773562b
Course Catalog Database Version Id: CCDB-080885
Billing System Version Id: BSSS-88335
Client Test PC’s
3 Remote PCs (with internet access) Serial No: A8339223Serial No: B9334022

Serial No: B9332544

3 Local PCs (connected via LAN) Serial No: R3322411 (Registrar’s)Serial No: A8832234 (IT Lab)

Serial No: W4592233 (IT Lab)

Test Repository
Wylie College Server Serial No: X179773562b
Test Development PC’s – 6 Serial No: A8888222Serial No: R3322435

Serial No: I88323423

Serial No: B0980988

Serial No: R3333223

Serial No: Y7289732

 

 

 5.    Project Milestones

Testing of the C-Registration Architectural Prototype incorporates test activities for each of the test efforts identified in the previous sections. Separate project milestones are identified to communicate project status and accomplishments.

Refer to the Software Development Plan [13] and the E1 Iteration Plan [14] for the overall phase or master project schedule.

Milestone Task Effort (pd) Start Date End Date
Prototype Test Planning 2 March 12 March 15
Prototype Test Design 3 March 15 March 18
Prototype Test Development 4 March 19 March 23
Prototype Test Execution 3 March 24 March 26
Prototype Test Evaluation 1 March 29 March 29

 

6.    DeliverablesThe deliverables of the test activities as defined in this Test Plan are outlined in the table below.

Deliverable Owner Review / Distribution Due Date
Test Plan K. Stone Senior Project Mgmt Team March 15
Test Environment S. Jones March 18
Test Suite C. Smith and M. Cox Internal Peer Review March 23
Test Data Sets M. Cox Internal Peer Review March 23
Test Scripts M. Cox Internal Peer Review March 23
Test Scripts M. Cox March 23
Test Stubs, Drivers M. Cox March 23
Test Defect Reports C. Smith Senior Project Mgmt Team March 26
Test Results C. Smith March 26
Test Evaluation Report C. Smith Senior Project Mgmt Team March 29

 

6.1 Test SuiteThe Test Suite will define all the test cases and the test scripts which are associated with each test case.

6.2 Test LogsIt is planned to use RequisitePro to identify the test cases and to track the status of each test case. The test results will be summarized in RequisitePro as untested, passed, conditional pass, or failed. In summary, RequisitePro will be setup to support the following attributes for each test case, as defined in the Requirements Attributes Guidelines [17]:

  • Test status
  • Build Number
  • Tested By
  • Date Tested
  • Test Notes

It will be the responsibility of the System Tester to update the test status in RequisitePro.

Test results will be retained under Configuration Control.

6.3 Defect ReportsRational ClearQuest will be used for logging and tracking individual defects.

7.    Project Tasks

Below are the test related tasks for testing the C-Registration Architectural Prototype:

Plan Test

Identify Requirements for Test

Assess Risk

Develop Test Strategy

Identify Test Resources

Create Schedule

Generate Test Plan

Design Test

Workload Analysis (not applicable for Prototype)

Develop Test Suite

Identify and Describe Test Cases

Identify and Structure Test Scripts

Review and Access Test Coverage

Implement Test

Setup Test Environment

Record or Program Test Scripts

Develop Test Stubs and Drivers

Identify Test-Specific functionality in the design and implementation model

Establish External Data sets

Execute Test

Execute Test Scripts

Evaluate Execution of Test

Recover from Halted Test

Verify the results

Investigate Unexpected Results

Log Defects

Evaluate Test

Evaluate Test-Case Coverage

Evaluate Code Coverage

Analyze Defects

Determine if Test Completion Criteria and Success Criteria have been achieved

Create Test Evaluation Report

 

Course Registration Project Web Example
Version 2001.02