i) Test any modifications to the system to ensure that no new problems are introduced and that the operational performance is not degraded due to the modifications.
ii) Any changes to the system after the completion of any phase of testing or after the final testing of the system must be subjected to a thorough Regression test. This is to ensure that the effects of the changes are transparent to other areas of the system and other systems that interface with the system.
iii) The project team must create test data based on predefined specifications. The original test data should come from other levels of testing and then it should be modified along with test cases.
Acceptance testing is performed on a collection of business functions in a production environment, and after the completion of functional testing. This is the final stage in the testing process before the system is accepted for operational use. It involves testing the system with data supplied by the customer or the site visitor rather than the simulated data developed as part of the testing process.
Acceptance testing often reveals errors and omissions in the system requirements definition. The requirements may not reflect the actual facilities and performance required by the user. Acceptance testing may demonstrate that the system does not exhibit the anticipated performance and functionality. This test confirms that the system is ready for production.
Running a pilot for a select set of customers helps in Acceptance testing for an e-commerce site. A survey is conducted among these site visitors on different aspects of the Web site, such as user friendliness, convenience, visual appeal, relevance, and responsiveness.
A sample of test plan and test cases on Web Testing has been added in Appendix – 3.
15 Guidelines to prepare Test Plan
15.1 Preparing Test Strategy
The test strategy should be:
· Risk based – the amount and rigour of testing at each stage corresponds to the risk of failure due to errors.
· Layered and staged – aligned with the development process, testing aims to detect different errors at each stage
· Prepared early – to allow testing to be planned, resourceful and scheduled and to identify any tool requirements
· Capable of automation – throughout the life cycle, there are opportunities for automated support, particularly in the areas of requirements testing test execution and test management.
Since the strategy is aimed at addressing the risks of a client/server development, knowledge of the risks of these projects is required.
15.2 Standard Sections of a Test Plan
A standard test plan contains different sections. Those sections with their explanations are given below:
1. Introduction
Set goals and expectations of the testing effort. Summarise the software items and software features to be tested. The purpose of each item and its history may be included.
References to the following documents, if they exist, are required in the highest-level test plan:
· · Project authorisation
· · Project plan
· · Relevant policies
· · Relevant standards
In multilevel test plans, each lower level plan must reference the next higher level plan.
1.1 Purpose
Describe the purpose of the test plan. Multiple components can be incorporated into one test plan
1.2 System Overview
This section provides an overview of the project and identifies critical and high-risk functions of the system.
1.3 Test Team Resources
The composition of the ABC Project test team is outlined within the test team profile depicted in Table 9.1. This table identifies the test team positions on the project together with the names of the personnel who will fill these positions. The duties to be performed by each person are described, and the skills of the individuals filling the positions are documented. The last two columns reflect the years of experience for each test team member with regard to total test program experience as well as years of experience with the designated test management tool for the project.
Table 9.1 Test Team Profile
Position | Name | Duties/Skills | Test Experience (years) | Test Tool Experience (years) |
| | | | |
| | | | |
2. Test Environment
2.1 Test Environment
The test environment mirrors the production environment. This section describes the hardware and software configurations that compose the system test environment. The hardware must be sufficient to ensure complete functionality of the software. Also, it should support performance analysis aimed at demonstrating field performance.
2.2 Automated Tools
List any testing tools you may want to use.
2.3 Test Data
Working in conjunction with the database group, the test team will create the test database. The test database will be populated with unclassified production data.
3. Test Program
3.1 Scope of testing
List of the features to be tested, such as particular field and expected values, etc., Identify software features to be tested. Identify the Test-Design Specification associated with each Feature
3.2 Areas beyond the scope
Identify all features and significant combinations of features, which will not be tested, and the reasons.
3.3 Test Plan Identifier
Specify a unique identifier to be used when referring to this document.
Naming Convention for Test Identifier
ABCXXYYnn
ABC - First 3 letters of the project name
XX - Type of Testing Code
For e.g.
System Testing - ST
Integration Testing -IT
Unit Testing -UT
Functional Testing - FT
YY - A particular document code/ abbreviation within the type of testing.
For e.g.
Test Plan - TP
Test Case -TC
Test Result - TR
Test Specifications - TS
Defect Reports - DR
nn - Version Serial Number
Identifier | Document | Remark |
ARCSTTP1.0 | System test Plan | MS-Word Document |
| | |
| | |
| | |
3.4 Test Item
Identify the test items including their version/revision level. Also specify characteristics of their transmittal media which impact hardware requirements or indicate the need for logical or physical transformations before testing can begin. (An example would be that the code must be placed on a production server or migrated to a special testing environment separate from the development environment.)
Supply references to the following item documentation, if it exists:
· · Requirements specification
· · Design specification
· · User guide
· · Operations guide
· · Installation guide
· · Reference any incident reports relating to the test items.
Items that are to be specifically excluded from testing may be identified.
3.5 Test Schedule
Include test milestones identified in the software project schedule as well as all item transmittal events. Define any additional test milestones needed. Estimate the time required for each testing task. Specify the schedule for each testing task and test milestone. For each testing resource (that is, facilities, tools, and staff), specify its periods of use.
3.6 Test Approach
Describe the general approach to testing software features and how this approach will ensure that these features are adequately tested. Specify the major activities, techniques, and tools, which will be used to test the described features. The description should include such detail as identification of the major testing tasks and estimation of the time required to do each one.
3.6.1 Test Coverage
(Determine the adequacy of test plan) Indicate branch or multiple location. If all the conditions are covered in test cases.
3.6.2 Fixes and Regression Testing
3.6.3 Preparation of test Specification
This contains the criteria and reference used to develop test specification. Type of testing (Black or White Box Testing is to be mentioned).
3.6.4 Pass/Fail Criteria
Specify the criteria to be used to determine whether each test item has passed or failed testing. If no basis exists for passing or failing test items, explain how such a basis could be created and what steps will be taken to do so.
3.6.5. Suspension criteria and resumption requirements
Specify the criteria used to suspend all or a portion of the testing activity on the test items associated with this plan. Specify the testing activities that must be repeated, when testing resumes.
3.6.6 Defect Tracking
To track defects, a defect workflow process has to be implemented.
3.6.7 Constraints
Identify significant constraints on testing such as test item availability, testing resource availability, and deadlines.
3.6.8 Entry and Exit Criteria
3.6.9 Test Deliverables
Identify all documents relating to the testing effort. These should include the following documents: Test Plan, Test-Design Specifications, Test-Case Specifications, Test-Procedure Specifications, Test-Item Transmittal Reports, Test Logs, Test-Incident Reports, and Test-Summary Reports.
Also identify test input/output data, test drivers, testing tools, etc.
3.6.10 Dependencies and Risk
Identify the high-risk assumptions of the test plan. Specify contingency plans for each.
3.6.11 Approvals
Specify the names and titles of all persons who must approve this plan. Provide space for the signatures and dates.
16 Amendment History
V1.0 – First Release
17 Guideline for Test Specifications
An overall plan for integration of the software and a description of specific tests are documented in the test Specification. This document contains a test plan and a test procedure, is a work product of the software process, and becomes part of the software configuration. A history of actual test results, problems or peculiarities is recorded in this document.
Sr. | Test Items | Test Condition | Expected Results | Observed Results | Remarks |
| | | | | |
| | | | | |
References
1. Kaner, Cem (1997). Improving the Maintainability of Automated Test Suites. www.kaner.com/lawst1.htm
2. Myers, Glenford J. (1978). The Art of Software Testing. John Wiley & Sons.
3. Pressman, Roger S. (5/e). Software Engineering – A practitioner’s Approach. McGraw Hill.
4. Beizer, Boris, (1995). Black Box Testing – Techniques for Functional Testing of Software and Systems. John Wiley & Sons
5. Dustin, Elfriede ; Rashka, Jeff ; Paul, John; (1999). Automated Software Testing – Introduction, Management and Performance. Addison Wesley.
Appendix – 1
List of Testing Tools:
Life-Cycle Phase | Type of Tool, | Tool Description | Tool Example |
Business Analysis Phase | Business Modeling Tool | Allow for recording definitions of user needs and automating the rapid construction of flexible, graphical, client-server applications | Oracle Designer 2000, Rational Rose |
| Configuration Management Tools | Allow for baseliningimportant data repositories | Rational ClearCase, PVCS |
| Defect Tracking Tools | Manage system life-cycle defects | TestTrack, Census, PVCS Tracker, Spyder |
| Technical Review Management | Facilitate communication, while automating technical review/inspection process | ReviewPro (Software Development Technologies) |
| Documentation Generators | Automate document generation | Rational SoDA |
| | | |
Life-Cycle | Type of Tool, | Tool Description | Tool Example |
Requirements Definition Phase | Requirements Management Tools | Manage and organize requirements; allow fortest procedure design; allow for test progress reporting | Rational Requisite Pro, QSS DOORS |
| Requirements Verifiers | Verify syntax, semantics, and testability | Aonix Validator/Req |
| Use Case Generators | Allow for creation of use cases | Rational Rose |
Life-Cycle | Type of Tool, | Tool Description | Tool Example |
Analysis and Design Phase | Database Design Tools | Provide a solution fordeveloping second- , generation enterprise client-server systems | Oracle Developer 2000, Erwin, Popkins ,Terrain byCayenne |
| Application Design Tools | Help define softwarearchitecture; allow for object-oriented analysis, modeling, design, and construction | Rational Rose, Oracle Developer 2000, Popkins, Platinum, Object Team by |
| Structure Charts and Sequence Diagrams | Help manage processes Flowcharts, | Micrografx and FlowCharter 7 |
| Test Procedure Generators | Generate test procedures from requirements or design or data and object models | Aonix Validator, StP/T from IDE, Rational TestStudio |
Life-Cycle | Type of Tool, | Tool Description | Tool Example |
Programming Phase | Syntax Checkers/ Debuggers | Allow for syntax checking and debugging capability; usually come with built-in programming language compiler | Miscellaneous language compilers (C, C++, VB, Powerbuilder) |
| Memory Leak and Runtime Error Detection Tools | Detect runtime errors and memory leaks | Rational Purify |
| Source Code Testing | Verify maintainability, Tools portability, complexity, cyclomatic complexity, and standards compliance | CodeCheck from Abraxas Software, Visual Quality from McCabe & Associates |
| Static and Dynamic Analyzers | Depict quality and structure of code | LDRA Testbed, Discover |
| Various Code Implementation Tools | Depending on the application, support code generation, among other things | PowerJ, JbuilderSilverStreamSymantec Café |
| Unit Test Tools | Automate the unit testing process | MTE from Integrisoft |
Life-Cycle | Type of Tool, | Tool Description | Tool Example |
Metrics Tools | Code (Test) Coverage Analyzers or Code Instrumentors | Identify untested code and support dynamic testing | STW/Coverage, Software Research TCAT, Rational Pure Coverage, IntegriSoft, Hindsight and EZCover |
| Usability Measurements | Provide usability testing as conducted in usability labs | ErgoLight |
Life-Cycle | Type of Tool, | Tool Description | Tool Example |
Other Testing Life-cycle Support Tools | Test Data Generators | Generate test data | TestBytes, Rational Performance Studio |
| Prototyping Tools | Allow for prototyping of applications, using programming languages like Visual Basic or using tools like Access 97 | VB, Powerbuilder |
| File Compare Utilities | Allow for searching for discrepancies between files that should be identical in content | Often part of capture/playback tools such as Rational’s Team Test, GMR Technologies’ D2K/PLUS, and Software Research's EXDIFF |
| Simulation Tools | Simulate application to measure for scalability, among other tasks | OPNET |
Life-Cycle | Type of Tool, | Tool Description | Tool Example |
Testing Phase | Test Management Tools | Allow for test management | Rational Suite TestStudio,Test Director from Mercury Interactive |
| Network Testing Tools | Allow for monitoring, measuring, testing, diagnosis of performance across the entire network | NETClarity, Applied and Computer Technology ITF |
| GUI Testing Tools-( Capture/Playback) | Allow for automated GUI tests; capture/playback tools interactions with online systems, so they may be replayed automatically | Rational Suite Test Studio, Visual Test, Mercury Interactive’s WinRunner, Segue’s Silk, STW/Regression from Software Research, Auto Scriptor Inferno, Automated Test Facility from Softbridge, QARUN from Compuware |
| Non-GUI Test Drivers | Allow for automated execution of tests for products without a graphical user interface | |
| Load/Performance Testing Tools | Allow for load/performance and stress testing | Rational Performance Studio |
| Web Testing Tools | Allow for testing of Web Applications, and so on | Segue’s Silk, , Java ParaSoft’s Jtest |
| Environment Testing | Various testing tools are on | Mercury Interactive’sXRunner, Rational’s Prevue-X |
No comments:
Post a Comment