US8312430B2 - Guarding code check-in with test case execution results - Google Patents

Guarding code check-in with test case execution results Download PDF

Info

Publication number
US8312430B2
US8312430B2 US12/199,330 US19933008A US8312430B2 US 8312430 B2 US8312430 B2 US 8312430B2 US 19933008 A US19933008 A US 19933008A US 8312430 B2 US8312430 B2 US 8312430B2
Authority
US
United States
Prior art keywords
code
modified copy
repository
source code
regression test
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
Application number
US12/199,330
Other versions
US20100058294A1 (en
Inventor
Debora O'Berry Best
Steven Francis Best
Robert James Eggers, Jr.
Janice Marie Girouard
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
International Business Machines Corp
Original Assignee
International Business Machines Corp
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by International Business Machines Corp filed Critical International Business Machines Corp
Priority to US12/199,330 priority Critical patent/US8312430B2/en
Assigned to INTERNATIONAL BUSINESS MACHINES CORPORATION reassignment INTERNATIONAL BUSINESS MACHINES CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: EGGERS, ROBERT JAMES, JR, BEST, DEBORA O'BERRY, BEST, STEVEN FRANCIS, GIROUARD, JANICE MARIE
Publication of US20100058294A1 publication Critical patent/US20100058294A1/en
Application granted granted Critical
Publication of US8312430B2 publication Critical patent/US8312430B2/en
Expired - Fee Related legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/70Software maintenance or management
    • G06F8/71Version control; Configuration management
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/36Preventing errors by testing or debugging software
    • G06F11/3668Software testing
    • G06F11/3672Test management
    • G06F11/3688Test management for test execution, e.g. scheduling of test suites

Definitions

  • the present invention relates generally to an improved data processing system, and more specifically to providing a source code control system that employs test case execution results to mandate that software code have a specific level of quality for check-in to a central repository.
  • a project may move through multiple cycles in which code is developed, debugged, and delivered for production.
  • a project may also need to be maintained and enhanced past the delivery stage, and may be released multiple times in different versions.
  • a code management system may be used to track all development work and code changes in a set of files and allow a team of developers to collaborate by sharing control of different versions of the source files in a central repository.
  • CVS Concurrent Versions System
  • CVS is a tool that is enables asynchronous collaboration on projects.
  • CVS maintains a history of all versions of the project at each point in the development in a central repository. Users may upload or commit their files to the central repository and download the files onto their local computer for editing. For example, when a source code file is registered with the code management system, a client may download or “check-out” a copy of the source code file onto their local computer from the central repository of the code management system. Once the client is finished editing the file, the client may upload or “check-in” the changes to the edited source file to the central repository of the code management system.
  • a commit in the context of a code management system refers to submitting the latest changes of the source code to the central repository, wherein these changes are made a part of the head source code file in the repository.
  • a head source code file is the latest revision of the source code in the central repository.
  • the version numbers of all files involved with the changes automatically increment, and the code management system writes various data to its log files, including user-supplied description information (e.g., comments explaining the changes that were made), the date, and the code author's name.
  • a commit of a source code file has been performed, a client may still rollback the source code changes committed to the central repository by retrieving a copy of a previous version of the source code file from the central repository.
  • the illustrative embodiments provide a mechanism for providing a source code control system that employs test case execution results to mandate that software code have a specific level of quality for check-in to a central repository.
  • a request to check-in a modified copy of a source code file to a repository is received, wherein the modified copy comprises changes to the source code file located in the repository.
  • the modified copy of the source code file is placed in a quality check pending state in the repository.
  • Responsive to an occurrence of a specific event or expiration of a set time period applicable regression test cases are executed against the changes in the modified copy.
  • a determination is made as to whether the regression test cases are successful. If the regression test cases are successful, the changes in the modified copy are committed to the source code file located in the repository.
  • FIG. 1 depicts a pictorial representation of a distributed data processing system in which the illustrative embodiments may be implemented
  • FIG. 2 is a block diagram of an exemplary data processing system in which the illustrative embodiments may be implemented
  • FIG. 3 is a block diagram of an exemplary code management system with which the illustrative embodiments may be implemented;
  • FIG. 4 is a flowchart of a known process for downloading and uploading source code files in a code management system
  • FIG. 5 is a flowchart of an exemplary process for managing source code files in a code management system in accordance with the illustrative embodiments.
  • the present invention may be embodied as a system, method or computer program product. Accordingly, the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, the present invention may take the form of a computer program product embodied in any tangible medium of expression having computer usable program code embodied in the medium.
  • the computer-usable or computer-readable medium may be, for example but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, device, or propagation medium.
  • the computer-readable medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CDROM), an optical storage device, a transmission media such as those supporting the Internet or an intranet, or a magnetic storage device.
  • a computer-usable or computer-readable medium could even be paper or another suitable medium upon which the program is printed, as the program can be electronically captured, via, for instance, optical scanning of the paper or other medium, then compiled, interpreted, or otherwise processed in a suitable manner, if necessary, and then stored in a computer memory.
  • a computer-usable or computer-readable medium may be any medium 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 computer-usable medium may include a propagated data signal with the computer-usable program code embodied therewith, either in baseband or as part of a carrier wave.
  • the computer usable program code may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc.
  • Computer program code for carrying out operations of the present invention may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages.
  • the program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server.
  • the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
  • LAN local area network
  • WAN wide area network
  • Internet Service Provider for example, AT&T, MCI, Sprint, EarthLink, MSN, GTE, etc.
  • These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
  • These computer program instructions may also be stored in a computer-readable medium that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable medium produce an article of manufacture including instruction means which implement the function/act specified in the flowchart and/or block diagram block or blocks.
  • the computer program instructions may also be loaded onto a computer or other programmable data processing apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
  • FIGS. 1-2 exemplary diagrams of data processing environments are provided in which illustrative embodiments may be implemented. It should be appreciated that FIGS. 1-2 are only exemplary and are not intended to assert or imply any limitation with regard to the environments in which different embodiments may be implemented. Many modifications to the depicted environments may be made.
  • FIG. 1 depicts a pictorial representation of a network of data processing systems in which illustrative embodiments may be implemented.
  • Network data processing system 100 is a network of computers in which the illustrative embodiments may be implemented.
  • Network data processing system 100 contains network 102 , which is the medium used to provide communications links between various devices and computers connected together within network data processing system 100 .
  • Network 102 may include connections, such as wire, wireless communication links, or fiber optic cables.
  • server 104 and server 106 connect to network 102 along with storage unit 108 .
  • clients 110 , 112 , and 114 connect to network 102 .
  • Clients 110 , 112 , and 114 may be, for example, personal computers or network computers.
  • server 104 provides data, such as boot files, operating system images, and applications to clients 110 , 112 , and 114 .
  • Clients 110 , 112 , and 114 are clients to server 104 in this example.
  • Network data processing system 100 may include additional servers, clients, and other devices not shown.
  • network data processing system 100 is the Internet with network 102 representing a worldwide collection of networks and gateways that use the Transmission Control Protocol/Internet Protocol (TCP/IP) suite of protocols to communicate with one another.
  • TCP/IP Transmission Control Protocol/Internet Protocol
  • At the heart of the Internet is a backbone of high-speed data communication lines between major nodes or host computers, consisting of thousands of commercial, governmental, educational and other computer systems that route data and messages.
  • network data processing system 100 also may be implemented as a number of different types of networks, such as for example, an intranet, a local area network (LAN), or a wide area network (WAN).
  • FIG. 1 is intended as an example, and not as an architectural limitation for the different illustrative embodiments.
  • Data processing system 200 is an example of a computer, such as server 104 or client 110 in FIG. 1 , in which computer usable program code or instructions implementing the processes may be located for the illustrative embodiments.
  • data processing system 200 includes communications fabric 202 , which provides communications between processor unit 204 , memory 206 , persistent storage 208 , communications unit 210 , input/output (I/O) unit 212 , and display 214 .
  • Processor unit 204 serves to execute instructions for software that may be loaded into memory 206 .
  • Processor unit 204 may be a set of one or more processors or may be a multi-processor core, depending on the particular implementation. Further, processor unit 204 may be implemented using one or more heterogeneous processor systems in which a main processor is present with secondary processors on a single chip. As another illustrative example, processor unit 204 may be a symmetric multi-processor system containing multiple processors of the same type.
  • Memory 206 and persistent storage 208 are examples of storage devices.
  • a storage device is any piece of hardware that is capable of storing information either on a temporary basis and/or a permanent basis.
  • Memory 206 in these examples, may be, for example, a random access memory or any other suitable volatile or non-volatile storage device.
  • Persistent storage 208 may take various forms depending on the particular implementation.
  • persistent storage 208 may contain one or more components or devices.
  • persistent storage 208 may be a hard drive, a flash memory, a rewritable optical disk, a rewritable magnetic tape, or some combination of the above.
  • the media used by persistent storage 208 also may be removable.
  • a removable hard drive may be used for persistent storage 208 .
  • Communications unit 210 in these examples, provides for communications with other data processing systems or devices.
  • communications unit 210 is a network interface card.
  • Communications unit 210 may provide communications through the use of either or both physical and wireless communications links.
  • Input/output unit 212 allows for input and output of data with other devices that may be connected to data processing system 200 .
  • input/output unit 212 may provide a connection for user input through a keyboard and mouse. Further, input/output unit 212 may send output to a printer.
  • Display 214 provides a mechanism to display information to a user.
  • Instructions for the operating system and applications or programs are located on persistent storage 208 . These instructions may be loaded into memory 206 for execution by processor unit 204 .
  • the processes of the different embodiments may be performed by processor unit 204 using computer implemented instructions, which may be located in a memory, such as memory 206 .
  • These instructions are referred to as program code, computer usable program code, or computer readable program code that may be read and executed by a processor in processor unit 204 .
  • the program code in the different embodiments may be embodied on different physical or tangible computer readable media, such as memory 206 or persistent storage 208 .
  • Program code 216 is located in a functional form on computer readable media 218 that is selectively removable and may be loaded onto or transferred to data processing system 200 for execution by processor unit 204 .
  • Program code 216 and computer readable media 218 form computer program product 220 in these examples.
  • computer readable media 218 may be in a tangible form, such as, for example, an optical or magnetic disc that is inserted or placed into a drive or other device that is part of persistent storage 208 for transfer onto a storage device, such as a hard drive that is part of persistent storage 208 .
  • computer readable media 218 also may take the form of a persistent storage, such as a hard drive, a thumb drive, or a flash memory that is connected to data processing system 200 .
  • the tangible form of computer readable media 218 is also referred to as computer recordable storage media. In some instances, computer recordable media 218 may not be removable.
  • program code 216 may be transferred to data processing system 200 from computer readable media 218 through a communications link to communications unit 210 and/or through a connection to input/output unit 212 .
  • the communications link and/or the connection may be physical or wireless in the illustrative examples.
  • the computer readable media also may take the form of non-tangible media, such as communications links or wireless transmissions containing the program code.
  • data processing system 200 The different components illustrated for data processing system 200 are not meant to provide architectural limitations to the manner in which different embodiments may be implemented.
  • the different illustrative embodiments may be implemented in a data processing system including components in addition to or in place of those illustrated for data processing system 200 .
  • Other components shown in FIG. 2 can be varied from the illustrative examples shown.
  • a storage device in data processing system 200 is any hardware apparatus that may store data.
  • Memory 206 , persistent storage 208 , and computer readable media 218 are examples of storage devices in a tangible form.
  • a bus system may be used to implement communications fabric 202 and may be comprised of one or more buses, such as a system bus or an input/output bus.
  • the bus system may be implemented using any suitable type of architecture that provides for a transfer of data between different components or devices attached to the bus system.
  • a communications unit may include one or more devices used to transmit and receive data, such as a modem or a network adapter.
  • a memory may be, for example, memory 206 or a cache such as found in an interface and memory controller hub that may be present in communications fabric 202 .
  • a software build comprises a compilation process in which source code files are converted into executable code.
  • software development projects e.g., Advanced Interactive ExecutiveTM (AIX®), Lotus Notes®, Microsoft Outlook®, WebSphere®, among others
  • AIX® Advanced Interactive ExecutiveTM
  • Lotus Notes® Lotus Notes®
  • Microsoft Outlook® WebSphere®
  • Regression testing is the process of repeating tests that have already run successfully and comparing the new results with the earlier valid results. As the project moves ahead and acquires new or rewritten code, one or more additional tests are run, debugged, and rerun until the project successfully passes the tests. If there is a malfunction or failure in one of the regression tests, a developer may determine that the malfunction resulted from code changes made since the last test run.
  • a code management system is used to track code changes in a set of files and allow developers to collaborate by sharing control of different versions of the source files in a central repository.
  • a client may download or “check-out” a copy of a source file from the central repository, and later upload or “check-in” the changes made to the copy to the central repository.
  • the check-in operation comprises placing the code changes in a library. If the check-in operation is determined to be valid, the commit operation then commits these changes to the source code file in the central repository (i.e., makes the changes a part of the product or finalizes the changes).
  • the illustrative embodiments address this problem by providing an enhancement to existing code management tools (e.g., CVS) which allows for automatically controlling the state of the code check-in process and testing the code quality.
  • CVS code management tools
  • the mechanism of the illustrative embodiments requires that a developer provide a specific level of code quality when uploading code to the code management system, thereby increasing the ability of a software development project to achieve successful build processes.
  • the mechanism of the illustrative embodiments provides developers with early feedback on their work.
  • the mechanism of the illustrative embodiments introduces a “quality check pending” state in the check-in process.
  • the quality check pending state is a state in the check-in process in which edited code submitted to the code management system is automatically tested until the quality of the pending code may be verified.
  • the edited code remains in the quality check pending state to ensure the code meets a minimum level of acceptable code quality before being committed to the central repository of the project.
  • the edited copy of source code is automatically placed in the central repository in the quality check pending state.
  • the edited copy of source code (and other pending software code changes) is automatically pulled into a software delivery (build) environment.
  • a build process is automatically performed and appropriate regression test buckets are automatically triggered for the quality check pending code.
  • the regression test buckets are used to run appropriate regression tests on the quality check pending code prior to the code being checked-in (committed) to the central repository. If the test case is not executed successfully, the edited code is not committed to the central repository, not included in any build, nor is it given to any subsequent developer when they checkout code.
  • the software delivery environment notifies the code management system that the check-in process of the edited copy of source code is allowed to complete.
  • the edited copy of source code may then be automatically committed to the central repository.
  • FIG. 3 is a block diagram of an exemplary code management system with which the illustrative embodiments may be implemented.
  • Code management system 300 may be implemented in a distributed computing environment, such as network data processing system 100 in FIG. 1 .
  • code management system 300 comprises code management system server 302 , clients 304 , 306 , and 308 , and code management database 310 .
  • Code management system 300 may include additional clients and other devices not shown.
  • Code management server 302 keeps track of the source code files sorted into directories in the code management database 310 . Code management server 302 records the changes to the source files over time and maintains a version history of these files.
  • Code management database 310 is a central repository which stores master copies of the source files and revision histories for a project. Each project has one code management database. Developers at clients 304 , 306 , and 308 may request personal working copies of the source code files from code management server 302 . A developer's personal working copy is the local source code file copy in which the developer may make changes to the project. The developer “checks-out” a personal working copy of a source code file from the code management system server.
  • the process of checking-out a file comprises retrieving a copy of the requested file from the code management database and storing the working copy to a local directory of files.
  • the developer may then edit the personal working copy in the developer's local directory.
  • Each developer may request their own personal working copy from the code management database. Consequently, a developer may make changes to the developer's own working copy independently from other working copies checked-out by other developers.
  • the developer Upon completing changes to the developer's personal working copy, the developer then “checks-in” this working copy to code management server 302 .
  • the process of checking-in a file copy to the code management server consists of the developer providing the edited working copy to the code management server. If the code management server determines the check-in operation is valid, the edited working copy may then be committed to the code management database.
  • a commit in this context refers to submitting the latest changes of the source code to the central repository and making these changes a permanent part of the head source code file revision in the repository.
  • a revision in this context refers to a committed change in the history of a file or set of files.
  • the code management server upon the developer checking-in an edited working copy of a source file, the code management server commits the edited working copy to the code management database by incorporating these changes permanently into the master copy of the source file in the database.
  • existing code management tools do not require that code being checked-in meet a specific level of code quality.
  • code management server 302 when a developer finishes editing the working copy and checks-in the copy to code management server 302 , code management server 302 places the edited copy in a “quality check pending” state.
  • the pending software changes are placed in code management database 310 separate from the base code of the project.
  • a set time period e.g. 1 hour, 24 hours, or until a particular time of day
  • pending software code changes in code management server 302 are pulled into software delivery environment 312 .
  • Software delivery environment 312 comprises a build mechanism that converts source code files into executable code and a regression test mechanism that tests the software code to identify regression bugs. Regression bugs occur whenever software functionality that previously worked as desired stops working or no longer works in the same way that was previously planned (usually as a unintended consequence of software code changes).
  • a regression test bucket is automatically applied to the pending code.
  • the regression test bucket comprises appropriate test cases which are executed against the pending code to ensure the pending code meets a minimum level of code quality.
  • software delivery environment 312 notifies code management system 302 that the check-in process of the pending code may complete. Subsequently, code management server 302 may then permanently commit the pending code to the code base in code management database 310 .
  • code management server 302 may retry the regression test cases.
  • code management server 302 may use a technique such as a binary search algorithm to locate the offending software code change which causes the build to break. For example, if there are 12 changes in the batch of pending code, the binary search algorithm may divide the code changes into two groups, and then re-run the regression tests against each of the groups. If the regression tests are successful against the first code change group, the offending code change is determined to be located in the second code change groups. Code management server 302 may continue to employ the binary search algorithm in this manner until the particular offending code change is identified.
  • a technique such as a binary search algorithm
  • Code management server 302 continues to use the binary search algorithm until the particular offending code change is identified in this group. By using a binary search algorithm in this manner, code management server 302 may automatically identify the error-causing culprit without requiring costly manual intervention.
  • the offending code change is assigned a software bug identifier (ID).
  • ID software bug identifier
  • Code management server 302 may automatically back out any code in the pending code files that have caused the regression tests to fail. These code changes may be identified and backed out of the pending code files per software bug ID. Since all of the remaining pending code changes successfully passed the test cases, code management server 302 may move these pending code changes out of the quality check pending state and permanently commit the pending code changes to the code base in code management database 310 .
  • FIG. 4 is a flowchart of a known process for downloading and uploading source files in a code management system.
  • a central repository comprises the master copies of the source code files for a project. These master copies comprise a project's full revision history.
  • the central repository is a code management database comprising several source code files for a project, including File_X (version A of the source code), File_Y (version B of the source code), and File_Z (version C of the source code).
  • the process begins when a developer sends a request to the code management system to “check-out” a personal working copy of a source code file, such as File_X (version A) (step 402 ).
  • the developer edits the personal working copy, wherein the edits change the developer's working copy of File_X (version A) into File_X′ (version A+1) (step 404 ).
  • the developer Upon completing changes to the developer's personal working copy, the developer then “checks-in” this working copy to the code management system (step 406 ).
  • a software build comprises a compilation process in which source code files are converted into executable code.
  • the build process of the latest version of the source code files may be manually invoked or automated to occur on a specific event or after a certain time period has elapsed.
  • the code management system makes a determination as to whether the build is successful (step 408 ). If the build is successful (‘yes’ output of step 408 ), the process terminates thereafter. However, if the build is not successful (‘no’ output of step 408 ), the code management system notifies the developer that the build was unsuccessful (step 410 ). This notification may be made through common bugtracker tools, such as, for example, Bugzilla.
  • step 402 the developer checks-out the offending file.
  • the developer must re-edit the file (step 404 ) and check-in the re-edited file to the code management database (step 406 ).
  • the build is repeated again (step 408 ) until the build process is successful.
  • FIG. 5 is a flowchart of a process for managing source files in a code management system in accordance with the illustrative embodiments.
  • the process described in FIG. 5 provides an enhancement to existing code management tools by introducing the “quality check pending” state into the code check-in process.
  • Steps 502 - 514 represent existing code check-in processes
  • steps 516 - 526 represent the quality check pending process in accordance with the illustrative embodiments.
  • As code is checked-in to the code management system the code is placed in the quality check pending state and a particular regression test bucket may be automatically triggered for the pending code. The code will only be committed to the repository if the test cases are successfully executed. Consequently, the process described in FIG. 5 requires that developers provide a specific level of code quality when uploading code to the code management system.
  • a code management database in the code management system comprises several source code files for a project, including File_X (version A of the source code), File_X (version A′ of the source code), File_Y (version B of the source code), and File_Z (version C of the source code).
  • File_X version A of the source code
  • File_X version A′ of the source code
  • File_Y version B of the source code
  • File_Z version C of the source code.
  • the code management system allows the developer to check-out a personal working copy of File_X (version A′) (step 504 ).
  • the developer edits the working copy in the developer's local directory, wherein the edits change the working copy of File_X (version A′) into File_X (version A′+1) (step 506 ).
  • the developer Upon completing changes to the developer's personal working copy, the developer then checks-in the working copy of File_X (version A′+1) to the code management database (step 508 ).
  • step 502 if a working copy of the finalized version of File_X (version A′) has not been requested by the developer (‘no’ output of step 502 ), the code management system allows the developer to retrieve a copy of a previous version of File_X, or version A (step 510 ).
  • the developer edits the working copy in the developer's local directory and changes the working copy of File_X (version A) into File_X (version A+1) (step 512 ).
  • the developer Upon completing changes to the developer's own working copy, the developer then checks-in the working copy of File_X (version A+1) to the code management database (step 514 ).
  • the check-in process comprises having the developer provide the edited working copy to the code management system, and the code management system places the edited working copy of the source code from a developer in a quality check pending state and run regression tests against the pending code while the pending code is in the quality check pending state. Only if the regression tests executed on the pending code are successful will the pending code be committed to the code management database. If the regression tests are not successful, the code management system backs out the pending code and does not commit the pending code to the code management database.
  • an edited working copy of a source file is placed in a quality check pending state.
  • the pending software changes in the code management database are pulled into a software delivery environment.
  • a software build is performed comprising regression tests against the pending code changes.
  • the build process begins by first setting the current Start and End values of the build (step 516 ).
  • Start and End values indicate the range of code changes in the list of code changes against which the build process will be executed (e.g., code changes 1, 2, and 3).
  • a determination is then made by the build mechanism as to whether the build process is successful (step 520 ). If the build process is successful (‘yes’ output of step 520 ), the build process finalizes the code changes from the current Start value to the current End value (step 522 ). The build process finalizes the code changes by committing the changes (i.e., moving the changes out of the pending verification state to a permanently applied state). The build process then determines if the current end code change value equals the total number of pending code changes (End M) (step 524 ).
  • step 520 if the build process is not successful (‘no’ output of step 520 ), the build process makes a determination as to whether the current Start value is equal to the current End value (step 528 ). If the current Start value is not equal to the current End value (‘no’ output of step 528 ), the build process attempts to reduce the number of pending code changes processed in the build in order to locate the offending code changes that caused the build to break. The build process sets the current End value ((End+1 ⁇ Start)/2), and sets the current End′ value to the new End value (step 530 ). The process then returns to step 518 in which the build process is re-executed with the new current Start, End, and End′ values reflecting the reduced number of code changes. The build process may continue to execute and, if unsuccessful, continue to reduce the number of code changes in each build according to step 530 until the offending change is identified.
  • step 528 if the current Start value is equal to the current End value (‘yes’ output of step 528 ), the build process has identified the code change that has caused the build to break. The build process may automatically back out any code in the pending code files that have caused the regression tests in the build process to fail. The build process assigns a software bug ID to the offending code change, and the build process then backs out the code change associated with the software bug ID (step 532 ). The build process then sets the current Start value to End+ 1 , sets the current End value to M, and sets the current End′ value to M (step 534 ). The process then returns to step 518 in which the build process is re-executed with the new current Start, End, and End′ values.
  • Start and End values of the build are set to 1 and 12, respectively. End′ value is also set to 12. If the build process is successful, the code changes from Start value 1 to the End value 12 are committed to the database. If the End value equals the total number of pending code changes (12 in this example), the process ends since all of the pending code changes have been processed in the build and the build process was successful.
  • End value is set to (End+1 ⁇ Start)/2, or 6 in this example.
  • End′ value is also set to the End value of 6.
  • the build process has identified the code change that has caused the build to break. This code change may be backed out of the pending code files.
  • the current Start value is then set to End+1(4 in this example), sets the current End value to M (12), and sets the current End′ value to M (12) in order to process the remaining pending code changes.
  • each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s).
  • the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved.
  • the invention can take the form of an entirely hardware embodiment, an entirely software embodiment or an embodiment containing both hardware and software elements.
  • the invention is implemented in software, which includes but is not limited to firmware, resident software, microcode, etc.
  • 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 tangible 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 modem and Ethernet cards are just a few of the currently available types of network adapters.

