US8381188B2 - Leveraging the relationship between object IDs and functions in diagnosing software defects during the post-deployment phase - Google Patents
Leveraging the relationship between object IDs and functions in diagnosing software defects during the post-deployment phase Download PDFInfo
- Publication number
- US8381188B2 US8381188B2 US12/631,549 US63154909A US8381188B2 US 8381188 B2 US8381188 B2 US 8381188B2 US 63154909 A US63154909 A US 63154909A US 8381188 B2 US8381188 B2 US 8381188B2
- Authority
- US
- United States
- Prior art keywords
- heat map
- defects
- uids
- software application
- accordance
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Fee Related, expires
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/36—Preventing errors by testing or debugging software
- G06F11/362—Software debugging
- G06F11/366—Software debugging using diagnostics
Definitions
- the present disclosure relates to the field of software and, more particularly, to leveraging the relationship between object IDs and functions in diagnosing software defects during the post-deployment phase.
- a support process in place to help support the end user.
- a support team in the organization accepts the support call and helps the customer depending on the type of support required. There may be different levels of support staff in the support team.
- an initial call can be accepted by a support person at the Level 0 .
- This person logs the call and tries to solve the problem at a basic level. If this person cannot help, he or she escalates the issue to the next level, typically to the Level 1 support engineer.
- the Level 1 support engineer tries to understand the problem, and tries basic configuration help.
- the problem escalates, for example, to Level 2 .
- Level 2 the typical problems addressed are related to some advanced configuration or other known issue of the software being unable to co-exist with other software products.
- the problem escalates to Level 3 if there is a defect or bug, which has to be fixed in the source code of the software application. Different organizations may have different numbers of levels. One of these levels will typically have someone responsible for fixing defects or bugs in software products.
- the person at Level 3 who has to fix defects or bugs can have the source code of the software and a change management system to help with addressing the defects. In an organization that uses multiple levels, this top level person leverages all the symptoms articulated by the lower level support people on this case before it gets to him or her. The person who has to fix defects in the source code finds the cause within the source code and fixes the source code to solve the particular problem.
- a function verification test (FVT) cycle is a period in time when most of the functionality of a software application is tested during development. This testing is typically done in iterations or cycles so that each FVT cycle catches newer defects.
- a project plan for software application development may specify that there be one or more function verification testing cycles during the development of the software product. There is an inherent gap in the software development lifecycle and process in that the data collected from the FVT phase is not reused in any other phase, especially in post-sales support.
- Various embodiments provide the usage of tools such as a change and release management tool and a function verification test tool to capture such data and render the data in a format which support teams can more easily interpret to focus in on the causality of issues more quickly. This helps post-sales/post-release support people. This particularly helps support engineers who are new to a particular application.
- tools such as a change and release management tool and a function verification test tool to capture such data and render the data in a format which support teams can more easily interpret to focus in on the causality of issues more quickly. This helps post-sales/post-release support people. This particularly helps support engineers who are new to a particular application.
- Some embodiments provide systems and methods to map a symptom of a defect against its cause in a usable format to aid a support team in diagnosing software defects.
- an object which has a defect is identified from a functional verification test or tester's report.
- a stack trace of a defect is used to determine where the defect emanated in the source code.
- Some embodiments provide creating a mapping of an Object UID versus the origin of the defect within the source code.
- the mapping is created in a spread sheet, and then a heat map generator is used to scan the spread sheet and generate a heat map to be used by a support team.
- FIG. 1 is a pictorial flow chart of an exemplary embodiment of a method for handling software defects and a data processing network or system for carrying out the method.
- FIG. 2 is a pictorial flowchart showing details of a step of the method of FIG. 1 .
- FIG. 3 is a pictorial flowchart illustrating use of a product produced by the method of FIG. 1 .
- FIG. 1 illustrates a method in accordance with various embodiments.
- a test engineer 14 captures a stack of software objects (object unique identifiers or UIDs) which were involved in the failure of a particular test 16 of a software product (application) 18 .
- objects object unique identifiers or UIDs
- a stack can be a last in, first out (LIFO) data structure.
- An object can be a component of a software program that knows how to perform certain actions and to interact with other pieces of the program.
- An object can have a set of data along with methods for manipulating that data.
- the objects described herein can be, for example, objects for graphical user interfaces.
- Object UIDs for various objects in the software 18 can be generated using the method and system described below in connection with FIG. 2 .
- the Object UIDs (which are generated from the hashing process) along with the defects are entered 20 in a change and release management (or source code management) system 22 (e.g., by the tester).
- a change and release management (CRM) or source code management (SCM) system 22 such as, for example, BugzillaTM, Rational ClearCaseTM or Rational ClearQuestTM.
- CCM change and release management
- SCM source code management
- the change management system 22 is used so that stakeholders can communicate with each other about defects that are found and the changes to the source code which will result. Change management systems are typically used during the period when a software product is being developed.
- the Object UIDs 24 , 25 , 26 etc. of objects involved in a defect are received and recorded (stored in a database) by the change and release management system 22 .
- the change and release management system 22 has a list of all Object UIDs, from the system and method of FIG. 2 , and a tester 14 indicates which UIDs were involved with a defect.
- a developer 28 who fixes 30 a defect can capture a stack trace and can use the stack trace to determine where the defect potentially emanates in the source code.
- a stack trace or stack traceback is a report of the functions instantiated by the execution of a program. It keeps track of how local variables change on each invocation of a routine as well as the values that they return.
- the developer 28 enters 32 the functions involved in a defect in the change and release management system 22 . More particularly, the change and release management system 22 receives and records (stores in memory) a list of functions 34 , 35 , 36 etc. involved in the defect.
- a heat map creator tool 38 walks all the defects and maps an exhaustive list 40 of functions in this application 18 to an exhaustive list 42 of object unique identifiers to produce a heat map 44 with function names on one axis and Object UIDs on another axis.
- the heat map creator 38 walks the defect record and creates a pheromone map from Object UID versus function. In time, more of the occurrences of links between Object UIDs and functions will result in “hotter” areas on the heat map.
- different colors are used to indicate different heat levels. For example, a bright red color may indicate a high occurrence linkage between a particular object and a particular function, a dark green color may indicate a low defect rate, and orange, yellow, and light green colors may indicate intermediate defect rates. Other colors or other graphical or tabular indications of potential problem areas can be used in other embodiments.
- the heat map 44 is then stored as an artifact along with code frozen bits (final source code) of this particular software product for later use by support people.
- the heat map 44 is a spreadsheet.
- the heat map creator 38 and the change and release management system 22 are defined by separate computer devices that are in communication with one another over a network. In other embodiments, the heat map creator 38 and the change and release management system 22 are defined by a single computer device.
- FIG. 2 illustrates a system and method for generating the list 42 of all Object UIDs 24 , 25 , 26 , etc. of FIG. 1 , in some embodiments.
- a hashing tool 46 is used to create the list 42 of object unique identifiers (UIDs) from the unique characteristics of respective objects (such as elements or objects of a graphical user interface 48 ). Any one of a variety of functional testing tools 50 can be employed to create these Object UIDs.
- the lists 42 and 40 (see FIG. 1 ) of object unique identifiers and functions are captured in the change and release management system 22 .
- the support engineer can simulate the defect in his or her own environment.
- the engineer will use the Object UID creation tool which is the hashing tool to generate the Object UID of the Graphical User object which is showing the symptom of the particular defect.
- higher level support people e.g., Level 2 and Level 3 support people
- These support people when given a support problem, can look up the heat maps and find out which are the functions that are likely candidates to have created a defect, involving the particular Object UIDS, and solve the problem faster.
- the change and release management system 22 and/or the heat map creator 38 and/or a network containing the change and release management system 22 and the heat map creator 38 has an access control, and access is given to a (post-release) customer support person. For example, it may be necessary to use a password to gain access to a network and only certain persons on the network are given permission to access the change and release management system 22 and/or the heat map creator 38 , and a customer support person is given such access.
- Embodiments of the invention can take the form of entirely hardware elements, entirely software elements or a combination containing both hardware and software elements.
- embodiments of the invention are implemented as software elements, which include but are not limited to firmware, resident software, microcode, etc.
- embodiments of the invention can take the form of a computer program product accessible from a computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system.
- a computer-usable or computer readable medium can be any apparatus that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device.
- the medium can be an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system (or apparatus or device) or a propagation medium.
- Examples of a computer-readable medium include a semiconductor or solid state memory, magnetic tape, a removable computer diskette, a random access memory (RAM), a read-only memory (ROM), a rigid magnetic disk and an optical disk.
- Current examples of optical disks include compact disk—read only memory (CD-ROM), compact disk—read/write (CD-R/W) and DVD.
- a data processing system suitable for storing and/or executing program code will include at least one processor coupled directly or indirectly to memory elements through a system bus.
- the memory elements can include local memory employed during actual execution of the program code, bulk storage, and cache memories which provide temporary storage of at least some program code in order to reduce the number of times code must be retrieved from bulk storage during execution.
- I/O devices including but not limited to keyboards, displays, pointing devices, etc.
- I/O controllers can be coupled to the system either directly or through intervening I/O controllers.
- Network adapters may also be coupled to the system to enable the data processing system to become coupled to other data processing systems or remote printers or storage devices through intervening private or public networks.
- Modems, cable modems and Ethernet cards are just a few of the currently available types of network adapters.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Hardware Design (AREA)
- Quality & Reliability (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Stored Programmes (AREA)
- Debugging And Monitoring (AREA)
Abstract
A hashing tool can be used to generate Object UIDs from a software application. The software application can be tested. A change and release management system can receive Object UIDs involved in a defect uncovered during the testing. The change and release management system can receive names of functions involved in the defect uncovered during the testing and defect fixing. A graphical representation of function names versus Object UIDs for which the defect occurred can be created.
Description
The present disclosure relates to the field of software and, more particularly, to leveraging the relationship between object IDs and functions in diagnosing software defects during the post-deployment phase.
After software is bought and used by the end user, there is typically a support process in place to help support the end user. Usually, a support team in the organization accepts the support call and helps the customer depending on the type of support required. There may be different levels of support staff in the support team.
For example, an initial call can be accepted by a support person at the Level 0. This person logs the call and tries to solve the problem at a basic level. If this person cannot help, he or she escalates the issue to the next level, typically to the Level 1 support engineer. The Level 1 support engineer tries to understand the problem, and tries basic configuration help. The problem escalates, for example, to Level 2. At Level 2 the typical problems addressed are related to some advanced configuration or other known issue of the software being unable to co-exist with other software products. The problem escalates to Level 3 if there is a defect or bug, which has to be fixed in the source code of the software application. Different organizations may have different numbers of levels. One of these levels will typically have someone responsible for fixing defects or bugs in software products.
The person at Level 3 who has to fix defects or bugs can have the source code of the software and a change management system to help with addressing the defects. In an organization that uses multiple levels, this top level person leverages all the symptoms articulated by the lower level support people on this case before it gets to him or her. The person who has to fix defects in the source code finds the cause within the source code and fixes the source code to solve the particular problem.
A function verification test (FVT) cycle is a period in time when most of the functionality of a software application is tested during development. This testing is typically done in iterations or cycles so that each FVT cycle catches newer defects. A project plan for software application development may specify that there be one or more function verification testing cycles during the development of the software product. There is an inherent gap in the software development lifecycle and process in that the data collected from the FVT phase is not reused in any other phase, especially in post-sales support.
There is a lot of information related to every defect which is reported and fixed during the function verification cycle, which can be used by support teams.
Various embodiments provide the usage of tools such as a change and release management tool and a function verification test tool to capture such data and render the data in a format which support teams can more easily interpret to focus in on the causality of issues more quickly. This helps post-sales/post-release support people. This particularly helps support engineers who are new to a particular application.
Some embodiments provide systems and methods to map a symptom of a defect against its cause in a usable format to aid a support team in diagnosing software defects. In some embodiments, an object which has a defect is identified from a functional verification test or tester's report. In some embodiments, a stack trace of a defect is used to determine where the defect emanated in the source code.
Some embodiments provide creating a mapping of an Object UID versus the origin of the defect within the source code. In some embodiments, the mapping is created in a spread sheet, and then a heat map generator is used to scan the spread sheet and generate a heat map to be used by a support team.
A stack can be a last in, first out (LIFO) data structure. An object can be a component of a software program that knows how to perform certain actions and to interact with other pieces of the program. An object can have a set of data along with methods for manipulating that data. The objects described herein can be, for example, objects for graphical user interfaces.
Object UIDs for various objects in the software 18 can be generated using the method and system described below in connection with FIG. 2 .
In the embodiments illustrated in FIG. 1 , the Object UIDs (which are generated from the hashing process) along with the defects are entered 20 in a change and release management (or source code management) system 22 (e.g., by the tester). Typically, when a software product is built, source code and defects are tracked in a change and release management (CRM) or source code management (SCM) system 22 such as, for example, Bugzilla™, Rational ClearCase™ or Rational ClearQuest™. The change management system 22 is used so that stakeholders can communicate with each other about defects that are found and the changes to the source code which will result. Change management systems are typically used during the period when a software product is being developed.
More particularly, in the illustrated embodiment, the Object UIDs 24, 25, 26 etc. of objects involved in a defect are received and recorded (stored in a database) by the change and release management system 22. In some embodiments, the change and release management system 22 has a list of all Object UIDs, from the system and method of FIG. 2 , and a tester 14 indicates which UIDs were involved with a defect.
A developer 28 who fixes 30 a defect can capture a stack trace and can use the stack trace to determine where the defect potentially emanates in the source code. A stack trace or stack traceback is a report of the functions instantiated by the execution of a program. It keeps track of how local variables change on each invocation of a routine as well as the values that they return. The developer 28 enters 32 the functions involved in a defect in the change and release management system 22. More particularly, the change and release management system 22 receives and records (stores in memory) a list of functions 34, 35, 36 etc. involved in the defect.
In the illustrated embodiments, a heat map creator tool 38 walks all the defects and maps an exhaustive list 40 of functions in this application 18 to an exhaustive list 42 of object unique identifiers to produce a heat map 44 with function names on one axis and Object UIDs on another axis. The heat map creator 38 walks the defect record and creates a pheromone map from Object UID versus function. In time, more of the occurrences of links between Object UIDs and functions will result in “hotter” areas on the heat map.
In some embodiments, different colors are used to indicate different heat levels. For example, a bright red color may indicate a high occurrence linkage between a particular object and a particular function, a dark green color may indicate a low defect rate, and orange, yellow, and light green colors may indicate intermediate defect rates. Other colors or other graphical or tabular indications of potential problem areas can be used in other embodiments.
The heat map 44 is then stored as an artifact along with code frozen bits (final source code) of this particular software product for later use by support people. In some embodiments, the heat map 44 is a spreadsheet. In some embodiments, the heat map creator 38 and the change and release management system 22 are defined by separate computer devices that are in communication with one another over a network. In other embodiments, the heat map creator 38 and the change and release management system 22 are defined by a single computer device.
When a defect is reported from the production environment, the support engineer can simulate the defect in his or her own environment. During the process of simulation, the engineer will use the Object UID creation tool which is the hashing tool to generate the Object UID of the Graphical User object which is showing the symptom of the particular defect.
As illustrated in FIG. 3 , after the software 18 has been released, higher level support people (e.g., Level 2 and Level 3 support people) are provided access to the heat map 44. These support people, when given a support problem, can look up the heat maps and find out which are the functions that are likely candidates to have created a defect, involving the particular Object UIDS, and solve the problem faster. In some embodiments, the change and release management system 22 and/or the heat map creator 38 and/or a network containing the change and release management system 22 and the heat map creator 38 has an access control, and access is given to a (post-release) customer support person. For example, it may be necessary to use a password to gain access to a network and only certain persons on the network are given permission to access the change and release management system 22 and/or the heat map creator 38, and a customer support person is given such access.
Embodiments of the invention can take the form of entirely hardware elements, entirely software elements or a combination containing both hardware and software elements. In a preferred embodiment, embodiments of the invention are implemented as software elements, which include but are not limited to firmware, resident software, microcode, etc.
Furthermore, embodiments of the invention can take the form of a computer program product accessible from a computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system. For the purposes of this description, a computer-usable or computer readable medium can be any apparatus that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device.
The medium can be an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system (or apparatus or device) or a propagation medium. Examples of a computer-readable medium include a semiconductor or solid state memory, magnetic tape, a removable computer diskette, a random access memory (RAM), a read-only memory (ROM), a rigid magnetic disk and an optical disk. Current examples of optical disks include compact disk—read only memory (CD-ROM), compact disk—read/write (CD-R/W) and DVD.
A data processing system suitable for storing and/or executing program code will include at least one processor coupled directly or indirectly to memory elements through a system bus. The memory elements can include local memory employed during actual execution of the program code, bulk storage, and cache memories which provide temporary storage of at least some program code in order to reduce the number of times code must be retrieved from bulk storage during execution.
Input/output or I/O devices (including but not limited to keyboards, displays, pointing devices, etc.) can be coupled to the system either directly or through intervening I/O controllers.
Network adapters may also be coupled to the system to enable the data processing system to become coupled to other data processing systems or remote printers or storage devices through intervening private or public networks. Modems, cable modems and Ethernet cards are just a few of the currently available types of network adapters.
The description set out above describes particular embodiments only and is not intended to limit the invention, whose scope is determined solely by the claims set out below. As used here, singular forms “a”, “an” and “the” are intended to include plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
In compliance with the patent statutes, the subject matter disclosed herein has been described in language more or less specific as to structural and methodical features. However, the scope of protection sought is to be limited only by the following claims, given their broadest possible interpretations. The claims are not to be limited by the specific features shown and described, as the description above only discloses example embodiments.
Claims (14)
1. A system comprising:
a function test tool used for testing software applications for defects;
an Object UID creator having a hashing tool generate Object unique identifiers (UIDs) from Graphical User Interface objects of a software application;
a change and release management system receiving and storing Object UIDs of objects involved in the defects uncovered during the testing as well as other Object UIDs from the software application, the change and release management system being further receiving and storing function names involved in the defects as well as other function names; and
a heat map creator generating a heat map that maps the function names versus the Object UIDs for which the defects emanate from, wherein the heat map is used to fix the defects of the software application.
2. The system in accordance with claim 1 wherein the heat map creator is in communication with the change and release management system.
3. The system in accordance with claim 1 and comprising a first computer device defining the heat map creator, and a second computer device, different from the first computer device, defining the change and release management system.
4. The system in accordance with claim 3 wherein the first computer device is in communication with the second computer device.
5. The system in accordance with claim 3 wherein the heat map creator creates the heat map with different colors used to indicate different levels of occurrence linkage between the Object UIDs and the function names.
6. A non-transitory computer program product comprising a computer readable storage medium having computer usable program code embodied therewith, the computer usable program code comprising:
computer usable program code being stored on a non-transitory storage medium, when executed by a processor tests software applications for defects;
computer usable program code being stored on a non-transitory storage medium, when executed by a processor generates Object unique identifiers (UIDs) from Graphical User Interface objects of a software application;
computer usable program code being stored on a non-transitory storage medium, when executed by a processor receives and stores Object UIDs of objects involved in the defects uncovered during the testing as well as other Object UIDs from the software application;
computer usable program code being stored on a non-transitory storage medium, when executed by a processor receives and stores function names involved in the defects as well as other function names; and
computer usable program code being stored on a non-transitory storage medium, when executed by a processor generates a heat map of the function names versus the Object UIDs for which the defects occurred; and
computer usable program code being stored on a non-transitory storage medium, when executed by a processor uses the heat map to fix the defects of the software application.
7. The computer program product in accordance with claim 6 wherein the heat map in used in post-release customer support of the software application.
8. The computer program product in accordance with claim 6 wherein computer usable program code generates the heat map with different colors used to indicate different levels of occurrence linkage between the Object UIDs and the function names.
9. The computer program product in accordance with claim 6 wherein the heat map is protected by access control, wherein the access to the heat map is provided to a customer support person via the access control.
10. A system comprising:
a hashing tool to generate Object unique identifiers (UIDs) from a software application;
a function verification testing tool to test the software application for defects;
a first computing device to:
store Object UIDs involved in the defects uncovered during the function verification test as well as other Object UIDs from the software application; and
store function names involved in the defects determined through the function verification testing tool;
a second computing device, communicatively coupled to the first computing device, to:
create a heat map by mapping the function names versus the Object UIDs for which the defects emanate from, wherein the heat map is used to fix defects of the software application; and
provide access to the heat map in providing customer support, wherein information about the defects learned during software development is made available to customer support using the heat map.
11. The system in accordance with claim 10 wherein the second computing device generates the heat map with different colors used to indicate different levels of occurrence linkage between the Object UIDs and the function names.
12. The system in accordance with claim 10 wherein the heat map is stored along with code frozen bits.
13. The system in accordance with claim 10 wherein the first computing device is a change and release management system.
14. The system in accordance with claim 10 wherein the first computing device is configured to use a stack trace to determine the functions involved in the defect.
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/631,549 US8381188B2 (en) | 2009-12-04 | 2009-12-04 | Leveraging the relationship between object IDs and functions in diagnosing software defects during the post-deployment phase |
US13/412,884 US8381190B2 (en) | 2009-12-04 | 2012-03-06 | Leveraging the relationship between object IDs and functions in diagnosing software defects during the post-deployment phase |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/631,549 US8381188B2 (en) | 2009-12-04 | 2009-12-04 | Leveraging the relationship between object IDs and functions in diagnosing software defects during the post-deployment phase |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US13/412,884 Continuation US8381190B2 (en) | 2009-12-04 | 2012-03-06 | Leveraging the relationship between object IDs and functions in diagnosing software defects during the post-deployment phase |
Publications (2)
Publication Number | Publication Date |
---|---|
US20110138360A1 US20110138360A1 (en) | 2011-06-09 |
US8381188B2 true US8381188B2 (en) | 2013-02-19 |
Family
ID=44083275
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/631,549 Expired - Fee Related US8381188B2 (en) | 2009-12-04 | 2009-12-04 | Leveraging the relationship between object IDs and functions in diagnosing software defects during the post-deployment phase |
US13/412,884 Expired - Fee Related US8381190B2 (en) | 2009-12-04 | 2012-03-06 | Leveraging the relationship between object IDs and functions in diagnosing software defects during the post-deployment phase |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US13/412,884 Expired - Fee Related US8381190B2 (en) | 2009-12-04 | 2012-03-06 | Leveraging the relationship between object IDs and functions in diagnosing software defects during the post-deployment phase |
Country Status (1)
Country | Link |
---|---|
US (2) | US8381188B2 (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10372591B2 (en) | 2016-09-07 | 2019-08-06 | International Business Machines Corporation | Applying eye trackers monitoring for effective exploratory user interface testing |
Families Citing this family (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9262851B2 (en) * | 2014-05-27 | 2016-02-16 | Oracle International Corporation | Heat mapping of defects in software products |
CN105589806B (en) * | 2015-12-17 | 2018-05-18 | 北京航空航天大学 | A kind of software defect tendency Forecasting Methodology based on SMOTE+Boosting algorithms |
US11288592B2 (en) | 2017-03-24 | 2022-03-29 | Microsoft Technology Licensing, Llc | Bug categorization and team boundary inference via automated bug detection |
US10754640B2 (en) | 2017-03-24 | 2020-08-25 | Microsoft Technology Licensing, Llc | Engineering system robustness using bug data |
US10585780B2 (en) | 2017-03-24 | 2020-03-10 | Microsoft Technology Licensing, Llc | Enhancing software development using bug data |
US11182239B2 (en) * | 2020-04-28 | 2021-11-23 | Intuit Inc. | Enriched high fidelity metrics |
Citations (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5537590A (en) | 1993-08-05 | 1996-07-16 | Amado; Armando | Apparatus for applying analysis rules to data sets in a relational database to generate a database of diagnostic records linked to the data sets |
US5847972A (en) | 1993-09-24 | 1998-12-08 | Eick; Stephen Gregory | Method and apparatus for graphically analzying a log-file |
US6389483B1 (en) * | 1995-10-17 | 2002-05-14 | Telefonaktiebolaget L M Ericsson (Publ) | System and method for reducing coupling between modules in a telecommunications environment |
US20040078667A1 (en) | 2002-07-11 | 2004-04-22 | International Business Machines Corporation | Error analysis fed from a knowledge base |
US20050091642A1 (en) | 2003-10-28 | 2005-04-28 | Miller William L. | Method and systems for learning model-based lifecycle diagnostics |
US7174536B1 (en) | 2001-02-12 | 2007-02-06 | Iowa State University Research Foundation, Inc. | Integrated interactive software visualization environment |
US7251584B1 (en) | 2006-03-14 | 2007-07-31 | International Business Machines Corporation | Incremental detection and visualization of problem patterns and symptoms based monitored events |
US7373554B2 (en) | 2004-09-24 | 2008-05-13 | Oracle International Corporation | Techniques for automatic software error diagnostics and correction |
US20090150420A1 (en) | 2007-11-05 | 2009-06-11 | Picochip Designs Limited | Generating debug information |
US7870396B2 (en) * | 2005-11-24 | 2011-01-11 | Fuji Xerox Co., Ltd. | Storage medium, method, and apparatus for creating a protected executable program |
-
2009
- 2009-12-04 US US12/631,549 patent/US8381188B2/en not_active Expired - Fee Related
-
2012
- 2012-03-06 US US13/412,884 patent/US8381190B2/en not_active Expired - Fee Related
Patent Citations (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5537590A (en) | 1993-08-05 | 1996-07-16 | Amado; Armando | Apparatus for applying analysis rules to data sets in a relational database to generate a database of diagnostic records linked to the data sets |
US5847972A (en) | 1993-09-24 | 1998-12-08 | Eick; Stephen Gregory | Method and apparatus for graphically analzying a log-file |
US6389483B1 (en) * | 1995-10-17 | 2002-05-14 | Telefonaktiebolaget L M Ericsson (Publ) | System and method for reducing coupling between modules in a telecommunications environment |
US7174536B1 (en) | 2001-02-12 | 2007-02-06 | Iowa State University Research Foundation, Inc. | Integrated interactive software visualization environment |
US20040078667A1 (en) | 2002-07-11 | 2004-04-22 | International Business Machines Corporation | Error analysis fed from a knowledge base |
US20050091642A1 (en) | 2003-10-28 | 2005-04-28 | Miller William L. | Method and systems for learning model-based lifecycle diagnostics |
US7373554B2 (en) | 2004-09-24 | 2008-05-13 | Oracle International Corporation | Techniques for automatic software error diagnostics and correction |
US7870396B2 (en) * | 2005-11-24 | 2011-01-11 | Fuji Xerox Co., Ltd. | Storage medium, method, and apparatus for creating a protected executable program |
US7251584B1 (en) | 2006-03-14 | 2007-07-31 | International Business Machines Corporation | Incremental detection and visualization of problem patterns and symptoms based monitored events |
US20090150420A1 (en) | 2007-11-05 | 2009-06-11 | Picochip Designs Limited | Generating debug information |
Non-Patent Citations (4)
Title |
---|
Chi, E., "A Framework for Information Visual Spreadsheets", [online] Thesis, Abstract, Mar. 1999, University of Minnesota, [retrieved Dec. 4, 2009] retrieved from the Internet: . |
Chi, E., "A Framework for Information Visual Spreadsheets", [online] Thesis, Abstract, Mar. 1999, University of Minnesota, [retrieved Dec. 4, 2009] retrieved from the Internet: <http://homepages.mcs.vuw.ac.nz/˜elvis/db/references/chi99framework>. |
Eick, S., et al., "Seesoft-A Tool for Visualizing Line Oriented Software Statistics", IEEE Transactions on Software Engineering, Nov. 1992, Abstract, vol. 18, Issue 11. |
Mark Brodie et al., "Quickly Finding Known Software Problems via Automated Symptom Matching", IEEE International Converence on Autonomic Computing (ICAC), 2005. * |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10372591B2 (en) | 2016-09-07 | 2019-08-06 | International Business Machines Corporation | Applying eye trackers monitoring for effective exploratory user interface testing |
Also Published As
Publication number | Publication date |
---|---|
US20120166884A1 (en) | 2012-06-28 |
US20110138360A1 (en) | 2011-06-09 |
US8381190B2 (en) | 2013-02-19 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8381190B2 (en) | Leveraging the relationship between object IDs and functions in diagnosing software defects during the post-deployment phase | |
Biggs et al. | A profile and tool for modelling safety information with design information in SysML | |
CN105701008B (en) | System and method for test case generation | |
US8875110B2 (en) | Code inspection executing system for performing a code inspection of ABAP source codes | |
Barbour et al. | An empirical study of faults in late propagation clone genealogies | |
TWI530783B (en) | Debug tours for software debugging | |
US20100275062A1 (en) | Functional Coverage Using Combinatorial Test Design | |
Nie et al. | Constraints: the core of supporting automated product configuration of cyber-physical systems | |
US8918762B2 (en) | Generating test plans and test cases from service-oriented architecture and process models | |
JP5246258B2 (en) | File generation program, file generation apparatus, and file generation method | |
Kahtan et al. | Reviewing the challenges of security features in component based software development models | |
Hu et al. | Quality model based on ISO/IEC 9126 for internal quality of MATLAB/Simulink/Stateflow models | |
Le et al. | DirectDebug: A software package for the automated testing and debugging of feature models | |
JP2009099111A (en) | Rule inspection program, rule inspection method, and rule inspection device | |
KR20230044380A (en) | Method for providing code inspection interface, and apparatus implementing the same method | |
Santos-Neto et al. | Requirements for information systems model-based testing | |
Vierhauser et al. | Evolving systems of systems: Industrial challenges and research perspectives | |
Dubey | Towards adopting ODC in automation application development projects | |
CN114116471A (en) | Automatic code scanning method, system, electronic equipment and storage medium | |
Gupta et al. | Requirement engineering: An overview | |
Firesmith | Common system and software testing pitfalls | |
Lysne et al. | Software quality and quality management | |
Mosser et al. | Visualizing and assessing a compositional approach of business process design | |
Zhou | Functional requirements and non-functional requirements: a survey | |
Kumar et al. | An empirical study of bad smell in code on maintenance effort |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: INTERNATIONAL BUSINESS MACHINES CORPORATION, NEW Y Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:JOHN, KURIAN;PARVATHANATHAN, KAMALA;SIGNING DATES FROM 20091125 TO 20091126;REEL/FRAME:023609/0152 |
|
REMI | Maintenance fee reminder mailed | ||
LAPS | Lapse for failure to pay maintenance fees | ||
STCH | Information on status: patent discontinuation |
Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362 |
|
FP | Lapsed due to failure to pay maintenance fee |
Effective date: 20170219 |