The present invention relates generally to computer systems, and more particularly to methods and mechanisms for issue reporting by software users to software developers and providers.
In general, it is impossible to guarantee that a computer program is free of bugs. Computer software projects of substantial scope and complexity are particularly likely to contain errors and other unexpected and undesirable behavior. In order to develop and maintain useful, high-quality software products while minimizing errors and other problems, it is essential that software developers receive informative feedback from users. The task of collecting and analyzing sufficiently-detailed user experience information in order to make appropriate improvements to software is especially challenging in large-scale projects involving a widely-dispersed user base. One important setting in which the need for such a task arises is the beta-release stage of software under development.
Utilities have been designed to facilitate submission of reports on bugs and other issues from users to developers. Most previous reporting tools and trouble ticket mechanisms have been tied to particular applications, products or platforms. Other reporting tools have been limited to allowing highly general diagnostic questions to be presented to the user. Changes to and extensions of existing tools have required substantial, time-consuming recoding efforts.
The present invention is directed to a system and method in which a dynamically-configurable general report client is used to facilitate reporting of information, such as a bug or other problem issue, regarding a computer software product. The invention is capable of being used for reporting on an arbitrary number of different software products. In accordance with the invention, a particular report user interface is specified for each product with respect to which a report can be prepared. A set of one or more report user interface definition files specifies a customized user interface for a particular product. The client causes a display of the customized report user interface in accordance with the report user interface definition files. In certain embodiments of the invention the report user interface definition files are Extensible Markup Format (XML) files or other markup-language files. Report user interface definition files may include a report parent file along with one or more additional report user interface definition files.
In accordance with one aspect of the present invention, there is provided a system for reporting information regarding the use of one or more software products by a software user. The system includes a report user interface, a set of report user interface definition files associated with each software product that can be the subject of a report, and the general report client. The software user enters requested information, as specified in the report user interface definition files, by way of the report user interface. The client generates a report file based on the information entered by the user and packages the report file with additional report information, such as hardware configuration information regarding the user's machine, required supporting files and user-supplied supporting files, and user authentication information, and transmits the package to a report server. The user can save an incomplete report in one session of running the client and complete and upload the report in a subsequent session.
In accordance with another aspect of the present invention, there is provided a method by which a software developer, provider or other party can obtain reported information regarding the use of a software product, as for example the use by a beta-testing customer. One or more report user interface definition files associated with that software product are designed to specify a customized user interface displayed by a general report client. Based on information reported by a user, the report user interface definition files can be modified for purposes of future reporting.
In accordance with another aspect of the invention, a method for debugging a computer program is provided. One or more report user interface definition files are written. The report user interface definition files, designed for use with a general report client, specify a report user interface that is customized for reporting on the computer program being debugged. By way of the report client, bug information reported by a user of the computer program is obtained. Based on this reported bug information, source code for the computer program is modified. The report user interface definition files can also be modified for purposes of future debugging of the computer program.
In accordance with another aspect of the invention, there is provided a method by which a user reports information regarding the use of a software product. The user runs a general report client. The user causes the client to load one or more report user interface definition files customized with respect to the software product. The user enters information by way of a report user interface displayed by the client in accordance with the report user interface definition files. Entering certain information may cause the client to load one or more additional report user interface definition files and accordingly add one or more additional child screens to the user interface. The user causes the client to upload a completed report to a server. In embodiments of the invention, the user can submit a report anonymously, and the user can save an incomplete report in a first session in which the report client is run, completing the incomplete report in a subsequent client session.
In accordance with another aspect of the invention, there is provided a method for authenticating a user who submits a report on a software product. A report cookie, comprising a report user identification and an expiration date, is generated for the reporting user. In embodiments of the invention, the report user identification is a cryptographically-random signed 64-bit integer, and the generating of the report cookie is performed by way of a web service. The report cookie is stored in a ticket file on the reporting user's computer. In an embodiment of the invention, the ticket file is an XML file.
While the appended claims set forth the features of the present invention with particularity, the invention, together with its objects and advantages, may be best understood from the following detailed description taken in conjunction with the accompanying drawings, of which:
Disclosed herein is an illustrative system architecture in accordance with which a single client installed on a user's computer is used to submit reports on multiple software products to one or more reporting servers, possibly by way of a remote network connection. The template format for a given report is specified in a manner that is customized for a corresponding software product. Based on initial user responses, a report can be further dynamically configured to request additional information from the user. Also disclosed herein is a method by which developers and providers of a software product obtain problem reports from users and accordingly modify both the software product and the report template files designed for user reports on that product. Also disclosed herein is a method by which a user prepares and submits, to one or more reporting servers, issue reports on one or more software products, along with supporting information, using a single problem-reporting client. Also disclosed herein are customizable features of an exemplary user interface design for a problem-reporting client.
While this detailed description will refer to illustrative embodiments of the invention that provide specifically for the preparation and submission of bug reports or issue reports, it will be recognized that the invention applies more broadly to communication between software users and software providers in general, including the submission of other kinds of user information besides issue reports. For example, alternative embodiments of the present invention are employed in the provision of support to a user of a software product where the user has not experienced a bug but seeks assistance in the use of the product.
Turning to
The problem-reporting client 107 is provided to the user 101 by, for example, the developers 105 of the software product 103 or by a third-party software provider 115. By way of example, the user interface-defining XML files 111 associated with the software product 103 are produced by the developers 105 and provided to the user 101 at the time at which the software product 103 itself is provided, or at a separate time. The user 101 is, for example, a customer selected by the developers 105 to participate in beta-release testing of the product 103.
If the user 101 experiences a bug or other problem or issue with respect to the use of the software product 103, the user 101 runs the problem-reporting client 107 in order to begin a new report or complete a report in progress on the encountered issue by way of the problem-reporting user interface 113. The client 107 packages the user's responses together with additional data, such as supporting files and hardware information, into a report package 117. If the user 101 chooses to upload the completed report package 117, the client 107 transmits the package 117 to a problem-reporting server 119, where the reported information will be parsed into a database. The developers 105 of the software product 103 for which the report 117 was completed will then retrieve information relating to the problem report 117. Typically the server 119 will be remote to the client 107 and to the user's computer 109, and the transmission occurs by way of a network 121.
Turning now to
The set of XML files 201 includes a top-level file called the Report Parent File (RPF) 207, marked in an embodiment by a file name with an .rpf extension. The RPF 207 contains definitions of user interface design elements specifying the base features and layout of the report user interface 203, such as colors, graphics elements, window heights and widths, and the positions, sizes, and captions of controls common to all windows in the display 203. The RPF can also include a list of additional files 209 stored on the user's system that are considered to be required or useful for processing a submitted user report.
One or more additional RPFs 211, each associated with a particular other software product, may be present on a user's system. In an embodiment of the invention, when the client is launched by the user, the client loads the RPF most recently loaded in a previous execution of the client. If the client is being run for the first time, or there is no record of the most recently loaded RPF, or if the most recently loaded RPF is not present on the user's system, the client loads the first valid RPF it finds. A well-written RPF will define a drop-down list display element that enumerates all RPFs 207, 211 stored on the user's system, permitting the user to change the report template being used for preparing a current report. An RPF file ideally will be given an intuitively meaningful file name, such as one identifying the product for which it is customized.
The RPF 207 can contain a list of user interface definition files (UIDFs) 213, which are additional files in the set of XML files 201. A particular UIDF defines controls that specify all elements of a corresponding “child screen” within the report display 203, including all questions and requests for additional files or additional supporting information that will be presented to the user in that child screen. The UIDF also specifies whether a response to a particular question is required in order for the corresponding child screen to be considered completely filled out. A typical report user interface 203 will incorporate several child screens, each of which is based on a particular UIDF.
In accordance with controls defined in the RPF 207 and specified files in the set of UIDFs 213, when the user selects or inputs particular values in a display screen, an appropriate UIDF is loaded by the client and parsed by the control parser 205. The questions defined in that UIDF are thereby incorporated into the user interface 203 presented to the user. In this way, the problem-reporting client is dynamically configurable. A potentially unlimited number of questions or other requests for information can be added to the user interface 203 during the course of a user's completion of a problem report. For example, within a software product development team, a group of developers may be responsible for a particular component of the software product. This group can define additional user interface child screens in one or more UIDFs for the purpose of obtaining more detailed information from the user pertaining to the component for which they are responsible. Based on the user's responses, progressively more finely-grained content, in the form of “additional information” child screens 215, can thus be added to the user interface 203 dynamically by loading additional UIDFs in the set of UIDFs 213.
In addition to the dynamically-defined child screens 215, the problem report user interface 203 will have a “save screen” 217, a child screen providing instructions to the user on saving and submitting a report. The text strings and other display characteristics of the save screen 217 are defined in the RPF 207 and can be customized (as for example by language and writing system). The user is not required to submit a report during the client session in which the report is first prepared; an incomplete report is saved by the user for future editing and completion. This permits the user to locate information needed to complete a problem report questionnaire.
When a user has completed a problem report, and the problem-reporting client verifies the report as having been filled out completely, a report file generator 219 compiles the user's responses into a properly-formatted user interface XML document 221 and cryptographically signs the document. A file gathering component 223 defines a user interface feature comprising a file list, and brings about the collection of additional files to be submitted with the report, including required files 209 specified in the RPF 207, such as relevant system log files and files supplied by the user 225. A hardware information gathering component 227 extracts information concerning the configuration of the user's machine and saves this information in a hardware information XML file 229. A user authentication component 231 supplies user identification credentials 233 to be included with the problem report if the user wishes to be contacted in the future regarding the submitted report. An embodiment of the invention uses the Microsoft® .NET Passport authentication service, in a manner described in further detail below.
A report packaging component 235 packages the report XML document 221 along with the files 209, 225 gathered by the file gathering component 223, the hardware information file 229 generated by the hardware information gathering component 227 (unless the user has opted not to have this information submitted with the report), and the report user identification credentials 233 produced by the user authentication component 231, into a cabinet (.cab extension) file 237. In an alternative embodiment, another file archive format is used. A report transmitting component 239 causes the cabinet file 237 to be uploaded to a reporting server, where it is parsed and sorted into an appropriate database based on such criteria as user status, program participation, and product.
Turning now to
Turning now to
With reference to
During step 417, the user adds to the report the names of any files that the user believes will be useful to developers in reproducing the encountered issue. The client gathers the required and user-supplied files that will accompany the report during step 419. At step 423 the user saves the report. The user decides at step 425 whether to file anonymously (i.e., without submission of hardware configuration information, contact information, and user authentication credentials).
If the user is not anonymous, the client initiates a process of authentication of the user during step 427. The flowchart of
Returning now to
With respect to the flow diagrams of
Turning now to
The Save screen 800 further includes text encouraging the customer to submit gathered hardware configuration information to assist in the processing and analysis of the report, and a check box 807 which, if not checked, prevents the customer's hardware configuration information from being submitted; here the check box 807 has been checked. In another embodiment, the Save screen allows the user to view hardware configuration information before it is uploaded to the reporting server. The Save screen 800 also includes a check box 809 allowing the customer to file the report anonymously (without submission of hardware information, Report UID authentication, or the customer's e-mail address). In another embodiment a save screen permits the user to save a report for future editing and to load a previously saved report.
The invention may be described in the general context of computer-executable instructions and computer-readable data being executed and read by a computing machine, including program modules. Program modules are broadly defined to include such elements as routines, programs, objects, components, and data structures, designed to perform particular tasks or to implement particular abstract data types. The invention is potentially incorporated within a distributed computing environment comprising a plurality of network nodes, in which certain tasks are performed by remote computing devices linked through a data communications network. In a distributed computing environment, program modules are generally located in both local and remote computer storage media.
With continued reference to
The exemplary computer machine 1010 further includes various input/output devices and media. A user may enter commands and information into the computer 1010 through input devices such as a keyboard 1062 and pointing device 1061. These and other input devices are often connected to the processing unit 1020 through an interface 1060 that is coupled to the system bus 1021, but they may be connected by other interface and bus structures, such as a universal serial bus. Output devices and media can include a monitor or other type of display 1091, and a printer 1096, and include secondary storage devices such as a non-removable magnetic hard disk 1041, a removable magnetic disk 1052, and a removable optical disk 1056. Such computer-readable media provide nonvolatile storage of computer program modules and data. The hard disk 1041 is also commonly used along with the primary memory 1030 in providing virtual memory. It will be appreciated by those skilled in the art that other kinds of computer-readable media that can provide volatile and nonvolatile storage of data can also be used in the exemplary computing environment 1000. The computer 1010 has a file system 1042 associated with the operating system 1034. The file system serves as an interface that maps a set of logically-organized named files to data physically stored on secondary storage media, such as data stored in clusters or sectors on the hard disk 1041.
It will be appreciated by those skilled in the art that a new and useful method and framework for facilitating, preparing and submitting issue and problem reports by a software user and to a software provider has been described herein. More particularly, an extensible and dynamically-configurable problem-reporting client situated on a user's computer can be used to provide customized product-specific and user-specific reports to software product developers. In view of the many possible computing environments to which the principles of this invention may be applied, it should be recognized that embodiments described herein are meant to be illustrative and should not be deemed to limit the scope of the invention. Those skilled in the art to which the present invention applies will appreciate that the illustrative embodiments disclosed herein can be modified in arrangement and detail without departing from the spirit of the invention. For example, process steps described herein may be interchangeable with other steps in order to achieve the same result. Therefore, the invention as described herein,contemplates all such embodiments as may come within the scope of the following claims and equivalents thereof.