Objective
The main objective of this article is to set some guidelines to guide the automation process in any project.
This document will present the automation process sequentially from the beginning (ROI for the project, schedule and estimation, execution, and maintenance)
for any further help or to get the template please contact me Ahmed.Ibrahim@Yahoo.com
Should we automate the testing?
First of all we must answer this question , we will doing that by conducting ROI on the project then let the upper management to decide should we automate it or not?
- Prepare for ROI
There are some questions must be answered before doing the ROI:
- What type of application are you automating? (Java , .Net , HTML)
- Number of test cases executed per release?
- Estimated cost to automate each test case?
- Number of testers per release needed for manual execution?
- Number of releases per year?
- Days of testing per release?
- Average tester hourly rate?
- Number of Rational Functional Tester Licenses needed?
http://www-01.ibm.com/software/rational/offerings/testing/roi/tool/ROI_Rational.html
The upper management must agree on ROI analysis result in order to resume the automation project, and must be updated regularly with the measurement and results from the automation.
- Target test types to be automated (Regression, Smoke, System test)?
- What is in scope and out of scope modules?
- List of all selected "Test cases" to be automated.
- EstimationThe following are factors impact on the estimation for the project:
# | Type | Factor | Impact | Remarks |
1 | Framework | Availability | High | Good framework makes your scripting, debugging and maintenance easier. Do understand that framework needs continuous updating across the script development. |
2 | Application | Repeat functionality | High | It is quite easier to automate incase the functionality repeats across the application (Recommend to use keyword driven in such cases, as you do not end up in writing more action/verification based methods). If NOT, then the effort of building libraries and/or scripts is more linear in nature. |
3 | Project | Test Scope | High | If the complexity of application as well as the test scope is complex in nature, then it would consume huge efforts to automate each test case. |
4 | Test tool | Support to AUT | Medium | The test tool to be used may not support some application functionality and may cause overhead. You may find it more difficult to get started with open source scripting and/or tools |
5 | Application | Custom Objects | Medium | The number of custom objects in the automation scope matters as it becomes overhead for the test automation team to built and maintain the libraries for them. |
6 | Scripter | Skills | Medium | This costs project. The right skill packages of the scripter are very essential for any good test automation. If the customer NOT willing to provide the leverage on the estimate for this factor, do NOT forget to add the learning curve cost to the overall time. |
- While estimate the TCs : the Estimator must be sure that he take into his consideration the following aspects for each test case
SUB COMPONENT
Estimated Efforts
Remarks
Simple
Medium
Complex
Pre–Script Development
Test Case execution (Manual)
0.5
1
2
For 1 iteration (assuming scripter knows navigation)
Test data selection
1
2
3
For one data set (valid/invalid/erratic kind)
Script Template creation
Can use script template generation utility to avoid this
Identify the required reusable (Design the TC before start)
Assuming proper reusable traceability matrix presence
Script Development
Application map creation
Assuming the no of objects = number of actions
Base scripting
Normally all these go hand-in-hand. Separated for analysis & reasoning.
Add error/exception handling
Implement framework elements
Script Execution
Script execution
For n iterations (~ average iteration count)
Verification & Reporting
Assuming there will minimal defect reporting.
Total Effort per script
15
30
50
- Test Schedule and Resources planning
- Establish VSS environment to put test automation scripts under it
- Test Design
- Design every test case by defining the global functions to be used
- Following Design Template
- Design every test case by defining the global functions to be used
- Coding Standards
- Naming conventions
- Script naming conventions
- Result naming conventions
- Report naming conventions
- Execution log design
- Script naming conventions
- Script, Result and Report Repository
- Location for the repository
- Repository access right
- Location for the repository
- Test Automation environment details
- Software require
- Hardware require
- Software require
- Test team roles and responsibilities
Role | Responsibilities |
Automation Project Sponsor | Approve project ROI, handle major issues related to automation project development, and approve on required resources |
Automation Project Manager |
|
Test Automation Tem Leader |
|
Test Automation Designer | |
Test Automation Developer |
|
Test Automation Officer |
|
- Test team training requirements
Automation Process
Design Phase:
1-Roles and Responsibilities
Designer
- Grouping similar test cases.
- Preparing question lists for every test case to discuss with the analyst.
- Conducting Knowledge Transfer Meeting (KTM) with the analyst for certain set of groups according to analyst specialization.
- Refine the test case design with the result of the KTM.
- Complete the design document for each group of test case
- Define Existing function for every Group of test cases
- Define Data pools for every function
- Define Script Type For Every function
- Define Data and Data Type input for every function
- Define the verification point for every test case
- Conduct a peer review on other designers
- Conduct a technical review for the coding against the design
- Define Existing function for every Group of test cases
Analyst:
- Attend Knowledge Transfer Meeting with the designer.
- Provide more detail for any ambiguous steps or calculations in the test case.
2-Entrance Criteria
For Existing test cases:
The entrance criterion for the design phase is a valid and reviewed test case and categorized by group according to the business
For Updated Test cases:
The entrance criterion for the design phase is any updates done on the base lined test cases.
3-Input
- The test cases which are reviewed by the analyst and Base lined
- TCTM
4-Tasks
4.1 Requests for Checkout Test Cases
Inform the configuration controller to check out desired test cases by mail
4.2 Create or Update Design Document
To create the design document from scratch or update it if exist Please see the design template
.\DesignTemplate.doc
4.3 Update Tractability Matrix
The traceability matrixes which bind every test case with design document with developed script please see the Traceability Matrix:
.\Automation_TM.doc
4.4 help the developer to achieve high level of test case understanding
After studying the test cases and conducting the knowledge transfer meeting with the analyst, the designer must be able to clarify any ambiguity in the test case to the developer to help him to achieve a quality code
4.5 Conduct Reviews
4.5.1 Peer Review
- Conduct a peer review for other designer on the design document as per quality plan.
4.5.2 Business Review
- For every developed script, the designer must re execute the script many times to ensure the start status and the end status of the script
4.5.3 Technical Review
- Review the code against the Automation Code Standard Document.
- Review all types of script that the developers employ it in the code.
- Review all Data pools contents or any other data retrieval method in the code.
4.5.4 Log Review
- Review that the script log to be clear for the executer
5-Output
5.1 Questionnaire Document
Prepared by the designer to discuss it with the analyst in the KTM –embedded in the design document -
5.2 Design Document
For every set of test cases (Test Case Group)
5.3 Reviews Documents
For the above mentioned reviews
5.4 Updated Traceability Matrix
By the end of reviewing the design document x
6-Exit Criteria
For each test case, the design end is reached when the designed test case has been already tested, reviewed and base lined.
Development Phase:
1-Roles and Responsibilities
Developer:
- Build the script for every test case upon the design document.
- Create required data pool as the design document.
- Conduct a unit test for the developed script.
Designer:
- Technical consultation for every group of test cases.
- Review the developed script as mentioned in the design phase section.
2-Entrance Criteria
Based line the design document will trigger this process to start.
3-Input
Traceability Matrix: to be updated by developed script.
Design Document: to be followed by the developer.
Maintenance Matrixes:
- Business Function /Sub routine Matrix
The purpose of this function to illustrate which subroutine used in which business function
- Test Case\ items Matrix
The purpose of this function to define which test case will be affected by changing certain item
4-Tasks
4.1 Develop the test case script
According to the design document the developer must develop the required scripts and required data pools according to the coding standard
Please see the coding standard at the path:
Put the link here.
4.2 Conduct a unit test for the developed scripts
4.3 Update Maintenance Matrixes
4.3.1 Traceability Matrix
4.3.2 Business Function /Sub routine Matrix
4.3.3 Test Case\ items Matrix
4.4 Conduct a unit test for the developed scripts
5-Output
- Developed Script
- Updated Traceability Matrix
- Updated Maintenance Matrixes
6-Exit Criteria
Check in the scripts in the source safe tool.
No comments:
Post a Comment