The present invention relates to computer software and, in particular, to validating the installation of computer software on a computer.
Given the configurability, complexity, and sophistication of most software applications available today, it is a challenging task to ensure that software applications are properly installed a computer. Ensuring that an operating system is properly installed is even more particularly challenging given the almost innumerable array of hardware components/devices that can be used to make up a computer. In spite of these challenges, if software is installed on a computer, the computer's user will have an expectation that the software was installed properly and is ready to run.
Most computers are purchased with software already installed, or preinstalled. In fact, it is very difficult to purchase a computer without at least an operating system installed. In addition to the operating system, most new computers are also bundled with a variety of other software applications, such as a Web browser, an email program, a word processor, and the like. However, the operating system and these bundled applications are not preinstalled on the new computer in a “typical” manner, i.e., where a user installs the application onto the computer from a distribution CD. Instead, the computer vendor will typically have a master installation drive upon which the operating system and other bundled applications have been installed. Then, for each new computer sold, the master installation drive is then copied, verbatim, onto the hard drive of the new computer using a special, high-speed disk drive copying device. However, while the software on the master installation drive may have been installed in the typical manner, it is difficult to determine whether the installations were successful or not because the master installations cannot be executed/tested to verify that they are properly installed.
Typically, when software applications are executed for the very first time, a startup process is executed to complete the initialization and customization of the software installation. Frequently, these startup processes customize the installed software to the computer upon which they are installed. For example, environment variables may be set, search paths established, and default directories created. In an operating system's startup process, the operating system will typically generate a unique system identification number (SID) based on the hardware configurations, hardware serial numbers, network connections, and the like. The SID is used by the operating system to uniquely identify itself in a networked environment. The SID may also be used for registration purposes. Accordingly, the SID is permanently associated with, and used by the operating system. Thus, the master installation cannot be run a first time because it would generate the SID for the master computer, not the end user's computer, and the customizations and personalizations of the master computer would be duplicated to new computers. If this occurred, each new computer would have the same SID, which would be grievous to every network administrator.
Therefore, what is needed is a system and method to determine whether a software application is properly installed on a computer.
In accordance with the present invention, a system and method for validating whether a software application is properly installed on a target computer is presented. A validation manifest corresponding to the software application is obtained. The validation manifest comprises validation actions for determining whether the software application is properly installed. Based on the results of executing the validation actions listed in the validation manifest, a determination is made as to whether the software application is properly installed.
In accordance with further aspects of the present invention, a computer networked environment for determining whether a software application is properly installed on a client computer is presented. A network administrator computer obtains a validation manifest corresponding to the software application on the client computer. The validation manifest comprises validation actions for determining whether the software application is properly installed on the client computer. Based on the results of executing the validation actions listed in the validation manifest, a determination is made as to whether the software application is properly installed on the client computer.
In accordance with yet further aspects of the present invention, a computer implemented method for determining whether a plurality of software applications installed on a target computer are properly installed. The plurality of software applications are identified. A validation manifest is obtained for each identified software application. The validation manifests comprises validation actions for determining whether the corresponding software application is properly installed on the client computer. For each identified software application, the validation actions in the corresponding validation manifest are carried out. For each identified software application, based on the results of executing the validation actions listed in the validation manifest, a determination is made as to whether the software application is properly installed on the client computer.
The foregoing aspects and many of the attendant advantages of this invention will become more readily appreciated as the same become better understood by reference to the following detailed description, when taken in conjunction with the accompanying drawings, wherein:
While aspects of the invention may be described in terms of application programs that run on an operating system in conjunction with a personal computer, those skilled in the art will recognize that those aspects also may be implemented in combination with other program modules. Generally, program modules include routines, programs, components, data structures, etc., that perform particular tasks or implement particular abstract data types.
With reference to
The personal computer 102 further includes a hard disk drive 116, a magnetic disk drive 118, e.g., to read from or write to a removable disk 120, and an optical disk drive 122, e.g., for reading a CD-ROM disk 124 or to read from or write to other optical media. The hard disk drive 116, magnetic disk drive 118, and optical disk drive 122 are connected to the system bus 108 by a hard disk drive interface 126, a magnetic disk drive interface 128, and an optical drive interface 130, respectively. The drives and their associated computer-readable media provide nonvolatile storage for the personal computer 102. Although the description of computer-readable media above refers to a hard disk, a removable magnetic disk, and a CD-ROM disk, it should be appreciated by those skilled in the art that other types of media that are readable by a computer, including magnetic cassettes, flash memory cards, digital video disks, Bernoulli cartridges, ZIP disks, and the like, may also be used in the exemplary operating environment.
A number of program modules may be stored in the drives and RAM 112, including an operating system 132, one or more application programs 134, other program modules 136, and program data 138. A user may enter commands and information into the personal computer 102 through input devices such as a keyboard 140 or a mouse 142. Other input devices (not shown) may include a microphone, touch pad, joystick, game pad, satellite dish, scanner, or the like. These and other input devices are often connected to the processing unit 104 through a user input interface 144 that is coupled to the system bus, but may be connected by other interfaces (not shown), such as a game port or a universal serial bus (USB).
A display device 158 is also connected to the system bus 108 via a display subsystem that typically includes a graphics display interface 156 and a code module, sometimes referred to as a display driver, to interface with the graphics display interface. While illustrated as a stand-alone device, the display device 158 could be integrated into the housing of the personal computer 102. Furthermore, in other computing systems suitable for implementing the invention, such as a tablet computer, the display could be overlaid with a touch-screen. In addition to the elements illustrated in
The personal computer 102 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 146. The remote computer 146 may be a server, a router, a peer device, or other common network node, and typically includes many or all of the elements described relative to the personal computer 102. The logical connections depicted in
When used in a LAN networking environment, the personal computer 102 is connected to the LAN 148 through a network interface 152. When used in a WAN networking environment, the personal computer 102 typically includes a modem 154 or other means for establishing communications over the WAN 150, such as the Internet. The modem 154, which may be internal or external, is connected to the system bus 108 via the user input interface 144. In a networked environment, program modules depicted relative to the personal computer 102, or portions thereof, may be stored in the remote memory storage device. It will be appreciated that the network connections shown are exemplary and other means of establishing a communication link between the computers may be used. In addition, the LAN 148 and WAN 150 may be used as a source of nonvolatile storage for the system.
Those skilled in the art will readily recognize that a software application 210 is often comprised of numerous individually identifiable files, including executable modules, dynamically loadable libraries, image files, help files, data files, etc. Thus, it should be understood that while the present discussion refers to a software application 210 as a singular object, it is made as a logical reference to the software application, whether or not the software application is comprised of a single or multiple files.
A validation manifest, in accordance with the present invention, such as validation manifest 204, includes validation information that is used by a validation process 208 to determine whether the corresponding software application 210 is properly installed on the computer. Typically, the validation manifest is provided with the software application 210, or at least available from the software application's vendor. However, according to embodiments of the present invention, some part of the validation manifest may be user configurable. User-configurable validation manifests may be especially important and useful to system administrators to maintain, or enforce, system-wide installation configurations. Additionally, as already mentioned above, a validation manifest 204 may include installation information that an installation manifest would typically include.
The validation manifest 204 includes validation information comprised of validation actions, i.e., tokens and data representing instructions to the validation process 208 to be carried out on the computer 102 and/or software application 210, as well as any expected values or responses for actually determining whether the software application has been properly installed on the computer when the validation actions are carried out. Examples of validation actions carried out by the validation process 208 include, but are not limited to, the following: determining whether specific application files have been created and/or copied to specific locations on the computer 102; determining whether system registry entries have been created and/or set according to specific values, often provided in the validation manifest; determining that shared resources, such as shared libraries or modules, are up to date such that a correct version is installed on the computer; determining whether system environmental settings are properly set, such as search paths and system variables; executing validation/test programs supplied with the software application 210; calling validation/test routines within dynamically loadable libraries associated with the software application; performing check sums on installed files associated with the software application; and determining whether installed files associated with the software application are of the appropriate size and have a correct modification date. Those skilled in the art will recognize that any number of combinations of the above-listed validation actions, or other validation actions, may be placed in a validation manifest to verify that the software application is properly installed.
According to one embodiment, after determining whether the software application 210 is properly installed on the computer 102, the validation process 208 may report its determination and/or findings to the user. Alternatively, the validation process 208, or another cooperative process (not shown), may attempt to correct installation defects that are found during the validation process. For example, the validation process may use information in the validation manifest, such as the installation information described above, to determine what actions are required to correct any installation defects that have been detected.
It should be understood that, while exemplary process 200 described above in regard to
In regard to further understanding how the present invention may be used at some period of time after a suitable software application has been installed,
With reference to
Because the validation process 208 (
Those skilled in the art will recognize that the example described above in regard to
As mentioned above, a validation process 208 obtains the validation manifest 204 and carries out the validation actions within. By monitoring the actual results of the validation actions, possibly comparing the actual results to expected results in the validation manifest 204, the validation process 208 determines whether the software application 210 is properly installed. For illustration purposes, box 402 represents the responses resulting from executing the validation actions. As shown in
While one validation action may result in a positive test, the determination as to whether the software application 210 is properly installed on the computer 102 is determined by executing all of the validation actions in the validation manifest 204, or at least until a negative result is detected. According to one embodiment, it is necessary that all of the validation actions yield positive results in order for the validation process 208 to determine that the software application 210 is properly installed. Alternatively, executing validation actions may cease as soon as one, or a predetermined threshold, of validation actions yield a negative results. Thus, according to this embodiment, not all validation actions need yield a positive result in order for the validation process 208 to determine that the software application 210 is properly installed.
The validation action Library Files 412, for this example, represents instructions to enumerate library files in the director corresponding to “$SRC\EXEC\”, and the expected libraries to be found are listed. In addition to listing the libraries, a validation routine and an expected results generated by the validation routine are supplied, such as shown in box 412 showing RECALC.LIB as one of the libraries to be found, having a validation routine “admin”, and expecting a result of PASS when it is called. As also shown in the actual results, RECALC.LIB is found in the directory, but the call to the validation routine “admin” generated the result FAIL, indicating a problem exists with the library, and possibly the application 210 is not properly installed.
The validation action Shared Libraries 414 for this example, represents instructions to enumerate library files in the director corresponding to “$SHARE\”, and the expected libraries to be found are listed. Also listed are expected library version numbers. Those skilled in the art will recognize that, quite frequently, software applications require shared libraries with a minimal base version, but are tolerant of, or can operate with, later versions. Thus, as shown in box 416, all of the libraries listed in the expected results are found in the actual results, though the corresponding version numbers that are actually installed on the computer 102 are actually higher. In this case it is likely that the validation process 208 will qualify the enumeration and version numbers of all of the shared libraries as a positive result.
As previously mentioned, the verification process 208 may be beneficially utilized by network administrators, and others, to maintain and/or enforce system-wide standard installations.
After recording the detected validation problem, or, if there were no validation problems, at block 612, a determination is made as to whether there are any additional validation actions in the validation manifest 204 to be executed. If there are additional validation actions, at block 614, the next validation action in the validation manifest 204 is selected. The routine 600 then returns to block 606 where the selected validation action is executed. Routine 600 continues until, at block 612, a determination is made that there are no validation actions remaining in the validation manifest 204. Once no additional validation actions are to be executed, at block 616, the validation problems, if any, are reported. Thereafter, the routine 600 terminates.
While the preferred embodiment of the invention has been illustrated and described, it will be appreciated that various changes can be made therein without departing from the spirit and scope of the invention.