Systems and methods for lifecycle management of automated testing are disclosed. In one embodiment, a method includes processing multiple manual test cases for an application under test, associating a set of reusable test scripts to the manual test cases, where the set of reusable test scripts is selected from a library of reusable test scripts, and executing the set of reusable test scripts for the application under test using an automated testing tool associated with the set of reusable test scripts.
|
15. A method for lifecycle management of automated testing, comprising:
processing a plurality of manual test cases for an application under test;
associating a set of reusable test scripts to the plurality of manual test cases, wherein the set of reusable test scripts is selected from a library of reusable test scripts;
executing the set of reusable test scripts for the application under test using an automated testing tool associated with the set of reusable test scripts;
displaying automated testing projects which include the automated testing of the application under test in a hierarchical tree view; and
displaying a return on investment (ROI) for the each automated testing project.
1. A method for lifecycle management of automated testing, comprising:
processing a plurality of manual test cases for an application under test;
associating a set of reusable test scripts to the plurality of manual test cases, wherein the set of reusable test scripts is selected from a library of reusable test scripts, wherein the library of reusable test scripts is accessed for an automated testing tool when the automated testing tool is selected from a number of licensed automated testing tools;
executing the set of reusable test scripts for the application under test using the automated testing tool associated with the set of reusable test scripts;
displaying automated testing projects which include the automated testing of the application under test; and
displaying a return on investment (ROI) for each of the automated testing projects.
2. The method of
3. The method of
4. The method of
5. The method of
6. The method of
7. The method of
8. The method of
9. The method of
10. The method of
11. The method of
0. 12. A method for lifecycle management of automated testing, comprising:
processing a plurality of manual test cases for an application under test;
associating a set of reusable test scripts to the plurality of manual test cases, wherein the set of reusable test scripts is selected from a library of reusable test scripts, wherein the library of reusable test scripts is in multiple levels for easy maintenance of the reusable test scripts; and
executing the set of reusable test scripts for the application under test using an automated testing tool associated with the set of reusable test scripts.
0. 13. The method of
0. 14. The method of
0. 16. A method for lifecycle management of automated testing, comprising:
presenting a guideline to generate a plurality of manual test cases for an application under test;
accessing a library of reusable test scripts for an automated testing tool to select a set of reusable test scripts which correspond to the plurality of manual test cases when the automated testing tool is selected from a number of licensed automated testing tools, wherein the library of reusable test scripts is in multiple levels for easy maintenance of the reusable test scripts;
setting respective parameters for the set of reusable test scripts; and
executing the set of reusable test scripts for the application under test using the automated testing tool.
0. 17. The method of
0. 18. A non-transitory computer readable medium for lifecycle management of automated testing having instructions that, when executed by a computer, cause the computer to perform a method comprising:
processing a plurality of manual test cases for an application under test;
associating a set of reusable test scripts to the plurality of manual test cases, wherein the set of reusable test scripts is selected from a library of reusable test scripts, wherein the library of reusable test scripts is in multiple levels for easy maintenance of the reusable test scripts; and
executing the set of reusable test scripts for the application under test using the automated testing tool associated with the set of reusable test scripts.
0. 19. A system embodied on a non-transitory computer-readable storage medium for lifecycle management of automated testing, the system comprising:
an administration module for performing administrative functions;
a report module for reporting on quality of automated testing projects and application under tests (AUT);
a project management module for centrally allocating available resources to the automated testing projects and managing progress of the automated testing projects;
a set of reusable test scripts comprising component codes used to create an automated test scenario of a plurality of manual test cases, wherein the set of reusable test scripts is selected from a library of reusable test scripts, and wherein the library of reusable test scripts is in multiple levels for easy maintenance of the reusable test scripts;
a requirement module for capturing technical requirements needed for the automated testing;
an analysis module for analyzing a user's responses to the technical requirements from the requirement module;
a design module for maintaining the set of reusable test scripts used for the automated testing;
a development module for building a test scenario for an application under test by associating the set of reusable test scripts to the plurality of manual test cases; and
an execution module for executing the test scenario for the application under test using a licensed automated testing tool associated with the set of reusable test scripts.
0. 20. The method of claim 1, wherein displaying a return on investment (ROI) for each of the automated testing projects comprises:
displaying the return on investment (ROI) for a plurality of the automated testing projects in a single report.
0. 21. The method of claim 20, wherein the return on investment (ROI) for the plurality of the automated testing projects are displayed via a graphical user interface on a display screen.
0. 22. The method of claim 21, wherein the plurality of manual test cases for the application under test are determined using a graphical user interface user input.
0. 23. The method of claim 15, wherein displaying a return on investment (ROI) for each of the automated testing projects comprises:
displaying the return on investment (ROI) for a plurality of the automated testing projects in a single report.
0. 24. The method of claim 23, wherein the return on investment (ROI) for the plurality of the automated testing projects are displayed via a graphical user interface on a display screen.
0. 25. The method of claim 24, wherein the plurality of manual test cases for the application under test are determined using a graphical user interface user input.
|
This application is a reissue application of U.S. Pat. No. 8,347,147, issued on Jan. 1, 2013, from U.S. patent application Ser. No. 12/399,982, filed on Mar. 9, 2009, all of which are incorporated herein by reference in their entirety.
Embodiments of the present invention relate to the field of automated testing. More particularly, embodiments of the present invention relate to lifecycle management of automated testing.
Software needs to be tested before it is delivered. For example, several features of an application under test (AUT) may be manually executed, and the results may be compared with their expected outcomes. Although the application can be tested manually, the recent trend is moving toward automated testing. Commonly, automated testing involves automating a manual process already in place that uses a formalized testing process. Record and playback features of conventional automated testing tools (e.g., HP QTP®, IBM RFT®, etc.) may capture and record the user's actions or manual testing steps to generated test scripts, which may be used later for automatic testing of the application under test.
However, as an application changes to adopt new features or functionalities, the test scripts may need to be updated or rewritten from scratch, thus ensuing in high maintenance costs. As for the maintenance of the test scripts, it has become harder to acquire test automation experts due to growing demands and increasing complexities in applications in general. Furthermore, as test automation projects for an organization or company spread across different geographical locations, business units, and/or various domains, it has become even more difficult to manage the test automation projects using the conventional automated testing tools.
Systems and methods of lifecycle management of automated testing are disclosed. In one aspect, a method for lifecycle management of automated testing comprises processing multiple manual test cases for an application under test, associating a set of reusable test scripts to the manual test cases, where the set of reusable test scripts is selected from a library of reusable test scripts, and executing the set of reusable test scripts for the application under test using an automated testing tool associated with the set of reusable test scripts.
In another aspect, a method for lifecycle management of automated testing comprises presenting a guideline to generate multiple manual test cases for an application under test, accessing a library of reusable test scripts for an automated testing tool to select a set of reusable test scripts which correspond to the manual test cases from the library when the automated testing tool is selected from a number of licensed automated testing tools, and setting respective parameters for the set of reusable test scripts, and executing the set of reusable test scripts for the application under test using the automated testing tool.
The methods disclosed herein may be implemented in any means for achieving various aspects, and may be executed in a form of a machine readable medium embodying a set of instructions that, when executed by a machine, cause the machine to perform any of the operations disclosed herein. Other features will be apparent from the accompanying drawings and from the detailed description that follows.
Example embodiments are illustrated by way of example and not limitation in the figures of the accompanying drawings, in which like references indicate similar elements and in which:
Other features of the present embodiments will be apparent from the accompanying drawings and from the detailed description that follows.
Systems and methods of lifecycle management of automated testing are disclosed. Embodiments of the present invention include test automation lifecycle management features and a guided engineering technique at each stage of test automation using reusable test scripts. Thus, the systems and methods maximize return on investment, ensure cross project reusability, empower non-automation experts to create automation test suites, ensure uniformity in automation approach across the organization, and/or provide a set of guidelines and best practices for the test automation.
In the following detailed description of the embodiments of the invention, reference is made to the accompanying drawings that form a part hereof, and in which are shown by way of illustration specific embodiments in which the invention may be practiced. These embodiments are described in sufficient detail to enable those skilled in the art to practice the invention, and it is to be understood that other embodiments may be utilized and that changes may be made without departing from the scope of the present invention. The following detailed description is, therefore, not to be taken in a limiting sense, and the scope of the present invention is defined only by the appended claims.
The administration module 102 may be used to perform administrative functions. For example, it can be used to maintain records for employees, control the scheduling of automated testing and resources, and/or produce management and operational reports. The report module 104 may be used to report the quality of ongoing or completed automated testing projects and/or the qualities of application under tests (AUT). The project management module 106 may be used to centrally allocate available resources (e.g., experts, licensed automated testing tools, etc.) to one or more automated testing projects and manage their progresses. The reusable test scripts 108 may include component codes which can be readily used or need some modifications to create an automated test scenario of multiple test cases. It is appreciated that a test case describes a test that needs to be run on the application under test to verify that the application under test runs as expected.
The system 100 also comes with in-built guidance at every stage of automation which is realized by the requirement module 110, the analysis module 112, the design module 114, the development module 116, and the execution module 118. The guideline may offer the best practices of test automation. The requirement module 110 may be used to capture various types of technical requirements needed for test automation. The analysis module 112 may be used to analyze a user's responses to the technical requirements from the requirement module 110. The design module 114 may be used to maintain reusable test scripts used for automated testing. The development module 116 may be used to build a test scenario by associating some of the reusable test scripts 108 to test cases used to build the test scenario. The execution module 118 may be used to execute the test scenario using a licensed automated testing tool (e.g., HP QTP®, IBM RFT®, etc.).
In one embodiment, a method for lifecycle management of automated testing comprises presenting a guideline across the automated testing modules which includes the requirement module 110, the analysis module 112, the design module 114, the development module 116, and the execution module 118, to generate multiple manual test cases for an application under test. The method also comprises accessing a library of reusable test scripts for an automated testing tool to select a set of reusable test scripts which correspond to the manual test cases when the automated testing tool is selected from a number of licensed automated testing tools. The method further comprises setting respective parameters for the set of reusable test scripts, and executing the set of reusable test scripts for the application under test using the automated testing tool.
One or more questionnaire items in the environment 204 solicit the user's responses on the environment (e.g., platform support requirements 214, OS/browser/application type requirements 216, lingual support requirements 218, etc.) in which the test is expected to run. The standard 206 solicits the user's responses on the requirements for maintenance (e.g., maintain from multiple places) and execution (e.g., execute locally or from a remote location). The time/resources 208 may solicit the user's responses on available licenses, skill levels of people, and/or organization of the test automation project. The integration 210 may solicit the user's responses on the project's integration with various entities. It is appreciated that there could me more items (e.g., others 212) on the technical requirements. As will be illustrated in detail in
In one exemplary implementation, the libraries 400 may be in multiple levels or layers. For example, the libraries 400 may comprise five levels—core framework functions 404, standard window functions 406, windows specific functions 408, entity functions 410, and application level functions 412. As illustrated in
With the layered structure of the libraries 400, the user may identify a layer or level where modification to a particular reusable test script needs to be made. For instance, if more fundamental changes to test scripts need to be made, reusable test scripts at the core frame work functions 404 may be modified. Additionally, the reusable test scripts may be divided into two sections, one that does not require any GUI application (e.g., business flow testing operations) and the other that require one or more GUI applications (e.g., functions that interact with GUI). This design approach may minimize changes or modifications to the reusable test scripts for automated testing projects, thus reducing the maintenance efforts and costs of the testing.
In
For example, a chief information office (CIO) 802 may appoint managers 804 (e.g., automation manager 1—division A, automation manager 2—division B. automation manager 3—division C) for multiple test automation tasks. Each manager then assigns tasks for the project to one or more of the people 806 according to their expertise. In
Then, the task of the develop test cases 830 is assigned to a manual tester/business user 832, and a manual tester 836 may be assigned to perform the task of the maintain & execute 834 using an automation scripting tool 838. The same tester 836 or another tester 842 may be assigned to perform a task of the report 840. Thus, the lifecycle management system 800 may define ongoing automation projects in a single console in a hierarchical tree view. In addition, it may provide a standard list of automation tasks that can be assigned, tracked, or reassigned by project managers for single or multiple projects. Furthermore, the lifecycle management system 800 may encompass a facility to assign specific users to certain tasks, and define their role requirements and privileges. Moreover, the lifecycle management system 800 may have in-built reports for test automation status and application quality reports which can be viewed any location.
In operation 904, a set of reusable test scripts is associated to the manual test cases, where the set of reusable test scripts is selected from a library of reusable test scripts. In one embodiment, the library of reusable test scripts for the automated testing tool may be accessed when the automated testing tool is selected from a number of licensed automated testing tools. In addition, respective parameters for the set of reusable test scripts may be set. Furthermore, the library of reusable test scripts may be in multiple levels for easy maintenance of the reusable test scripts, where the multiple levels may include a field level, a window level, a module level, and an application functionality level.
In operation 906, the set of reusable test scripts (e.g., or a test scenario) for the application under test is executed using an automated testing tool associated with the set of reusable test script, if the set of reusable test scripts at the field level is generated using the automated testing tool.
It is appreciated that the methods disclosed herein may be executed in a form of a machine readable medium embodying a set of instructions that, when executed by a machine, cause the machine to perform any of the operations disclosed herein.
It is appreciated that the methods disclosed herein may be executed in a form of a machine readable medium embodying a set of instructions that, when executed by a machine, cause the machine to perform any of the operations disclosed herein.
Although the present embodiments have been described with reference to specific example embodiments, it will be evident that various modifications and changes may be made to these embodiments without departing from the broader spirit and scope of the various embodiments. For example, the various devices, modules, analyzers, generators, etc. described herein may be enabled and operated using hardware circuitry (e.g., CMOS based logic circuitry), firmware, software and/or any combination of hardware, firmware, and/or software (e.g., embodied in a machine readable medium). For example, the various electrical structure and methods may be embodied using transistors, logic gates, and electrical circuits (e.g., application specific integrated ASIC circuitry).
Adiyapatham, Pandiyan, Devarajan, Vivek, Singhania, Sfoorti, Joshwa, Rooth, Krishna M., Mukil, Murthy S.N., Shashank, Welankar, Shashank Shripad, Gupta, Upasana
Patent | Priority | Assignee | Title |
Patent | Priority | Assignee | Title |
6694509, | Dec 28 1999 | GE Medical Systems Global Technology Company, LLC | Automated regression testing of workstation software |
7296188, | Jul 11 2002 | GOOGLE LLC | Formal test case definitions |
7493521, | Jun 23 2005 | NetApp, Inc | Apparatus and method for estimating the testing proficiency of a software test according to EMS messages extracted from a code base |
7895565, | Mar 15 2006 | JP Morgan Chase Bank, N.A.; JPMORGAN CHASE BANK, N A | Integrated system and method for validating the functionality and performance of software applications |
8615738, | Jul 16 2004 | International Business Machines Corporation | System and method for software product test modularization |
20040034543, | |||
20040107415, | |||
20050166094, | |||
20060123389, | |||
20060253742, | |||
20070006038, | |||
20080222454, | |||
20080222608, | |||
20090249297, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Feb 05 2009 | ADIYAPATHAM, PANDIYAN | WIPRO LIMITED | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 045171 | /0469 | |
Feb 05 2009 | DEVARAJAN, VIVEK | WIPRO LIMITED | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 045171 | /0469 | |
Feb 05 2009 | SINGHANIA, SFOORTI | WIPRO LIMITED | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 045171 | /0469 | |
Feb 05 2009 | JOSHWA, ROOTH | WIPRO LIMITED | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 045171 | /0469 | |
Feb 05 2009 | MURTHY S N , SHASHANK | WIPRO LIMITED | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 045171 | /0469 | |
Feb 19 2009 | KRISHNA M , MUKIL | WIPRO LIMITED | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 045171 | /0469 | |
Oct 06 2014 | GUPTA, UPASANA | WIPRO LIMITED | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 045171 | /0469 | |
Mar 17 2015 | WELANKAR, SHASHANK SHRIPAD | WIPRO LIMITED | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 045171 | /0469 | |
Jul 16 2015 | WIPRO LIMITED | (assignment on the face of the patent) | / |
Date | Maintenance Fee Events |
Jun 18 2020 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Jun 19 2024 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
May 15 2021 | 4 years fee payment window open |
Nov 15 2021 | 6 months grace period start (w surcharge) |
May 15 2022 | patent expiry (for year 4) |
May 15 2024 | 2 years to revive unintentionally abandoned end. (for year 4) |
May 15 2025 | 8 years fee payment window open |
Nov 15 2025 | 6 months grace period start (w surcharge) |
May 15 2026 | patent expiry (for year 8) |
May 15 2028 | 2 years to revive unintentionally abandoned end. (for year 8) |
May 15 2029 | 12 years fee payment window open |
Nov 15 2029 | 6 months grace period start (w surcharge) |
May 15 2030 | patent expiry (for year 12) |
May 15 2032 | 2 years to revive unintentionally abandoned end. (for year 12) |