Build automation is the practice of building software systems in a relatively unattended fashion. The build is configured to run with minimized or no software developer interaction and without using a developer's personal computer. Build automation encompasses the act of configuring the build system as well the resulting system itself.
Build automation encompasses both sequencing build operations via non-interactive interface tools and running builds on a shared server.[1]
Tools
editBuild-automation tools allow for sequencing the tasks of building software via a non-interactive interface. Existing tools such as Make can be used via custom configuration file or command-line parameters. Custom tools such as shell scripts can also be used.
Some tools, such as shell scripts, are task-oriented declarative programming. They encode sequences of commands to perform with usually minimal conditional logic.
Some tools, such as Make are product-oriented. They build a product, a.k.a. target, based on configured dependencies.[2]
Servers
editA build server is a server setup to run builds. As opposed to a personal computer, a server allows for a more consistent and available build environment.
Traditionally, a build server was a local computer dedicated as a shared resource instead of used as a personal computer. Today, there are many cloud computing, software as a service (SaaS) web sites for building.
Without a build server, building generally depends on developers to use their personal computers which has many drawbacks, including but not limited to: The developers who know how to build may be on vacation. The developer's machine may have an issue that prevents building. The developer's machine may have other software installed that conflicts with building properly.
A continuous integration server is a build server that is setup to build in a relatively frequent way – often on each code commit. A build server may also be incorporated into an ARA tool or ALM tool.
Typical build triggering options include:
- On-demand: requested by a user
- Scheduled: such as a nightly build
- On-commit: building on every commit to a version control system
Continuous integration and continuous delivery
editAutomating the build process is a required step for implementing continuous integration and continuous delivery (CI/CD) – all of which considered best practice for software development.[3][how?]
Advantages
editPluses of build automation include:[4]
- Can save time and money in the long run
- Enables continuous integration, delivery and testing
- More consistent build process
- Can optimize the build process; reducing time and redundant tasks
- Reduces dependency on key personnel and their personal computers
- Can automate collection of build history
See also
edit- Application-release automation – Process of packaging and deployment
- Continuous configuration automation – software configuration and deployment methodology
- Continuous integration – Software development practice of building and testing frequently
- Continuous delivery – Software engineering approach of short cycles
- Continuous testing – process of executing automated tests as part of the software delivery pipeline to obtain immediate feedback on the business risks associated with a release candidate
- DevOps – Set of software development practices
- List of build automation software
- Product family engineering – synonym for "domain engineering"
- Release engineering
- Software configuration management – Tracking and controlling software changes
- Unit testing – Validating the behavior of isolated source code
References
edit- ^ Ceruzzi, Paul E. (2003). A history of Modern computing. The MIT Press. ISBN 978-0-262-53203-7.
- ^ Clark, Mike (2004). Pragmatic Project Automation: How to Build, Deploy, and Monitor Java Apps. The Pragmatic Programmers. ISBN 978-0-9745140-3-1.
- ^ Bashan, Shmuel; Bellagio, David E. (2011). Work Item Management with IBM Rational ClearQuest and Jazz: A customization Guide. IBM Press. ISBN 978-0-13-700179-8.
- ^ "Archived copy" (PDF). Archived from the original (PDF) on 2008-11-23. Retrieved 2008-09-19.
{{cite web}}
: CS1 maint: archived copy as title (link)