| Project: | PROJECT-NAME | 
|---|---|
| Internal Release Number: | X.Y.Z | 
| Release Audience: | General availability release Customer-specific release: CUSTOMER(S) Developer release (Internal usage only) Early access release (Controlled external
    access only) | 
| Attached Worksheets: | QA plan > Review meeting log QA plan > System test case suite QA plan > System test run log | 
| Related Documents: | LINKS-TO-RELEVANT-STANDARDS LINKS-TO-OTHER-DOCUMENTS | 
| Activity | Coverage or Frequency | Description | 
|---|---|---|
| Preconditions | Every public method Every public method in COMPONENT-NAME All public methods that modify data | We will use if-statements at the beginning of public methods to validate each argument value. This helps to document assumptions and catch invalid or malicious values before they can cause faults. | 
| Assertions | Every private method Every private method in COMPONENT-NAME All private methods that modify data | Assertions will be used to validate all arguments to private methods. Since these methods are only called from our other methods, arguments passed to them should always be valid, unless our code is defective. Assertions will also be used to test class invariants and some postconditions. | 
| Static analysis | Strict compiler warnings Automated style checking XML validation Detect common errors | We will use source code analysis tools to automatically detect errors. Style checkers will help make all of our code consistent with our coding standards. XML validation ensures that each XML document conforms to its DTD. Lint-like tools help detect common programming errors. E.g., lint, lclint/splint, jlint, checkstyle, Jcsc, PyLint, PyChecker, LinkLint, and Tidy. | 
| Buddy review | All changes to release branches All changes to COMPONENT-NAME All changes | Whenever changes must be made to code on a release branch (e.g., to prepare a maintenance release), the change will be reviewed by another developer before it is committed. This will help ensure that fixes do not introduce new defects. | 
| Review meetings | Weekly Once before release Every source file | We will hold review meetings where developers will perform formal inspections of selected code or documents. We choose to spend a small, predetermined amount of time and will try to maximize our results by carefully selecting documents for review. In the review process, we will develop and use a set of relevant checklists. | 
| Unit testing | 100% of public methods, and 75% of statements 100% of public methods 75% of statements | We will develop and maintain a unit test suite using the JUnit framework. We will consider the boundary conditions for each argument and test both sides of each boundary. Tests must be run and passed before each commit. Unit tests will also be run by the testing team. | 
| Manual system testing | 100% of UI screens and fields 100% of specified requirements | The QA team will author and maintain a detailed written suite of manual tests to test the entire system through the user interface. This plan will be detailed enough that a new team member could repeatably carry out the tests. | 
| Automated system testing | 100% of UI screens and fields 100% of specified requirements | The QA team will use a system test automation tool to author and maintain a suite of test scripts to test the entire system through the user interface. | 
| Regression testing | Run all unit tests before each commit Run all unit tests nightly Add new unit test when verifying fixes | We will adopt a policy of frequently re-running all automated tests, including those that have previously been successful. This will help catch regressions (bugs that we thought were fixed, but appear again). | 
| Load, stress, and capacity testing | Simple load testing Detailed analysis of each scalability parameter | We will use a load testing tool and/or custom scripts to simulate heavy usage of the system. Load will be defined by scalability parameters such as number of concurrent users, number of transactions per second, or number/size of data items stored/processed. We will verify that the system can handle loads within its capacity without crashing, producing incorrect results, mixing up results for distinct users, or corrupting its database. We will verify that when capacity limits are exceeded, the system safely rejects, ignores, or defers requests that it cannot handle. | 
| Beta testing | 4 current customers 40 members of our developers network 1000 members of the public | We will involve outsiders in a beta test, or early access, program. We will give beta testers directions to focus on specific features of the system. We will actively follow up with beta testers to encourage them to report issues. | 
| Instrumentation and monitoring | Monitor our ASP servers Remotely monitor customer servers | As part of our SLA, we will monitor the behavior of servers to automatically detect service outages or performance degradation. We have policies and procedures in place for failure notification, escalation, and correction. | 
| Field failure reports | Prompt users to report failures Automatically report failures | We want to understand each post-deployment system failure and actively take steps to correct the defect. The system has built-in capabilities for gathering detailed information from each system failure (e.g., error message, stack traceback, operating system version). This information will be transmitted back to us so that we may analyze it and act on it. | 
| Goal | Preconditions | Assertions | Buddy review | Review meeting | Unit testing | Manual system testing | Overall assurance | 
|---|---|---|---|---|---|---|---|
| Functionality | Medium | Medium | Medium | High | High | High | Strong | 
| Correctness | High | High | Medium | Medium | High | Medium | Strong | 
| Robustness | High | High | Medium | Medium | High | Medium | Strong | 
| Usability | None | None | None | High | None | Medium | Strong | 
| Security | Medium | None | Medium | High | None | Medium | Strong | 
| Reliability | None | Medium | Low | Medium | Medium | Medium | Weak | 
| Efficiency | None | None | Low | Medium | None | Low | At-Risk | 
| Scalability | None | None | Low | Medium | Low | Low | At-Risk | 
| Operability | None | None | None | Low | None | Low | At-Risk | 
| Maintainability | Medium | Low | Medium | High | Low | None | Weak | 
Cell values in the table above are subjective estimates of the effectiveness of each activity. This table helps to identify quality goals that are not being adequately assured.