Abstract

A mechanism for providing a source code control system that employs test case execution results to mandate that software code have a specific level of quality for check-in to a central repository. A request to check-in a modified copy of a source code file to a repository is received, wherein the modified copy comprises changes to the source code file located in the repository. The modified copy of the source code file is placed in a quality check pending state in the repository. Responsive to an occurrence of a specific event or expiration of a set time period, applicable regression test cases are executed against the changes in the modified copy. A determination is made as to whether the regression test cases are successful. If the regression test cases are successful, the changes in the modified copy are committed to the source code file located in the repository.

Description

BACKGROUND OF THE INVENTION
1. Field of the Invention
The present invention relates generally to an improved data processing system, and more specifically to providing a source code control system that employs test case execution results to mandate that software code have a specific level of quality for check-in to a central repository.
2. Description of the Related Art
In the field of software development, a project may move through multiple cycles in which code is developed, debugged, and delivered for production. A project may also need to be maintained and enhanced past the delivery stage, and may be released multiple times in different versions. To monitor the evolution of code through the development process, a code management system may be used to track all development work and code changes in a set of files and allow a team of developers to collaborate by sharing control of different versions of the source files in a central repository.
One example of a code management system is the Concurrent Versions System (CVS). CVS is a tool that is enables asynchronous collaboration on projects. CVS maintains a history of all versions of the project at each point in the development in a central repository. Users may upload or commit their files to the central repository and download the files onto their local computer for editing. For example, when a source code file is registered with the code management system, a client may download or “check-out” a copy of the source code file onto their local computer from the central repository of the code management system. Once the client is finished editing the file, the client may upload or “check-in” the changes to the edited source file to the central repository of the code management system. If the check-in operation is successful, the code management system commits these changes to the source code file in the central repository. A commit in the context of a code management system refers to submitting the latest changes of the source code to the central repository, wherein these changes are made a part of the head source code file in the repository. A head source code file is the latest revision of the source code in the central repository. The version numbers of all files involved with the changes automatically increment, and the code management system writes various data to its log files, including user-supplied description information (e.g., comments explaining the changes that were made), the date, and the code author's name. If a commit of a source code file has been performed, a client may still rollback the source code changes committed to the central repository by retrieving a copy of a previous version of the source code file from the central repository.
BRIEF SUMMARY OF THE INVENTION
The illustrative embodiments provide a mechanism for providing a source code control system that employs test case execution results to mandate that software code have a specific level of quality for check-in to a central repository. A request to check-in a modified copy of a source code file to a repository is received, wherein the modified copy comprises changes to the source code file located in the repository. The modified copy of the source code file is placed in a quality check pending state in the repository. Responsive to an occurrence of a specific event or expiration of a set time period, applicable regression test cases are executed against the changes in the modified copy. A determination is made as to whether the regression test cases are successful. If the regression test cases are successful, the changes in the modified copy are committed to the source code file located in the repository.
BRIEF DESCRIPTION OF THE SEVERAL VIEWS OF THE DRAWINGS
FIG. 1 depicts a pictorial representation of a distributed data processing system in which the illustrative embodiments may be implemented;
FIG. 2 is a block diagram of an exemplary data processing system in which the illustrative embodiments may be implemented;
FIG. 3 is a block diagram of an exemplary code management system with which the illustrative embodiments may be implemented;
FIG. 4 is a flowchart of a known process for downloading and uploading source code files in a code management system; and
FIG. 5 is a flowchart of an exemplary process for managing source code files in a code management system in accordance with the illustrative embodiments.
DETAILED DESCRIPTION OF THE INVENTION
As will be appreciated by one skilled in the art, the present invention may be embodied as a system, method or computer program product. Accordingly, the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, the present invention may take the form of a computer program product embodied in any tangible medium of expression having computer usable program code embodied in the medium.
Any combination of one or more computer usable or computer readable medium(s) may be utilized. The computer-usable or computer-readable medium may be, for example but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, device, or propagation medium. More specific examples (a non-exhaustive list) of the computer-readable medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CDROM), an optical storage device, a transmission media such as those supporting the Internet or an intranet, or a magnetic storage device. Note that the computer-usable or computer-readable medium could even be paper or another suitable medium upon which the program is printed, as the program can be electronically captured, via, for instance, optical scanning of the paper or other medium, then compiled, interpreted, or otherwise processed in a suitable manner, if necessary, and then stored in a computer memory. In the context of this document, a computer-usable or computer-readable medium may be any medium 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 computer-usable medium may include a propagated data signal with the computer-usable program code embodied therewith, either in baseband or as part of a carrier wave. The computer usable program code may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc.
Computer program code for carrying out operations of the present invention may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
The present invention is described below with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions.
These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. These computer program instructions may also be stored in a computer-readable medium that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable medium produce an article of manufacture including instruction means which implement the function/act specified in the flowchart and/or block diagram block or blocks.
The computer program instructions may also be loaded onto a computer or other programmable data processing apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
With reference now to the figures and in particular with reference to FIGS. 1-2, exemplary diagrams of data processing environments are provided in which illustrative embodiments may be implemented. It should be appreciated that FIGS. 1-2 are only exemplary and are not intended to assert or imply any limitation with regard to the environments in which different embodiments may be implemented. Many modifications to the depicted environments may be made.
FIG. 1 depicts a pictorial representation of a network of data processing systems in which illustrative embodiments may be implemented. Network data processing system 100 is a network of computers in which the illustrative embodiments may be implemented. Network data processing system 100 contains network 102, which is the medium used to provide communications links between various devices and computers connected together within network data processing system 100. Network 102 may include connections, such as wire, wireless communication links, or fiber optic cables.
In the depicted example, server 104 and server 106 connect to network 102 along with storage unit 108. In addition, clients 110, 112, and 114 connect to network 102. Clients 110, 112, and 114 may be, for example, personal computers or network computers. In the depicted example, server 104 provides data, such as boot files, operating system images, and applications to clients 110, 112, and 114. Clients 110, 112, and 114 are clients to server 104 in this example. Network data processing system 100 may include additional servers, clients, and other devices not shown.
In the depicted example, network data processing system 100 is the Internet with network 102 representing a worldwide collection of networks and gateways that use the Transmission Control Protocol/Internet Protocol (TCP/IP) suite of protocols to communicate with one another. At the heart of the Internet is a backbone of high-speed data communication lines between major nodes or host computers, consisting of thousands of commercial, governmental, educational and other computer systems that route data and messages. Of course, network data processing system 100 also may be implemented as a number of different types of networks, such as for example, an intranet, a local area network (LAN), or a wide area network (WAN). FIG. 1 is intended as an example, and not as an architectural limitation for the different illustrative embodiments.
With reference now to FIG. 2, a block diagram of a data processing system is shown in which illustrative embodiments may be implemented. Data processing system 200 is an example of a computer, such as server 104 or client 110 in FIG. 1, in which computer usable program code or instructions implementing the processes may be located for the illustrative embodiments. In this illustrative example, data processing system 200 includes communications fabric 202, which provides communications between processor unit 204, memory 206, persistent storage 208, communications unit 210, input/output (I/O) unit 212, and display 214.
Processor unit 204 serves to execute instructions for software that may be loaded into memory 206. Processor unit 204 may be a set of one or more processors or may be a multi-processor core, depending on the particular implementation. Further, processor unit 204 may be implemented using one or more heterogeneous processor systems in which a main processor is present with secondary processors on a single chip. As another illustrative example, processor unit 204 may be a symmetric multi-processor system containing multiple processors of the same type.
Memory 206 and persistent storage 208 are examples of storage devices. A storage device is any piece of hardware that is capable of storing information either on a temporary basis and/or a permanent basis. Memory 206, in these examples, may be, for example, a random access memory or any other suitable volatile or non-volatile storage device. Persistent storage 208 may take various forms depending on the particular implementation. For example, persistent storage 208 may contain one or more components or devices. For example, persistent storage 208 may be a hard drive, a flash memory, a rewritable optical disk, a rewritable magnetic tape, or some combination of the above. The media used by persistent storage 208 also may be removable. For example, a removable hard drive may be used for persistent storage 208.
Communications unit 210, in these examples, provides for communications with other data processing systems or devices. In these examples, communications unit 210 is a network interface card. Communications unit 210 may provide communications through the use of either or both physical and wireless communications links.
Input/output unit 212 allows for input and output of data with other devices that may be connected to data processing system 200. For example, input/output unit 212 may provide a connection for user input through a keyboard and mouse. Further, input/output unit 212 may send output to a printer. Display 214 provides a mechanism to display information to a user.
Instructions for the operating system and applications or programs are located on persistent storage 208. These instructions may be loaded into memory 206 for execution by processor unit 204. The processes of the different embodiments may be performed by processor unit 204 using computer implemented instructions, which may be located in a memory, such as memory 206. These instructions are referred to as program code, computer usable program code, or computer readable program code that may be read and executed by a processor in processor unit 204. The program code in the different embodiments may be embodied on different physical or tangible computer readable media, such as memory 206 or persistent storage 208.
Program code 216 is located in a functional form on computer readable media 218 that is selectively removable and may be loaded onto or transferred to data processing system 200 for execution by processor unit 204. Program code 216 and computer readable media 218 form computer program product 220 in these examples. In one example, computer readable media 218 may be in a tangible form, such as, for example, an optical or magnetic disc that is inserted or placed into a drive or other device that is part of persistent storage 208 for transfer onto a storage device, such as a hard drive that is part of persistent storage 208. In a tangible form, computer readable media 218 also may take the form of a persistent storage, such as a hard drive, a thumb drive, or a flash memory that is connected to data processing system 200. The tangible form of computer readable media 218 is also referred to as computer recordable storage media. In some instances, computer recordable media 218 may not be removable.
Alternatively, program code 216 may be transferred to data processing system 200 from computer readable media 218 through a communications link to communications unit 210 and/or through a connection to input/output unit 212. The communications link and/or the connection may be physical or wireless in the illustrative examples. The computer readable media also may take the form of non-tangible media, such as communications links or wireless transmissions containing the program code.
The different components illustrated for data processing system 200 are not meant to provide architectural limitations to the manner in which different embodiments may be implemented. The different illustrative embodiments may be implemented in a data processing system including components in addition to or in place of those illustrated for data processing system 200. Other components shown in FIG. 2 can be varied from the illustrative examples shown.
As one example, a storage device in data processing system 200 is any hardware apparatus that may store data. Memory 206, persistent storage 208, and computer readable media 218 are examples of storage devices in a tangible form. In another example, a bus system may be used to implement communications fabric 202 and may be comprised of one or more buses, such as a system bus or an input/output bus. Of course, the bus system may be implemented using any suitable type of architecture that provides for a transfer of data between different components or devices attached to the bus system. Additionally, a communications unit may include one or more devices used to transmit and receive data, such as a modem or a network adapter. Further, a memory may be, for example, memory 206 or a cache such as found in an interface and memory controller hub that may be present in communications fabric 202.
A software build comprises a compilation process in which source code files are converted into executable code. In the software development field today, it is not unusual for very large software development projects (e.g., Advanced Interactive Executive™ (AIX®), Lotus Notes®, Microsoft Outlook®, WebSphere®, among others) to experience difficulties during the software build process. These large projects may often continue for days (or sometimes even weeks) between project builds that have no regression failures. Regression testing is the process of repeating tests that have already run successfully and comparing the new results with the earlier valid results. As the project moves ahead and acquires new or rewritten code, one or more additional tests are run, debugged, and rerun until the project successfully passes the tests. If there is a malfunction or failure in one of the regression tests, a developer may determine that the malfunction resulted from code changes made since the last test run.
As previously mentioned, a code management system is used to track code changes in a set of files and allow developers to collaborate by sharing control of different versions of the source files in a central repository. A client may download or “check-out” a copy of a source file from the central repository, and later upload or “check-in” the changes made to the copy to the central repository. There are currently two steps to finalize a code change—“check-in” and “commit”. The check-in operation comprises placing the code changes in a library. If the check-in operation is determined to be valid, the commit operation then commits these changes to the source code file in the central repository (i.e., makes the changes a part of the product or finalizes the changes). A problem with existing processes in the current art is that these check-in and commit processes are performed manually. In addition, existing code management tools allow developers to check-in code into the central repository without mandating a specific level of code quality. Taking into consideration the high complexity and component interdependencies large software development projects usually have, by not requiring a specific level of code quality in the code check-in, it can be difficult for these large software development projects to achieve successful build processes due to unacceptable code being committed to the repository.
The illustrative embodiments address this problem by providing an enhancement to existing code management tools (e.g., CVS) which allows for automatically controlling the state of the code check-in process and testing the code quality. The mechanism of the illustrative embodiments requires that a developer provide a specific level of code quality when uploading code to the code management system, thereby increasing the ability of a software development project to achieve successful build processes. In addition, by mandating a specific level of code quality be checked-in to the code management system for a project, the mechanism of the illustrative embodiments provides developers with early feedback on their work.
To implement the aspects of the illustrative embodiments, the mechanism of the illustrative embodiments introduces a “quality check pending” state in the check-in process. The quality check pending state is a state in the check-in process in which edited code submitted to the code management system is automatically tested until the quality of the pending code may be verified. The edited code remains in the quality check pending state to ensure the code meets a minimum level of acceptable code quality before being committed to the central repository of the project. When an edited copy of source code is checked into the code management system, the edited copy of source code is automatically placed in the central repository in the quality check pending state. Upon the occurrence of a defined event or the expiration of a set time period, the edited copy of source code (and other pending software code changes) is automatically pulled into a software delivery (build) environment. Within the software delivery environment, a build process is automatically performed and appropriate regression test buckets are automatically triggered for the quality check pending code. The regression test buckets are used to run appropriate regression tests on the quality check pending code prior to the code being checked-in (committed) to the central repository. If the test case is not executed successfully, the edited code is not committed to the central repository, not included in any build, nor is it given to any subsequent developer when they checkout code. If the test case is executed successfully (i.e., the code meets a specific level of quality), the software delivery environment notifies the code management system that the check-in process of the edited copy of source code is allowed to complete. The edited copy of source code may then be automatically committed to the central repository.
FIG. 3 is a block diagram of an exemplary code management system with which the illustrative embodiments may be implemented. Code management system 300 may be implemented in a distributed computing environment, such as network data processing system 100 in FIG. 1. In this illustrative example, code management system 300 comprises code management system server 302, clients 304, 306, and 308, and code management database 310. Code management system 300 may include additional clients and other devices not shown.
Code management server 302 keeps track of the source code files sorted into directories in the code management database 310. Code management server 302 records the changes to the source files over time and maintains a version history of these files. Code management database 310 is a central repository which stores master copies of the source files and revision histories for a project. Each project has one code management database. Developers at clients 304, 306, and 308 may request personal working copies of the source code files from code management server 302. A developer's personal working copy is the local source code file copy in which the developer may make changes to the project. The developer “checks-out” a personal working copy of a source code file from the code management system server. The process of checking-out a file comprises retrieving a copy of the requested file from the code management database and storing the working copy to a local directory of files. The developer may then edit the personal working copy in the developer's local directory. Each developer may request their own personal working copy from the code management database. Consequently, a developer may make changes to the developer's own working copy independently from other working copies checked-out by other developers.
Upon completing changes to the developer's personal working copy, the developer then “checks-in” this working copy to code management server 302. In existing code management systems, the process of checking-in a file copy to the code management server consists of the developer providing the edited working copy to the code management server. If the code management server determines the check-in operation is valid, the edited working copy may then be committed to the code management database. A commit in this context refers to submitting the latest changes of the source code to the central repository and making these changes a permanent part of the head source code file revision in the repository. A revision in this context refers to a committed change in the history of a file or set of files. Thus, in existing code management systems (and as illustrated in FIG. 4), upon the developer checking-in an edited working copy of a source file, the code management server commits the edited working copy to the code management database by incorporating these changes permanently into the master copy of the source file in the database. Thus, existing code management tools do not require that code being checked-in meet a specific level of code quality.
In contrast, with the mechanism in the illustrative embodiments, when a developer finishes editing the working copy and checks-in the copy to code management server 302, code management server 302 places the edited copy in a “quality check pending” state. The pending software changes are placed in code management database 310 separate from the base code of the project. Upon the occurrence of a defined event or the expiration of a set time period (e.g., 1 hour, 24 hours, or until a particular time of day), pending software code changes in code management server 302 are pulled into software delivery environment 312. Software delivery environment 312 comprises a build mechanism that converts source code files into executable code and a regression test mechanism that tests the software code to identify regression bugs. Regression bugs occur whenever software functionality that previously worked as desired stops working or no longer works in the same way that was previously planned (usually as a unintended consequence of software code changes).
Within software delivery environment 312, a regression test bucket is automatically applied to the pending code. The regression test bucket comprises appropriate test cases which are executed against the pending code to ensure the pending code meets a minimum level of code quality. When all of the relevant test cases have successfully executed against the pending code, software delivery environment 312 notifies code management system 302 that the check-in process of the pending code may complete. Subsequently, code management server 302 may then permanently commit the pending code to the code base in code management database 310.
However, if the regression testing of any one of the pending code files results in a failure, code management server 302 may retry the regression test cases. In one embodiment, code management server 302 may use a technique such as a binary search algorithm to locate the offending software code change which causes the build to break. For example, if there are 12 changes in the batch of pending code, the binary search algorithm may divide the code changes into two groups, and then re-run the regression tests against each of the groups. If the regression tests are successful against the first code change group, the offending code change is determined to be located in the second code change groups. Code management server 302 may continue to employ the binary search algorithm in this manner until the particular offending code change is identified. Likewise, if the regression tests are not successful against the initial batch of code, the offending code change is determined to be located in the tested code change group. Code management server 302 continues to use the binary search algorithm until the particular offending code change is identified in this group. By using a binary search algorithm in this manner, code management server 302 may automatically identify the error-causing culprit without requiring costly manual intervention.
Once the offending change is located, the offending code change is assigned a software bug identifier (ID). Code management server 302 may automatically back out any code in the pending code files that have caused the regression tests to fail. These code changes may be identified and backed out of the pending code files per software bug ID. Since all of the remaining pending code changes successfully passed the test cases, code management server 302 may move these pending code changes out of the quality check pending state and permanently commit the pending code changes to the code base in code management database 310.
FIG. 4 is a flowchart of a known process for downloading and uploading source files in a code management system. Within the code management system, a central repository comprises the master copies of the source code files for a project. These master copies comprise a project's full revision history. In this illustrative example, the central repository is a code management database comprising several source code files for a project, including File_X (version A of the source code), File_Y (version B of the source code), and File_Z (version C of the source code).
The process begins when a developer sends a request to the code management system to “check-out” a personal working copy of a source code file, such as File_X (version A) (step 402). The developer edits the personal working copy, wherein the edits change the developer's working copy of File_X (version A) into File_X′ (version A+1) (step 404). Upon completing changes to the developer's personal working copy, the developer then “checks-in” this working copy to the code management system (step 406).
A software build comprises a compilation process in which source code files are converted into executable code. The build process of the latest version of the source code files may be manually invoked or automated to occur on a specific event or after a certain time period has elapsed. When the build process of the latest version of the source code files in the code management database is performed, the code management system makes a determination as to whether the build is successful (step 408). If the build is successful (‘yes’ output of step 408), the process terminates thereafter. However, if the build is not successful (‘no’ output of step 408), the code management system notifies the developer that the build was unsuccessful (step 410). This notification may be made through common bugtracker tools, such as, for example, Bugzilla. If changes to multiple files were made since the last successful build, the developer may determine which of the edited files likely caused the error. The process then returns to step 402, wherein the developer checks-out the offending file. The developer must re-edit the file (step 404) and check-in the re-edited file to the code management database (step 406). The build is repeated again (step 408) until the build process is successful.
FIG. 5 is a flowchart of a process for managing source files in a code management system in accordance with the illustrative embodiments. The process described in FIG. 5 provides an enhancement to existing code management tools by introducing the “quality check pending” state into the code check-in process. Steps 502-514 represent existing code check-in processes, and steps 516-526 represent the quality check pending process in accordance with the illustrative embodiments. As code is checked-in to the code management system, the code is placed in the quality check pending state and a particular regression test bucket may be automatically triggered for the pending code. The code will only be committed to the repository if the test cases are successfully executed. Consequently, the process described in FIG. 5 requires that developers provide a specific level of code quality when uploading code to the code management system.
In this illustrative example, a code management database in the code management system comprises several source code files for a project, including File_X (version A of the source code), File_X (version A′ of the source code), File_Y (version B of the source code), and File_Z (version C of the source code). When a developer wants to check-out a working copy of a source code file, such as File_X, if the source code file has multiple versions, the code management system identifies the specific version requested by the developer. In this example check-out process, the code management system determines whether the developer has requested a working copy of the finalized version of File_X (version A′) (step 502). If a working copy of the finalized version of File_X (version A′) has been requested by the developer (‘yes’ output of step 502), the code management system allows the developer to check-out a personal working copy of File_X (version A′) (step 504). The developer edits the working copy in the developer's local directory, wherein the edits change the working copy of File_X (version A′) into File_X (version A′+1) (step 506). Upon completing changes to the developer's personal working copy, the developer then checks-in the working copy of File_X (version A′+1) to the code management database (step 508).
Turning back to step 502, if a working copy of the finalized version of File_X (version A′) has not been requested by the developer (‘no’ output of step 502), the code management system allows the developer to retrieve a copy of a previous version of File_X, or version A (step 510). The developer edits the working copy in the developer's local directory and changes the working copy of File_X (version A) into File_X (version A+1) (step 512). Upon completing changes to the developer's own working copy, the developer then checks-in the working copy of File_X (version A+1) to the code management database (step 514).
In contrast with the process in FIG. 4, the check-in process according the mechanism of the illustrative embodiments comprises having the developer provide the edited working copy to the code management system, and the code management system places the edited working copy of the source code from a developer in a quality check pending state and run regression tests against the pending code while the pending code is in the quality check pending state. Only if the regression tests executed on the pending code are successful will the pending code be committed to the code management database. If the regression tests are not successful, the code management system backs out the pending code and does not commit the pending code to the code management database.
As mentioned previously, an edited working copy of a source file is placed in a quality check pending state. Upon the occurrence of a specific event or the expiration of a set time period, the pending software changes in the code management database are pulled into a software delivery environment. In the software delivery environment, a software build is performed comprising regression tests against the pending code changes. The build process begins by first setting the current Start and End values of the build (step 516). In this example, there are “M” pending code changes. The Start value and End values indicate the range of code changes in the list of code changes against which the build process will be executed (e.g., code changes 1, 2, and 3). End′ is the last known endpoint in the failed build sequence (e.g., if code changes 1-3 are tested and the build fails, the last known endpoint failure maximum (End′)=3). The build process then begins processing the pending code changes according to the current Start, End, and End′ values (e.g., from Start=1 to End=M, End′=M) (step 518).
A determination is then made by the build mechanism as to whether the build process is successful (step 520). If the build process is successful (‘yes’ output of step 520), the build process finalizes the code changes from the current Start value to the current End value (step 522). The build process finalizes the code changes by committing the changes (i.e., moving the changes out of the pending verification state to a permanently applied state). The build process then determines if the current end code change value equals the total number of pending code changes (End=M) (step 524). If the current end code change value equals the total number of pending code changes (‘yes’ output of step 524), the process terminates thereafter, since all of the pending code changes have been processed in the build and the build process was successful. However, if the current end code change value does not equal the total number of pending code changes (‘no’ output of step 524), the build process increments the current start value by 1 (Start=End+1) and sets the current End value to the current End′ value (End=End′) (step 526). The process then returns to step 518 in which the build process is re-executed for the remaining pending code changes according to the new current Start, End, and End′ build values.
Turning back to step 520, if the build process is not successful (‘no’ output of step 520), the build process makes a determination as to whether the current Start value is equal to the current End value (step 528). If the current Start value is not equal to the current End value (‘no’ output of step 528), the build process attempts to reduce the number of pending code changes processed in the build in order to locate the offending code changes that caused the build to break. The build process sets the current End value ((End+1−Start)/2), and sets the current End′ value to the new End value (step 530). The process then returns to step 518 in which the build process is re-executed with the new current Start, End, and End′ values reflecting the reduced number of code changes. The build process may continue to execute and, if unsuccessful, continue to reduce the number of code changes in each build according to step 530 until the offending change is identified.
Turning back to step 528, if the current Start value is equal to the current End value (‘yes’ output of step 528), the build process has identified the code change that has caused the build to break. The build process may automatically back out any code in the pending code files that have caused the regression tests in the build process to fail. The build process assigns a software bug ID to the offending code change, and the build process then backs out the code change associated with the software bug ID (step 532). The build process then sets the current Start value to End+1, sets the current End value to M, and sets the current End′ value to M (step 534). The process then returns to step 518 in which the build process is re-executed with the new current Start, End, and End′ values.
A particular example of the software build process in FIG. 5 is shown in Table 1. Table 1 shows the Start, End, and End′ values in a software build that processes 12 pending code changes (M=12), where code change 3 in the list of pending code changes breaks the build.
TABLE 1
Start End End′
1 12 12
1 6 6
1 3 3
1 1 3
2 3 3
2 2 3
3 3 3
4 12 12
Initially, the current Start and End values of the build are set to 1 and 12, respectively. End′ value is also set to 12. If the build process is successful, the code changes from Start value 1 to the End value 12 are committed to the database. If the End value equals the total number of pending code changes (12 in this example), the process ends since all of the pending code changes have been processed in the build and the build process was successful.
However, if the build process is not successful, one of the 12 code changes has caused the failure. The current End value is consequently reset by reducing the number of pending code changes processed in the build in order to locate the offending code changes that caused the build to break. End value is set to (End+1−Start)/2, or 6 in this example. End′ value is also set to the End value of 6. After the build process is re-executed with the new current Start, End, and End′ values (1, 6, 6) reflecting the reduced number of code changes, if this build process is successful, the code changes from Start value 1 to End value 6 are committed to the database. If the build process is not successful, one of the 6 code changes has caused the failure. The current End value is then reset to (End+1−Start)/2, or 3. End′ value is also set to the End value of 3, and the build process is re-executed with the new current Start, End, and End′ values (1, 3, 3).
If, after an unsuccessful build, the current Start value (e.g., Start value 3) is determined to be equal to the current End value (e.g., End value 3), the build process has identified the code change that has caused the build to break. This code change may be backed out of the pending code files. The current Start value is then set to End+1(4 in this example), sets the current End value to M (12), and sets the current End′ value to M (12) in order to process the remaining pending code changes.
The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used herein, the singular forms “a”, “an” and “the” are intended to include the 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.
The corresponding structures, materials, acts, and equivalents of all means or step plus function elements in the claims below are intended to include any structure, material, or act for performing the function in combination with other claimed elements as specifically claimed. The description of the present invention has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the invention. The embodiment was chosen and described in order to best explain the principles of the invention and the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.
The invention can take the form of an entirely hardware embodiment, an entirely software embodiment or an embodiment containing both hardware and software elements. In a preferred embodiment, the invention is implemented in software, which includes but is not limited to firmware, resident software, microcode, etc.
Furthermore, 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 tangible 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 modem and Ethernet cards are just a few of the currently available types of network adapters.
The description of the present invention has been presented for purposes of illustration and description, and is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art. The embodiment was chosen and described in order to best explain the principles of the invention, the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.

