The present invention generally relates to methods for software vendors to provide technical assistance to their customers and in particular, to a method and apparatus for remotely debugging an application program over the Internet.
It is common business practice for customers to purchase application programs or software over the Internet by downloading them from vendor web sites. This method of purchasing software is both convenient for customers, and cost effective for vendors. Customers do not waste time or gas traveling to and looking for retail stores stocking the software, and vendors eliminate middleman expenses and avoid packaging and media costs.
Unfortunately, when customers experience problems using the purchased software, the prevalent method of debugging those problems continues to be the old fashioned method of calling in for customer telephone assistance. This approach results too often in long waits to talk to technical support personnel, and limited diagnostic assistance once such personnel become available since it may be difficult for them to replicate the customer's problem on their computers.
Accordingly, it is an object of the present invention to provide an improved method and apparatus for software vendors to provide technical assistance to their customers.
Another object is to provide a method and apparatus for software vendors to provide technical assistance to their customers over the Internet.
Still other objects are to provide a method and apparatus for remotely debugging an application program over the Internet.
These and additional objects are accomplished by the various aspects of the present invention, wherein briefly stated, one aspect is a method implemented in a client computer for remotely debugging an application program over the Internet, comprising: (a), establishing a connection between the client computer and a server computer over the Internet; (b), receiving a request from a debug program of the server computer; (c), causing an application program of the client computer to generate a response to the request; and (d), transmitting an indication of the response back to the debug program; and (e), repeating (b), (c) and (d) multiple times so as to run the application program through a diagnostic sequence.
In another aspect, an apparatus for remotely debugging an application program over the Internet, comprises a client computer having an interface program for: (a), establishing a connection between the client computer and a server computer over the Internet; (b), receiving a request from a debug program of the server computer; (c), causing an application program of the client computer to generate a response to the request; and (d), transmitting an indication of the response back to the debug program; and (e), repeating (b), (c) and (d) multiple times so as to run the application program through a diagnostic sequence.
In another aspect, a method implemented in a client computer for remotely debugging an application program over the Internet, comprises: (a), establishing a connection between the client computer and a server computer over the Internet; (b), receiving a request from a debug program of the server computer; (c), causing an application program of the client computer to respond to the request; (d), generating a graphics file including pixel information for a graphics image displayed on a display screen of the client computer; and (e), transmitting the graphics file to the server computer so that the graphics image is displayable on a display screen of the server computer.
In another aspect, an apparatus for remotely debugging an application program over the Internet, comprises a client computer having an interface program for: (a), establishing a connection between the client computer and a server computer over the Internet; (b), receiving a request from a debug program of the server computer; (c), causing an application program of the client computer to respond to the request; (d), generating a graphics file including pixel information for a graphics image displayed on a display screen of the client computer; and (e), transmitting the graphics file to the server computer so that the graphics image is displayable on a display screen of the server computer.
In another aspect, a method implemented in a server computer for remotely debugging an application program over the Internet, comprises: (a), receiving a request from a client computer over the Internet to debug an application program of the client computer; (b), transmitting back to the client computer a request for the application program to take an action; (c), receiving an indication of a response of the application program action back from the client computer; and (d), repeating (b) and (c) multiple times so as to run the application program through a diagnostic sequence.
In another aspect, an apparatus for remotely debugging an application program over the Internet, comprises a server computer having a debug program for: (a), receiving a request from a client computer over the Internet to debug an application program of the client computer; (b), transmitting back to the client computer a request for the application program to take an action; (c), receiving an indication of a response of the application program action back from the client computer; and (d), repeating (b) and (c) multiple times so as to run the application program through a diagnostic sequence.
In yet another aspect, a method implemented in a server computer for remotely debugging an application program over the Internet, comprises: (a), receiving a request from a client computer over the Internet to debug an application program of the client computer; (b), transmitting back to the client computer a request for the application program to take an action; (c), receiving a graphics file including pixel information for a graphics image displayed on a display screen of the client computer in response to the action; (d), displaying the graphics image on a display screen of a server computer; and (e), repeating (b) through (d) multiple times so as to allow a user of the server computer to interactively debug the application program by transmitting requests for the application program to take certain actions in consideration of graphics images defined in graphics files received from the client computer in response to prior such requests.
In still another aspect, an apparatus for remotely debugging an application program over the Internet, comprises a server computer having a debug program for: (a), receiving a request from a client computer over the Internet to debug an application program of the client computer; (b), transmitting back to the client computer a request for the application program to take an action; (c), receiving a graphics file including pixel information for a graphics image displayed on a display screen of the client computer in response to the action; (d), displaying the graphics image on a display screen of a server computer; and (e), repeating (b) through (d) multiple times so as to allow a user of the server computer to interactively debug the application program by transmitting requests for the application program to take certain actions in consideration of graphics images defined in graphics files received from the client computer in response to prior such requests.
Additional objects, features and advantages of the various aspects of the present invention will become apparent from the following description of its preferred embodiments, which description should be taken in conjunction with the accompanying drawings.
The interface program 14 controls the application program 12 and communicates with the debug program 32 during the debug mode. When the debug program 32 transmits a request to be acted upon by the application program 12, the interface program 14 receives the request and causes the application program 12 to generate a response to the request. The interface program 14 then transmits an indication of the response back to the debug program 32.
In one form of indication, the interface program 14 simply returns the response to the debug program 32. In another form of indication, the interface program 14 captures pixel information for a graphics image on the display screen of the client computer 10 from a frame buffer associated with the client computer 10, converts the pixel information into a graphics file of a selected graphics file format, and transmits the graphics file to the debug program 32. The graphics file format may be any one of a number of standard formats such as JPEG, GIF or TIF. This form of indication allows the vendor operator to see what is being displayed on the display screen of the client computer 10. This is especially useful when the vendor operator is unable to replicate the response generated by the application program 12 running on the client computer 10 with a corresponding response generated by a copy of the application program 12 running on the server computer 30.
As used herein, the purchaser of the application program 12 is referred to as the “customer”, the operator or user of the client computer 10 is referred to as the “customer operator”, the vendor company of the application program 12 is referred to as the “vendor”, and the operator or user of the server computer 30 is referred to as the “vendor operator”. Vendor operators are typically customer technical support personnel. The interface program 14 is typically sold or licensed by the vendor along with the application program 12.
In one use of the window 304, the interface program 14 prompts the customer operator for a user identification and password. After the customer operator provides the requested information, the interface program 14 transmits the user identification and password to the debug program 32 for verification. In another use of the window 304, the interface program 14 presents a check-the-box type questionnaire to the customer operator to facilitate efficient diagnosis of the problem to be debugged. After the customer operator clicks the appropriate boxes, the interface program 14 transmits the information to the debug program 32, which in turn, initiates appropriate diagnostic sequences corresponding to each checked box. In still another use of the window 304, an instant messaging or chat room type area facilitates communication back and forth between the customer operator and the vendor operator to further facilitate diagnosis of the problem to be debugged.
In 402, the interface program 14 transmits identification information to the debug program 32 of the server computer 30 over the Internet 20. A first set of identification information includes identification of the application program 12, and identification of the client computer 10. This information allows the debug program 32 to verify that the application program 12 is still under warranty or maintenance contract, and that the client computer 10 is authorized to run the application program 12. The identifications of the application program and client computer 10 may be sent automatically by the interface program 14 according to its programming after establishing connection with the debug program 32, or sent by the interface program 14 after the debug program 32 has made a request for such information to the interface program 14. A second set of identification information includes a user identification and a password. The customer operator provides this information in a conventional fashion after being prompted by the interface program 14. Providing the user identification and password allows the debug program 32 to verify that the customer operator is authorized to contact the vendor company for debug support. If verification fails for either the first or second set of identification information, the interface program 14 displays a failure message received from the debug program 32 in the window 304. The interface program 14 is then deactivated, and control of the application program 12 is passed back to the customer operator.
In 403, the interface program 14 receives a request for preliminary information from the debug program 32. The preliminary information request may take the form of a fill-in-the-box questionnaire preprogrammed in and automatically transmitted by the debug program 32, or instant messaging or chat room type questions from the vendor operator. In either case, the questionnaire or questions are displayed in the window 304. The customer operator then responds to the questionnaire by checking the appropriate boxes, or answers the instant messaging or chat room type questions, as the case may be, and the interface program 14 transmits the information back to the debug program 32. The purpose of such preliminary information is to make the debug process more efficient, such as narrowing the choices of diagnostic sequences to take in subsequent debugging activities.
In 404 through 406, the interface program 14 takes certain actions in response to a diagnostic sequence received from the debug program 32. The diagnostic sequence may be preprogrammed into the debug program 32, or it may be provided to the debug program 32 from the vendor operator. It may also be a combination of a preprogrammed diagnostic sequence and vendor operator provided diagnostic sequence. In this case, the diagnostic sequence typically starts out as a preprogrammed diagnostic sequence that is paused at some point by the vendor operator. The vendor operator then takes over control of the debug program 32 at this point, and generates his or her own diagnostic sequence so as to interactively debug the application program 12.
In 404, the interface program 14 receives a request from the debug program 32 to be redirected to the application program 12. As previously described, the request is one of a diagnostic sequence directed to debug the application program 12. In 405, the interface program 14 causes the application program 12 to generate a response to the request. In 406, the interface program 14 transmits an indication of the response back to the debug program 32. As previously described, the indication may be the response itself, or a graphics file including pixel information for a graphics image displayed on the display screen of the client computer 10. Then 404 through 406 are repeated multiple times so as to run the application program 12 through the diagnostic sequence.
Although the various aspects of the present invention have been described with respect to a preferred embodiment, it will be understood that the invention is entitled to full protection within the full scope of the appended claims.
Number | Date | Country | |
---|---|---|---|
Parent | 09664941 | Sep 2000 | US |
Child | 11030691 | Jan 2005 | US |