Paper Sasanur S S Ijaistmay 8165
Paper Sasanur S S Ijaistmay 8165
Paper Sasanur S S Ijaistmay 8165
1, July 2013
Test Plan and overall test approach for the Testing Project. This includes Test Strategy, Test methodologies, Risk Mitigation Plan, Traceability, Resources required, and Estimated schedule.
. Index terms UltrasonicSensor, Microcontroller, StepperMotor.
Performance tests derived from nonfunctional requirements are developed from the nonfunctional requirements in the RAD. Structured (unit/white box) tests are generated from the OOD (Object Design Document). The specific tests are developed from the OOD component diagram of each of the components. Integration tests are developed from the SDD (System/Architecture Design Document). The integration tests generally come from the overall package diagram describing the architecture of the system. The architecture is also used to help in determining the integration test approach. The test environment (hardware/software) is also derived from the SDD. A visualization of the relationships to the other documents can be seen in the diagram below.
I. INTRODUCTION The goal is to provide a framework that can be used by managers and testers to plan and execute the necessary tests in a timely and cost-effective manner. 1.1 Test objectives The objective of the test suite is to provide adequate coverage metrics, requirements validation, and system quality data such that sufficient data is provided for those making the decision to release. 1.2 Extent of tests The tests referenced herein are written to validate use cases, requirements (both functional and non-functional), system architecture. The structured tests to validate the system architecture will be run next as the system is integrated in bottom-up fashion during integration test. II. RELATIONSHIPS TO DOCUMENTS Black box tests relating to use cases are developed from the use case diagram(s) in the RAD (requirements analysis document). Black box tests derived from functional requirements are developed from the requirements lists in the RAD.
III TEST NAMING SCHEME The names of test cases will indicate from where they have been derived using a system of prefixes. The
following prefixes are use to denote the tests were derived from the following places. uc_ tests derived from use cases nfrs_ tests derived from nonfunctional requirements arch_ integration tests derived from the system architecture spec odd_ structured tests derived from the subsystem decomposition and component diagrams e2e_ end-to-end systemic tests that exercise the entire user scenarios If a test was derived from a particular requirement number or component design number, the test names will contain the requirement number or name after prefix followed by an underscore. After the prefix and the number or name identifier, the test name shall contain a brief, but descriptive name.
B. Integration Pass/Fail criteria Tests executed on integrated components only pass when they satisfy the signatures, constraints, and interfaces dictated by both the object design specification and the system architecture specification. This includes positive tests, negative and stress tests, boundary conditions, and tests that explicitly manipulate the interface environment (such as the physical connection to the database server). If a test exhibits a product failure to meet the objectives of both the object design specification and the system architecture specification, it will fail and a defect/issue will be reported in the defect tracking system for review by the triage team. V SYSTEM PASS/FAIL CRITERIA Tests executed against the system use the functional requirements, non-functional requirements, and use cases as the oracle to determine pass or fail. If a test exhibits a product failure to meet the objectives of any of the functional requirements, non-functional requirements, or the use cases, it will fail and a defect/issue will be reported in the defect tracking system for review by the triage team. VI APPROACH This section describes the general approach to the testing process. It discusses the reasons for the selected integration testing strategy. Different strategies are often needed to test different parts of the system. A. General Test Strategy
III. FEATURES TO BE TESTED/NOT TO BE TESTED This section, focusing on the functional aspects of testing, identifies all features and combinations of features to be tested. It also describes all those features that are not to be tested and the reasons for not testing them. IV. PASS/FAIL CRITERIA This section specifies generic pass/fail criteria for the tests covered in this plan. They are supplemented by pass/fail criteria in the test design specification. Note that fail in the IEEE standard terminology means successful test in our terminology. A. Component Pass/Fail criteria Tests executed on components only pass when they satisfy the signatures, constraints, and interfaces dictated by the Object Design Specification for that component. This includes positive tests, negative and stress tests, and boundary tests.
Unit testing and component testing will be performed on the components as they are developed. Test will be executed using test code in the form of either custom test tools or as an automated suite of tests run against the components in their individual sandboxes. Integrations tests will be performed by both the component testers as well as the system testers. The BAT and the unit test suite will be used as a regression during the integration of components. However, as the integration begins to include GUI level functionality, the tests being run will utilize significantly more manual testing and less automated testing. System test will require a new set of tools that can measure NFRS compliance, such as LoadRunner (load testing) or FindBugs (java source code analysis for security issues). Manual tests will start by validating functionality based on the requirements. Later stages of system test will include manual end-to-end tests to validate use cases. B. Integration Test Strategy
As components are being developed, unit tests will be developed to test the interfaces of the components and low-level unit tests will be developed to test the methods of the underlying classes in the components. As a prerequisite to the BAT, the automated unit test suite will be run by the build server on a per-build basis. When the unit-test suite reports failures, testing will not occur on that build until the failures have been analyzed and resolved. Testing will resume on a build that passes the automated unit test suite. B. Build Acceptance Test (BAT)
Because the components will be developed from the bottom-up and top-down, the test strategy will also align to the order of development of components. This will utilize a mostly bottom-up integration test approach, but will also involve the sandwich integration test approach. Please review the system architecture overview and the subsystem architecture in section 3. Test Case alignment with test phases
When a build is deemed ready to test by development, a build acceptance test will be run on the build. The BAT will consist of a broad but shallow set of tests to determine the overall stability of the build and decide if it is worth testing. If the BAT fails on a particular build, testing will suspend until another build is created with any BAT failure issues fixed, verified by running the BAT again. Testing will resume on a build that passes the BAT. Different build acceptance tests will be developed and used for the different test phases. Component BATs will be small and localized for each of the components. Integration BATs will vary based on the level of integration testing being performed. The System Test BAT will contain a set of tests that will utilize each of the components of the system. C. Regression Testing
On a build by build basis, major bug fixes or code changes will be reviewed to determine the effects they may have on the system. If the changes are deemed to cause a sufficient amount of risk, regression test sets of the appropriately judged size will be created and executed. A system-wide regression will also be run on the release candidate build to ensure incremental changes to the system have not altered the results of the tests that were run early in the test cycle. D, System Design Changes If at any point in time issues are submitted that require a design change to the system, all testing will be suspended. After the changes to the requirements, system architecture, and object design are made, a review and updates will be performed of the test specifications to ensure they properly align with the revised system changes. After updates are made, testing will resume. Tests in the vicinity of the change must all be rerun. A 20% regression of other tests must also be performed to ensure the changes did not adversely affect other parts of the system. VII TESTING MATERIALS (HARDWARE/SOFTWARE REQUIREMENTS) This section identifies the resources that are needed for testing. This should include the physical characteristics of the facilities, including the hardware, software, special test tools, and other resources needed (office space, etc.) to support the tests. A. Facilities required
Software required in this system is minimal. The database server needs the appropriate database (MySQL) installed, setup, and configured properly. The WebServer machine needs IIS installed the the ISS services started so that it can properly act as a WebServer machine. The client machine needs Java 1.5.0_b12 installed and properly configured with Internet Explorer 6.0 or newer. D. Special requirements
Additional tools and software may need to be purchased or otherwise acquired or reused. Such software is used to execute special tests that are best run and results recorded and analyzed by automated means. For Load testing this requires a tool like LoadRunner. For Security testing at the complied source code level this requires a tool like FindBugs. E. Test Deliverables This includes a list of documents, reports, and charts that are required to be presented to the stakeholders on a regular basis during the testing process and after its completion. Read more at Buzzle:
The team will need a lab are for the test equipment. The lab area should be approximately 400 sq ft in size, with 160 sq ft of desktop space. The lab area needs multiple power outlets on each side of the room. A table in the center of the room would also allow for easy-access test team technical discussions. B. Hardware required
nfrs_3.3.1_usability_MouseKeyboardNavigation
nfrs_3.3.1_usability_EaseOfUnderstandabilityAndUse IX TESTING SCHEDULE This section of the test plan covers responsibilities, staffing and training needs, risks and contingencies, and the test schedule. A. Test Schedule Test Phase Owner Test Plan Creation Test Manager Test Specification Creation Test Leads Test Specification Team Review Project Team Component Testing Component Testers Integration Testing Component & System Testers System Testing System Testers
B. X Responsibilities The Test Manager is responsible for the overall test plan (this document) and test resources throughout the course of the project. He needs to be assigned to the project to review the requirements analysis, system architecture design, and object design of the system. From those specifications, he will generate the Test Plan. He will also
C.
2 Test Leads - must be trained on the process being used for this project - must be trained on the test specification format utilized - must be trained on the defect/issue tracking system utilized 3 Component Testers - must know SQL and Java - must be familiar with NetBeans and Eclipse - must be skilled at unit testing, API testing, and integration testing - must be trained on the process being used for this project, the test specification format utilized, and the defect/issue tracking system utilized 4 System Testers - must know how to use Load testing & Stress testing automation tools (such as LoadRunner) - must be experienced in system testing and use case validation testing - must be trained on the process being used for this project. - must be trained on the test specification format utilized - must be trained on the defect/issue tracking system utilized XI RISKS AND CONTINGENCIES MATRIX
Risk Unable to acquir e the necess ary numbe r Probabil ity 30% Risk Type Personn el Schedule Owner Test Manager Contingencies / Mitigation Approach Resources for components will be split between the existing resources. Schedule must be adjusted accordingly.