Claims (20)

1. A computer implemented method for automating software code check-in in a code management system, the computer implemented method comprising:
receiving a request to check-in a modified copy of a source code file to a repository, wherein the modified copy comprises changes to the source code file located in the repository;
placing the modified copy of the source code file in a quality check pending state in the repository, wherein the quality check pending state is a state in the repository in which the modified copy of the source code is maintained until the quality of the modified copy of the source code file is verified;
responsive to an occurrence of a specific event or expiration of a set time period, automatically pulling the modified copy of the source code from the repository into a software delivery environment comprising a build mechanism that converts source code files into executable code and a regression test mechanism to execute regression test cases against the changes in the modified copy;
automatically determining by the software delivery environment if the regression test cases are successful to verify the modified copy; and
responsive to a determination that the regression test cases are successful, committing the changes in the modified copy to the source code file located in the repository.
2. The computer implemented method of claim 1, further comprising:
responsive to a determination that the regression test cases are not successful, preventing the modified copy from being committed to the repository.
3. The computer implemented method of claim 1, further comprising:
responsive to a determination that the regression test cases are not successful, backing out the modified copy from the quality check pending state.
4. The computer implemented method of claim 3, further comprising:
providing notification that the regression test cases were unsuccessful.
5. The computer implemented method of claim 1, wherein the regression test cases automatically test the modified copy of the source code file to verify the modified copy meets a minimum level of acceptable code quality before being committed to the repository.
6. The computer implemented method of claim 1, wherein placing the modified copy of the source code file in a quality check pending state in the repository further comprises:
performing a build process on the modified code in the software delivery environment, wherein appropriate regression test buckets are automatically triggered in the build process to test a quality of the modified code.
7. The computer implemented method of claim 1, wherein committing the changes in the modified copy to the source code file located in the repository further comprises:
moving the modified copy from the quality check pending state to a permanent state in the repository.
8. The computer implemented method of claim 1, further comprising:
responsive to a determination that the regression test cases are not successful, separating the changes in the modified copy into change sub groups;
re-executing the regression test cases on each separate change sub group; and
responsive to a determination that the re-executed regression test cases are unsuccessful against a change sub group, iteratively performing the separating and re-executing steps on the change sub group to locate a change in the modified copy that caused the regression test cases to fail.
9. A computer program product for automating software code check-in in a code management system, the computer program product comprising:
a computer recordable storage device having computer usable program code tangibly embodied thereon, the computer usable program code comprising:
computer usable program code for receiving a request to check-in a modified copy of a source code file to a repository, wherein the modified copy comprises changes to the source code file located in the repository;
computer usable program code for placing the modified copy of the source code file in a quality check pending state in the repository, wherein the quality check pending state is a state in the repository in which the modified copy of the source code is maintained until the quality of the modified copy of the source code file is verified;
computer usable program code for automatically pulling the modified copy of the source code from the repository into a software delivery environment comprising a build mechanism that converts source code files into executable code and a regression test mechanism to execute regression test cases against the changes in the modified copy in response to an occurrence of a specific event or expiration of a set time period;
computer usable program code for automatically determining by the software delivery environment if the regression test cases are successful to verify the modified copy; and
computer usable program code for committing the changes in the modified copy to the source code file located in the repository in response to a determination that the regression test cases are successful.
10. The computer program product of claim 9, further comprising:
computer usable program code for preventing the modified copy from being committed to the repository in response to a determination that the regression test cases are not successful.
11. The computer program product of claim 9, further comprising:
computer usable program code for backing out the modified copy from the quality check pending state in response to a determination that the regression test cases are not successful.
12. The computer program product of claim 11, further comprising:
computer usable program code for providing notification that the regression test cases were unsuccessful.
13. The computer program product of claim 9, wherein the regression test cases automatically test the modified copy of the source code file to verify the modified copy meets a minimum level of acceptable code quality before being committed to the repository.
14. The computer program product of claim 9, wherein the computer usable program code for placing the modified copy of the source code file in a quality check pending state in the repository further comprises:
computer usable program code for performing a build process on the modified code in the software delivery environment, wherein appropriate regression test buckets are automatically triggered in the build process to test a quality of the modified code.
15. The computer program product of claim 9, wherein the computer usable program code for committing the changes in the modified copy to the source code file located in the repository further comprises:
computer usable program code for moving the modified copy from the quality check pending state to a permanent state in the repository.
16. The computer program product of claim 9, further comprising:
computer usable program code for separating the changes in the modified copy into change sub groups in response to a determination that the regression test cases are not successful;
computer usable program code for re-executing the regression test cases on each separate change sub group; and
computer usable program code for iteratively performing, in response to a determination that the re-executed regression test cases are unsuccessful against a change sub group, the separating and re-executing steps on the change sub group to locate a change in the modified copy that caused the regression test cases to fail.
17. A data processing system for automating software code check-in in a code management system, the data processing system comprising:
a bus;
a storage device connected to the bus, wherein the storage device contains computer usable code;
at least one managed device connected to the bus;
a communications unit connected to the bus; and
a processing unit connected to the bus, wherein the processing unit executes the computer usable code to receive a request to check-in a modified copy of a source code file to a repository, wherein the modified copy comprises changes to the source code file located in the repository; place the modified copy of the source code file in a quality check pending state in the repository, wherein the quality check pending state is a state in the repository in which the modified copy of the source code is maintained until the quality of the modified copy of the source code file is verified; automatically pull the modified copy of the source code from the repository into a software delivery environment comprising a build mechanism that converts source code files into executable code and a regression test mechanism to execute regression test cases against the changes in the modified copy in response to an occurrence of a specific event or expiration of a set time period; automatically determine by the software delivery environment if the regression test cases are successful to verify the modified copy; and commit the changes in the modified copy to the source code file located in the repository in response to a determination that the regression test cases are successful.
18. The data processing system of claim 17, wherein the processing unit further executes the computer usable code to back out the modified copy from the quality check pending state in response to a determination that the regression test cases are not successful.
19. The data processing system of claim 18, wherein the processing unit further executes the computer usable code to provide notification that the regression test cases were unsuccessful.
20. The data processing system of claim 17, wherein the regression test cases automatically test the modified copy of the source code file to verify the modified copy meets a minimum level of acceptable code quality before being committed to the repository.
US12/199,330 2008-08-27 2008-08-27 Guarding code check-in with test case execution results Expired - Fee Related US8312430B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US12/199,330 US8312430B2 (en) 2008-08-27 2008-08-27 Guarding code check-in with test case execution results

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US12/199,330 US8312430B2 (en) 2008-08-27 2008-08-27 Guarding code check-in with test case execution results

