This article has multiple issues. Please help improve it or discuss these issues on the talk page. (Learn how and when to remove these template messages)(Learn how and when to remove this template message)
In software development, a neutral build is a software build that reflects the current state of the source code checked into the source code version control system by the developers, and done in a neutral environment (an environment not used for development).
A nightly build is a neutral build that takes place automatically. These typically take place when no one is likely to be working in the office so that there are no changes to the source code during the build. The results of the build are inspected by the arriving programmers, who generally place a priority on ensuring the recent changes to the source code have not broken the build process or functionality of the software. Nightly builds also ensure that the build tools have not broken due to system updates, and are therefore often run whether any source code has changed or not.
In contrast, continuous integration environments automatically rebuild the project whenever changes are checked in – often several times a day – and provide more immediate feedback; however, they do not necessarily include nightly builds. As a result, compiler and tool updates may break the ability to compile older projects easily without warning. Nonetheless, CI techniques are considered the more modern approach. CI jobs are often run on isolated virtual machines, and typically include automated testing as well.
When someone says a developer "broke the build", they are effectively saying that a developer checked in code which might very well have compiled (and hopefully also run properly) in their account, but does not compile (and therefore, cannot be run) in anyone else's account. This is typically due to additional developer-specific changes that were either not checked in, or (in the case of environment variables, etc.) were modifications to systems not under revision control. One of the most common cases is remembering to check in all modified files, but forgetting to add newly created files to the repository. If the other developers check out the new code without being aware of the problem, their work may grind to a halt while they wait for the problem to be fixed (or try to fix it themselves, which can be even more problematic, if multiple developers attempt to fix the issue at the same time). This naturally can result in a significant loss of productivity.
Neutral builds are important for software development processes running at high loads with short schedules (see extreme programming, startup). Not having them means that any build that needs to be created for the software quality assurance department will use code that may be in the middle of major modifications, and which is therefore best left out of a build intended for independent validation – particularly a build being evaluated for possible release.
Some obstacles to a reliable neutral build process are:
- Getting a consistent build automation system and set of project control files.
- Having the same operating system and tools setup as the development machines.
- Set up a checkout procedure that ensures all files are up to date. This may imply the additional task of integrating a version control system with the process.
- Decoupling the build process from specific IDEs.
- Setting up adequate feedback from the build system so that failed builds can be diagnosed.
- Convincing management of the benefit of automated builds.
The following list gives some examples of software that has publicly available nightly and/or neutral builds.
- CyanogenMod, an open-source custom ROM for Android-based devices.
- Firefox, an open-source web browser.
- Media Player Classic - Home Cinema, an open-source media player.
- Simutrans, an open-source transportation simulator.
- VLC media player, an open-source media player.
- WebKit, the web browser renderer used by Google Chrome and Apple's Safari.
- Arduino, Arduino is a family of single-board microcontroller, intended to make it easier to build interactive objects or environments.
- RetroArch, RetroArch is an emulator for different consoles such as PlayStation, NES, GameBoy etc.
- MuseScore, WYSIWYG music notation, generates Linux nightly builds in the format of a distro-agnostic AppImage.
- "VLC media player nightly builds". VideoLAN Organization. Retrieved 21 February 2014.