Publications (2)

Publication Number Publication Date
US20100058294A1 US20100058294A1 (en) 2010-03-04
US8312430B2 true US8312430B2 (en) 2012-11-13

Family

ID=41727196

Family Applications (1)

Application Number Title Priority Date Filing Date
US12/199,330 Expired - Fee Related US8312430B2 (en) 2008-08-27 2008-08-27 Guarding code check-in with test case execution results

Country Status (1)

Country Link
US (1) US8312430B2 (en)

Cited By (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100037209A1 (en) * 2007-04-09 2010-02-11 Fujitsu Limited Source program review program, source program review method, and source program review device
US20110035726A1 (en) * 2009-08-07 2011-02-10 International Business Machines Corporation Identifying source code elements for refactoring
US20120123949A1 (en) * 2010-11-17 2012-05-17 Shreyank Gupta Method and system to automatically modify task status in a project management system via keywords in source code version control commit logs
US20140282406A1 (en) * 2013-03-14 2014-09-18 Microsoft Corporation Automatic risk analysis of software
US20150095619A1 (en) * 2013-09-30 2015-04-02 Linkedin Corporation Request change tracker
US20180081784A1 (en) * 2016-09-22 2018-03-22 Microsoft Technology Licensing, Llc Method and system for managing code
US20180203727A1 (en) * 2017-01-13 2018-07-19 International Business Machines Corporation Optimizing pipeline execution scheduling based on commit activity trends, priority information, and attributes
US10120664B2 (en) * 2015-08-28 2018-11-06 International Business Machines Corporation Incremental build generation
US10162628B2 (en) 2016-12-16 2018-12-25 Microsoft Technology Licensing, Llc Transactional distributed data analysis and transformation
US10175975B2 (en) 2015-02-18 2019-01-08 Red Hat Israel, Ltd. Self-mending software builder
US10372441B2 (en) 2016-11-28 2019-08-06 Microsoft Technology Licensing, Llc Build isolation system in a multi-system environment
US11301221B2 (en) * 2019-12-13 2022-04-12 Sap Se Rapid code compiling system
US11494288B2 (en) 2017-08-17 2022-11-08 Micro Focus Llc Test relevancy prediction for code changes
US20230004484A1 (en) * 2021-06-30 2023-01-05 Fmr Llc Systems and Methods for Impact-Centric Source Code Testing Based on Historical Execution Analysis

Families Citing this family (52)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20090055805A1 (en) * 2007-08-24 2009-02-26 International Business Machines Corporation Method and System for Testing Software
US8161458B2 (en) * 2007-09-27 2012-04-17 Oracle America, Inc. Method and apparatus to increase efficiency of automatic regression in “two dimensions”
US8463760B2 (en) * 2008-09-04 2013-06-11 At&T Intellectual Property I, L. P. Software development test case management
WO2010044150A1 (en) * 2008-10-15 2010-04-22 富士通株式会社 Program change management device, program change management program, and program change management method
US8527947B2 (en) * 2008-12-28 2013-09-03 International Business Machines Corporation Selective notifications according to merge distance for software version branches within a software configuration management system
US8316224B2 (en) * 2009-08-31 2012-11-20 Red Hat, Inc. Systems and methods for tracking a history of changes associated with software packages and configuration management in a computing system
US8443361B2 (en) * 2009-08-31 2013-05-14 Red Hat, Inc. Systems and methods for tracking a history of changes associated with software packages in a computing system
US8352919B2 (en) * 2009-09-30 2013-01-08 Sap Ag Operation support in versioning systems
US20110214105A1 (en) * 2010-02-26 2011-09-01 Macik Pavel Process for accepting a new build
US20110296386A1 (en) * 2010-05-28 2011-12-01 Salesforce.Com, Inc. Methods and Systems for Validating Changes Submitted to a Source Control System
US20120159434A1 (en) * 2010-12-20 2012-06-21 Microsoft Corporation Code clone notification and architectural change visualization
US8839188B2 (en) * 2011-05-18 2014-09-16 International Business Machines Corporation Automated build process and root-cause analysis
US8875100B2 (en) * 2011-06-17 2014-10-28 Microsoft Corporation Pattern analysis and performance accounting
US20130024469A1 (en) * 2011-07-21 2013-01-24 International Business Machines Corporation Apparatus and method for preventing regression defects when updating software components
US8677315B1 (en) * 2011-09-26 2014-03-18 Amazon Technologies, Inc. Continuous deployment system for software development
US9542176B2 (en) 2012-08-20 2017-01-10 Microsoft Technology Licensing, Llc Predicting software build errors
US9632771B2 (en) * 2012-12-13 2017-04-25 Microsoft Technology Licensing, Llc Association of metadata with source code and applications and services premised thereon
US9134931B2 (en) * 2013-04-30 2015-09-15 Hewlett-Packard Development Company, L.P. Printing content over a network
CN103226485B (en) * 2013-05-21 2016-09-28 北京奇虎科技有限公司 Code dissemination method, code issue machine and code delivery system
GB2517717A (en) 2013-08-29 2015-03-04 Ibm Testing of combined code changesets in a software product
US9436460B2 (en) * 2013-10-29 2016-09-06 International Business Machines Corporation Regression alerts
US9893972B1 (en) 2014-12-15 2018-02-13 Amazon Technologies, Inc. Managing I/O requests
US9928059B1 (en) 2014-12-19 2018-03-27 Amazon Technologies, Inc. Automated deployment of a multi-version application in a network-based computing environment
WO2016121002A1 (en) * 2015-01-27 2016-08-04 三菱電機株式会社 File management device, file management method, and program
US10095509B2 (en) * 2015-02-04 2018-10-09 Sap Se Supporting developer-user collaborative software review in IDE
WO2016138953A1 (en) * 2015-03-04 2016-09-09 Verifyter Ab A method for identifying a cause for a failure of a test
US9959114B2 (en) 2015-03-16 2018-05-01 Microsoft Technology Licensing, Llc Representation of customizable types in a development environment
US10078501B2 (en) 2015-03-16 2018-09-18 Microsoft Technology Licensing, Llc Domain specific language modeling framework in a development environment
US10067755B2 (en) * 2015-03-16 2018-09-04 Microsoft Technology Licensing, Llc Model driven customization framework
US9684507B2 (en) * 2015-03-31 2017-06-20 Ca, Inc. Effective defect management across multiple code branches
US10733520B2 (en) 2015-05-13 2020-08-04 Microsoft Technology Licensing, Llc Making a prediction regarding development of a software product
CN105893259B (en) * 2016-03-31 2019-04-09 广州华多网络科技有限公司 Code detection system, method and device
US10037263B1 (en) * 2016-07-27 2018-07-31 Intuit Inc. Methods, systems, and articles of manufacture for implementing end-to-end automation of software services
US10827036B2 (en) * 2016-09-19 2020-11-03 Palantir Technologies Inc. Version control machine
US10175978B2 (en) * 2016-11-04 2019-01-08 International Business Machines Corporation Monitoring code sensitivity to cause software build breaks during software project development
US10754761B2 (en) * 2016-11-11 2020-08-25 Atlassian Pty Ltd Systems and methods for testing source code
US10585780B2 (en) 2017-03-24 2020-03-10 Microsoft Technology Licensing, Llc Enhancing software development using bug data
US10754640B2 (en) * 2017-03-24 2020-08-25 Microsoft Technology Licensing, Llc Engineering system robustness using bug data
US11288592B2 (en) 2017-03-24 2022-03-29 Microsoft Technology Licensing, Llc Bug categorization and team boundary inference via automated bug detection
US10289409B2 (en) * 2017-03-29 2019-05-14 The Travelers Indemnity Company Systems, methods, and apparatus for migrating code to a target environment
US10691449B2 (en) * 2017-04-27 2020-06-23 Microsoft Technology Licensing, Llc Intelligent automatic merging of source control queue items
US10671519B2 (en) * 2018-04-27 2020-06-02 Microsoft Technology Licensing, Llc Unit testing for changes to version control
CN112513813A (en) * 2018-06-25 2021-03-16 亚马逊技术有限公司 Performing auxiliary functions in an on-demand network code execution system
US10318412B1 (en) * 2018-06-29 2019-06-11 The Travelers Indemnity Company Systems, methods, and apparatus for dynamic software generation and testing
CN110750502A (en) * 2018-07-23 2020-02-04 北京奇虎科技有限公司 Component processing method and device
US10521220B1 (en) 2018-12-18 2019-12-31 Palantir Technologies Inc. Systems and methods for coordinating the deployment of components to defined user groups
US10809992B1 (en) * 2019-04-26 2020-10-20 Hitachi, Ltd. Method and apparatus for continuous delivery of permissioned blockchain application
CN110347423A (en) * 2019-06-28 2019-10-18 北京你财富计算机科技有限公司 The online management method of file modification and device
US11816501B2 (en) * 2019-11-08 2023-11-14 Zerofox, Inc. System and methods for managing high volumes of alerts
US11656977B2 (en) * 2021-04-06 2023-05-23 EMC IP Holding Company LLC Automated code checking
US11907106B2 (en) * 2021-12-23 2024-02-20 Gm Cruise Holdings Llc Code integration with time-variant test failure detection
US20230418580A1 (en) * 2022-06-28 2023-12-28 Red Hat, Inc. Identification and removal of redundant interfaces

Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5706510A (en) 1996-03-15 1998-01-06 Hewlett-Packard Company Zymbolic history management system
US5806078A (en) 1994-06-09 1998-09-08 Softool Corporation Version management system
US6601018B1 (en) * 1999-02-04 2003-07-29 International Business Machines Corporation Automatic test framework system and method in software component testing
US20060041440A1 (en) 2004-08-20 2006-02-23 International Business Machines Corporation Method, system and program product for managing a project
US20060101443A1 (en) 2004-10-25 2006-05-11 Jim Nasr Source code management system and method
US20060200803A1 (en) 2005-03-04 2006-09-07 Microsoft Corporation Methods and apparatus for implementing checkin policies in source code control systems
US7260818B1 (en) 2003-05-29 2007-08-21 Sun Microsystems, Inc. System and method for managing software version upgrades in a networked computer system

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5806078A (en) 1994-06-09 1998-09-08 Softool Corporation Version management system
US5706510A (en) 1996-03-15 1998-01-06 Hewlett-Packard Company Zymbolic history management system
US6601018B1 (en) * 1999-02-04 2003-07-29 International Business Machines Corporation Automatic test framework system and method in software component testing
US7260818B1 (en) 2003-05-29 2007-08-21 Sun Microsystems, Inc. System and method for managing software version upgrades in a networked computer system
US20060041440A1 (en) 2004-08-20 2006-02-23 International Business Machines Corporation Method, system and program product for managing a project
US20060101443A1 (en) 2004-10-25 2006-05-11 Jim Nasr Source code management system and method
US20060200803A1 (en) 2005-03-04 2006-09-07 Microsoft Corporation Methods and apparatus for implementing checkin policies in source code control systems
US7653893B2 (en) * 2005-03-04 2010-01-26 Microsoft Corporation Methods and apparatus for implementing checkin policies in source code control systems

Non-Patent Citations (3)

* Cited by examiner, † Cited by third party
Title
"Using HP System Software manager for the mass deployment of software updates to client PCs", Mar. 2004, Hewlett-Packard Development Company, L.P., pp. 1-12.
Canfora, et al. "Identifying Changed Source Code Lines from Version Repositories", 2007, IEEE, p. 1-8. *
Singh et al., "Improving Agile Software Development using eXtreme AOCE and aspect-Oriented CVS", Proceedings of the 12th Asia-Pacific Software engineering Conference (APSEC'05), IEEE 2005, pp. 1-8.

Cited By (24)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100037209A1 (en) * 2007-04-09 2010-02-11 Fujitsu Limited Source program review program, source program review method, and source program review device
US8473902B2 (en) * 2009-08-07 2013-06-25 International Business Machines Corporation Identifying source code elements for refactoring
US20110035726A1 (en) * 2009-08-07 2011-02-10 International Business Machines Corporation Identifying source code elements for refactoring
US8499280B2 (en) * 2009-08-07 2013-07-30 International Business Machines Corporation Identifying source code elements for refactoring
US20120167040A1 (en) * 2009-08-07 2012-06-28 International Business Machines Corporation Identifying source code elements for refactoring
US20120123949A1 (en) * 2010-11-17 2012-05-17 Shreyank Gupta Method and system to automatically modify task status in a project management system via keywords in source code version control commit logs
US20140282406A1 (en) * 2013-03-14 2014-09-18 Microsoft Corporation Automatic risk analysis of software
US9864678B2 (en) 2013-03-14 2018-01-09 Microsoft Technology Licensing, Llc Automatic risk analysis of software
US10747652B2 (en) * 2013-03-14 2020-08-18 Microsoft Technology Licensing, Llc Automatic risk analysis of software
US9448792B2 (en) * 2013-03-14 2016-09-20 Microsoft Technology Licensing, Llc Automatic risk analysis of software
US20150095619A1 (en) * 2013-09-30 2015-04-02 Linkedin Corporation Request change tracker
US9632919B2 (en) * 2013-09-30 2017-04-25 Linkedin Corporation Request change tracker
US10175975B2 (en) 2015-02-18 2019-01-08 Red Hat Israel, Ltd. Self-mending software builder
US10120664B2 (en) * 2015-08-28 2018-11-06 International Business Machines Corporation Incremental build generation
US20180081784A1 (en) * 2016-09-22 2018-03-22 Microsoft Technology Licensing, Llc Method and system for managing code
US10282275B2 (en) * 2016-09-22 2019-05-07 Microsoft Technology Licensing, Llc Method and system for managing code
US10372441B2 (en) 2016-11-28 2019-08-06 Microsoft Technology Licensing, Llc Build isolation system in a multi-system environment
US10162628B2 (en) 2016-12-16 2018-12-25 Microsoft Technology Licensing, Llc Transactional distributed data analysis and transformation
US20180203727A1 (en) * 2017-01-13 2018-07-19 International Business Machines Corporation Optimizing pipeline execution scheduling based on commit activity trends, priority information, and attributes
US10725816B2 (en) * 2017-01-13 2020-07-28 International Business Machines Corporation Optimizing pipeline execution scheduling based on commit activity trends, priority information, and attributes
US10956207B2 (en) 2017-01-13 2021-03-23 International Business Machines Corporation Optimizing pipeline execution scheduling based on commit activity trends, priority information, and attributes
US11494288B2 (en) 2017-08-17 2022-11-08 Micro Focus Llc Test relevancy prediction for code changes
US11301221B2 (en) * 2019-12-13 2022-04-12 Sap Se Rapid code compiling system
US20230004484A1 (en) * 2021-06-30 2023-01-05 Fmr Llc Systems and Methods for Impact-Centric Source Code Testing Based on Historical Execution Analysis

Also Published As

Publication number Publication date
US20100058294A1 (en) 2010-03-04

Similar Documents

Publication Publication Date Title
US8312430B2 (en) Guarding code check-in with test case execution results
US9940219B2 (en) Detecting merge conflicts and compilation errors in a collaborative integrated development environment
EP3769223B1 (en) Unified test automation system
US10592229B1 (en) Method and system for restoring software
US9703692B2 (en) Development supporting system
US7802247B1 (en) Method and system for restoring software
US7831968B1 (en) Method and system for restoring software
US9454351B2 (en) Continuous deployment system for software development
US8250568B2 (en) Installing and upgrading an application in a computer system
US7624394B1 (en) Software installation verification
US9311064B1 (en) Systems and methods for automated centralized build/merge management
US8713552B2 (en) Avoiding conflict in update in distributed environment employing multiple clients
US20090319552A1 (en) Software merging utility
US20070204262A1 (en) Facilitating the automated testing of daily builds of software
US10747653B2 (en) Software testing systems and methods
US11055078B2 (en) Systems and methods for deploying software products to environments
US20060123040A1 (en) Algorithm for automated enterprise deployments
US7437705B1 (en) System and method for building an application on a computing device which includes an environment-controlling process
US10599424B2 (en) Committed program-code management
US20080172659A1 (en) Harmonizing a test file and test configuration in a revision control system
US7921417B2 (en) Method and computer system for activation of source files
WO2023242640A1 (en) Automatically orchestrating a computerized workflow
EP4315070A1 (en) Automatic testing of interrelated components of a software application
CN117806660A (en) Automatic CI/CD project deployment method, device, equipment and medium
Bach et al. Upgrading to Oracle 12c

Legal Events

Date Code Title Description
AS Assignment

Owner name: INTERNATIONAL BUSINESS MACHINES CORPORATION,NEW YO

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:BEST, DEBORA O'BERRY;BEST, STEVEN FRANCIS;EGGERS, ROBERT JAMES, JR;AND OTHERS;SIGNING DATES FROM 20080806 TO 20080821;REEL/FRAME:021451/0024

Owner name: INTERNATIONAL BUSINESS MACHINES CORPORATION, NEW Y

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:BEST, DEBORA O'BERRY;BEST, STEVEN FRANCIS;EGGERS, ROBERT JAMES, JR;AND OTHERS;SIGNING DATES FROM 20080806 TO 20080821;REEL/FRAME:021451/0024

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 Expired due to failure to pay maintenance fee

Effective date: 20161113