Buildbot no longer supports Python 2.7 on the Buildbot master.
This page documents the latest, unreleased version of Buildbot. For documentation for released versions, see http://docs.buildbot.net/current/.
5.42. Release Notes for Buildbot
5.42.1. Bug fixes¶
5.43. Release Notes for Buildbot
5.43.1. Bug fixes¶
Fix builder page not showing any build (issue # 3820)
Fix double Workers button in the menu. (issue # 3818)
Fix bad icons in the worker action dialog.
Fix url arguments in Buildbot Badges for python3.
Upgrading to guanlecoja-ui version 1.8.0, fixing two issues. Fixed issue where the console view would jump to the top of page when opening the build summary dialog (issue # 3657). Also improved sidebar behaviour by remembering previous pinned vs. collapsed state.
Fixes issue with Buildbot
DockerLatentWorkernot reaping zombies process within its container environment.
Update requirement text to use the modern “docker” module from the older “docker-py” module name
Fixed exception when using
New Buildbot SVG icons for web UI. The web UI now uses a colored favicon according to build results (issue # 3785).
gracefulWorkers States are now stored in the database.
Workers States are now displayed in the web UI.
Quarantine timers is now using the
Quarantine timer is now enabled when a build finish on
Standalone binaries for buildbot-worker package are now published for windows and linux (
amd64). This allows to run a buildbot-worker without having a python environment.
buildbot-worker create-worker --maxretriesfor Latent Workers to quit if the master is or becomes unreachable.
Badges can now display running as status.
The database schema now supports cascade deletes for all objects instead of raising an error when deleting a record which has other records pointing to it via foreign keys.
Buildbot can properly find its version if installed from a git archive tarball generated from a tag.
Enhanced the test suite to add worker/master protocol interoperability tests between python3 and python2.
5.43.3. Deprecations and Removals¶
buildbot.util.ascii2unicode() is removed. buildbot.util.bytes2unicode() should be used instead.
5.44. Release Notes for Buildbot
5.44.1. Bug fixes¶
Compile step now properly takes the decodeRC parameter in account (issue # 3774)
GitPollernow accepts git branch names with UTF-8 characters (issue # 3769).
Fixed inconsistent use of pointer style mouse cursor by removing it from the .label css rule and instead creating a new .clickable css rule which is used only in places which are clickable and would not otherwise automatically get the pointer icon, for example it is not needed for hyper-links. (issue # 3795).
Rebuilding with the same revision now takes new change properties into account instead of re-using the original build change properties (issue # 3701).
Worker authentication is now delayed via a DeferredLock until Buildbot configuration is finished. This fixes UnauthorizedLogin errors during buildbot restart (issue # 3462).
Fixes python3 encoding issues with Windows Service (issue # 3796)
new :ref`badges` plugin which reimplement the buildbot eight png badge system.
In progress worker control API. Worker can now be stopped and paused using the UI. Note that there is no UI yet to look the status of those actions (issue # 3429).
Make maximum number of builds fetched on the builders page configurable.
Include context in the log message for GitHubStatusPush
On ‘Builders’ page reload builds when tags change.
Give reporters access to master single in renderables. This allows access to build logs amongst other things
Added possibility to check www user credentials with a custom class.
5.45. Release Notes for Buildbot
5.45.1. Deprecations and Removals¶
Following will help Buildbot to leverage new feature of twisted to implement important features like worker protocol encryption.
buildbot-workerpackages now requires Python 2.7 or Python 3.4+ – Python 2.6 is no longer supported.
buildbot-workerpackages now required Twisted versions >= 16.1.0. Earlier versions of Twisted are not supported.
5.45.2. Bug fixes¶
Fix Console View forced builds stacking at top (issue:3461)
Improve buildrequest distributor to ensure all builders are processed. With previous version, builder list could be re-prioritized, while running the distributor, meaning some builders would never be run in case of master high load. (issue # 3661)
getOldestRequestTimefunction of buildrequest distributor to do sorting and paging in the database layer (issue # 3661).
Arguments passed to GitLab push notifications now work with Python 3 (issue # 3720).
Web hooks change sources which use twisted.web.http.Request have been fixed to use bytes, not native strings. This ensures web hooks work on Python 3. Please report any issues on web hooks in python3, as it is hard for us to test end to end.
Fixed null value of steps and logs in reporter HttpStatusPush api. Fixes (issue # 3180)
EC2LatentBuilder now correctly sets tags on spot instances (issue # 3739).
Fixed operation of the Try scheduler for a code checked out from Subversion.
Fix buildbot worker startup when running as a windows service
Make parameters for
WarningCountingShellCommandrenderable. These are suppressionList, warningPattern, directoryEnterPattern, directoryLeavePattern and maxWarnCount.
GitHubEventHandlernow supports authentication for GitHub instances that do not allow anonymous access
Added support for renderable builder locks. Previously only steps could have renderable locks.
Added flag to Docker Latent Worker to always pull images
5.46. Release Notes for Buildbot
This is a release which only exists for the
5.47. Release Notes for Buildbot
5.47.1. Bug fixes¶
Fixed many issues related to connecting masters and workers with different major version of Python (issue # 3416).
Fix for SVN.purge fails when modified files contain non-ascii characters (issue # 3576)
Fix the GitHub change hook on Python 3 (issue # 3452).
reporters.gitlabto use correct commit status codes (issue # 3641).
Fixed deadlock issue, when locks are taken at least 3 times by the 3 Buildstep with same configuration (issue # 3650)
Fix the Gerrit source step in the presence of multiple Gerrit repos (issue # 3460).
Add empty pidfile option to master and worker start script when –nodaemon option is on. (issue # 3012).
5.47.3. Deprecations and Removals¶
buildbot.util.encodeString() has been removed. buildbot.util.unicode2bytes() should be used instead.
5.48. Release Notes for Buildbot
5.48.1. Incompatible Changes¶
Buildbot is not compatible with
python3-ldapanymore. It now requires
ldap3package for its ldap operations (issue # 3530)
5.48.2. Bug fixes¶
Fix issue with
logviewerscrolling up indefinitely when loading logs (issue # 3154).
Do not add the url if it already exists in the step. (issue # 3554)
Fix filtering for REST resource attributes when SQL is involved in the backend (eq, ne, and contains operations, when there are several filters) (issue # 3526).
gitsource step now uses git checkout -B rather than git branch -M to create local branches (issue # 3537)
Fixed Grid View settings. It is now possible to configure “false” values.
Fix performance issue when remote command does not send any line boundary (issue # 3517)
Fix regression in GithHub oauth2 v3 api, when using enterprise edition.
Fix the Perforce build step on Python 3 (issue # 3493)
Make REST API’s filter __contains use OR connector rather than AND according to what the documentation suggests.
Fixed secret plugins registration, so that they are correctly available in
import buildbot.plugins.secrets. changes to all secrets plugin to be imported and used.
Fix secrets downloaded to worker with too wide permissions.
Fix issue with stop build during latent worker substantiating, the build result was retried instead of cancelled.
pip install 'buildbot[bundle]'now installs
grid_viewplugin. This fixes issues with the tutorial where
grid_viewis enabled by default.
5.48.3. Improved Documentation¶
Fixed documentation regarding log obfuscation for passwords.
Improve documentation of REST API’s __contains filter.
Added autopull for Docker images based on config. (issue # 3071)
Allow to expose logs to summary callback of
Implement GitHub change hook CI skipping (issue # 3443). Now buildbot will ignore the event, if the
[ci skip]keyword (configurable) in commit message. For more info, please check out the
GitHubStatusPushnow support reporting to ssh style URLs, ie firstname.lastname@example.org:Owner/RepoName.git
Added the possibility to filter builds according to results in Grid View.
OpenStackLatentWorkernow supports V3 authentication.
Buildbot now tries harder at finding line boundaries. It now supports several cursor controlling ANSI sequences as well as use of lots of backspace to go back several characters.
UI Improvements so that Buildbot build pages looks better on mobile.
OpenStackLatentWorkernow supports region attribute.
builderNamesparameter can now be a
IRenderableobject that will render to a list of builder names.
LdapUserInfonow uses the python3-ldap successor ldap3 (issue # 3530).
Added support for static suppressions parameter for shell commands.
5.49. Release Notes for Buildbot
5.49.1. Bug fixes¶
Fix ‘reconfig master causes worker lost’ error (issue # 3392).
Fix bug where object names could not be larger than 150 characters (issue # 3449)
Fix bug where notifier names could not be overridden (issue # 3450)
Fix exception when shutting down a master (issue # 3478)
Fix Manhole support to work with Python 3 and Twisted 16.0.0+ (issue # 3160).
PasswordManholenow require a directory containing SSH host keys to be specified.
Fix python 3 issue with displaying the properties when fetching builders (issue # 3418).
Fix bug when
ShellArgarguments were rendered only once during an instance’s lifetime.
Fix waterfall tiny size of build status indicators (issue # 3475)
Fix waterfall natural order of builder list
Fix builder page use ‘pointer’ cursor style for tags (issue # 3473)
Fix builder page update tag filter when using the browser’s back button (issue # 3474)
5.50. Release Notes for Buildbot
5.51. Release Notes for Buildbot
5.52. Release Notes for Buildbot
5.52.1. Bug fixes¶
Fixed a regression inn
UserPasswordAuthwhere a list would create an error.
Fix non ascii payload handling in base web hook (issue # 3321).
Fixed default buildrequest collapsing (issue # 3151)
_wait_for_request() would fail to format a log statement due to an invalid type being passed to log.msg (resulting in a broken build)
Fix Windows compatibility with frontend development tool
gulp dev proxy(issue # 3359)
New Grid View UI plugin.
The Change Hooks system is now integrated in the Plugin Infrastructure in Buildbot system, making it easier to subclass hooks. There is still the need to re- factor hook by hook to allow better customizability.
GitHubAuthnow allows fetching the user team membership for all organizations the user belongs to. This requires access to a V4 GitHub API(GraphQL).
GitLab merge request hook now create a change with repository to be the source repository and branch the source branch. Additional properties are created to point to destination branch and destination repository. This makes
GitLabStatusPushpush the correct status to GitLab, so that pipeline report is visible in the merge request page.
GitHubEventHandlernow allows the inclusion of white-listed properties for push events.
Allow sending a comment to a pull request for Bitbucket Server in
Implement support for Bitbucket Server webhook plugin in
5.53. Release Notes for Buildbot
5.53.1. Core Bug fixes¶
Fix incompatibility issue of
UserPasswordAuthwith python 3.
Fix issue with oauth sequence not working with Firefox (issue # 3306)
addChangemethod to accept the new chdict names if only the new name is present. Fixes issue # 3191.
fix bytes vs string issue on python3 with authorization of rest endpoints.
5.53.2. Core Features¶
doStepIfis now renderable.
Source step codebase is now renderable.
Step names are now renderable.
giturlparseutility function to help buildbot components like reporters to parse git url from change sources.
Factorized the mail reporter to be able to write new message based reporters, for other backend than SMTP.
Propertynow allows being used with Python built in comparators. It will return a Renderable which executes the comparison.
5.53.3. Components Bug fixes¶
GitLab reporter now correctly sets the status to running instead of pending when a build starts.
GitLab reporter now correctly works when there are multiple codebase, and when the projects names contain url reserved characters.
GitLab reporter now correctly reports the status even if there are several sourcestamps. Better parsing of change repository in GitLab reporter so that it understands ssh urls and https url. GitLab reporter do not use the project field anymore to know the repository to push to.
5.53.4. Components Features¶
GitLab hook now supports the merge_request event to automatically build from a merge request. Note that the results will not properly displayed in merge_request UI due to https://gitlab.com/gitlab-org/gitlab-ce/issues/33293
Added a https://pushjet.io/ reporter as
New build step
AssertTests a renderable or constant if it evaluates to true. It will succeed or fail to step according to the result.
5.54. Release Notes for Buildbot
5.54.1. Core Bug fixes¶
Console View now display changes the same way as in Recent Changes page.
Fix issue with Console View when no change source is configured but still builds have
5.54.2. Components Bug fixes¶
Allow renderables in options and definitions of step
CMake. Currently only dicts and lists with renderables inside are allowed.
OAuthAuthentication are now working with
_image_existsdoes not raise anymore if it encounters an image with
Fix command line parameters for
5.54.3. Core Features¶
state_stringis now automatically computed according to the
updateBuildSummaryPolicyfrom Parameters Common to all Steps. This allows the dashboards and reporters to get a descent summary text of the build without fetching the steps.
configuratorssection, which can be used to create higher level configuration modules for Buildbot.
JanitorConfiguratorwhich can be used to create a builder which save disk space by removing old logs from the database.
5.55. Release Notes for Buildbot
5.55.1. Core Bug fixes¶
buildbot.www.authz.endpointmatchers.AnyControlEndpointMatchernow actually doesn’t match GET requests. Before it would act like an AnyEndpointMatcher since the GET had a different case.
ForceSchedulerno longer causes an error.
Fix issue with :bb:sched::Nightly change classification raising foreign key exceptions (issue # 3021)
Fixes an exception found
buildbot_net_usage_data._sendWithUrlibwhen running through the tutorial using Python 3.
usePTYconfiguration of the
ShellCommandnow works as expected with recent version of buildbot-worker.
5.55.2. Components Bug fixes¶
GitHubPullrequestPollernow works as expected. Also the author email won’t be displayed as None
SlaveDirectoryUploadCommandno longer throws exceptions because the file “is used by another process” under Windows
5.55.3. UI Bug fixes¶
Fix waterfall scrolling and zooming in current browsers
console_viewnow properly uses
revlinkmetadata to link to changes.
Fixed Console View infinite loading spinner when no change have been recorded yet (issue # 3060).
5.55.4. Core Features¶
new Virtual Builders concept for better integration of frameworks which store the build config along side the source code.
5.55.5. Components Features¶
BitBucketnow sets the
eventproperty on each change to what the
GitHubPullrequestPollernow adds additional information about the pull request to properties. The property argument is removed and is populated with the repository full name.
GitHubnow sets the
eventproperty on each change to what the
GitHubAuthnow supports GitHub Enterprise when setting new
GitLabnow sets the
eventproperty on each change to what the
GitHubnow process git tag push events
GitLabnow process git tag push events
GitLabnow supports authentication with the secret token
5.56. Release Notes for Buildbot
5.56.1. Bug fixes¶
Fix issue with compressing empty log
Fix issue with db being closed by wrong thread
Fix issue with buildbot_worker not closing file handles when using the transfer steps
Fix issue with buildbot requesting too many permissions from GitHub’s OAuth
jsonas keyword argument.
OpenStackLatentWorkerto use keystoneauth1 so it will support latest python-novaclient packages.
RpmLintstep in steps plugins.
5.56.2. Core Features¶
Experimental support for Python 3.5 and 3.6. Note that complete support depends on fixes to be released in Twisted 17.2.0.
New experimental Secret Management framework, which allows to securely declare secrets, reusable in your steps.
New Writing Dashboards with Flask or Bottle plugin, which allows to write custom dashboard with traditional server side web frameworks.
EnableSchedulerEndpointMatcherfor better configurability of the access control. If you have access control to your Buildbot, it is recommended you add
AnyControlEndpointMatcherat the end of your access control configuration.
Schedulers can now be toggled on and off from the UI. Useful for temporarily disabling periodic timers.
5.56.3. Components Features¶
EC2LatentWorkernow provides instance id as the instance property enabling use of the AWS toolkit.
Add GitHub pull request Poller to list of available changesources.
OAuth2LoginResourcenow supports the token URL parameter. If a user wants to authenticate through OAuth2 with a pre- generated token (such as the access_token provided by GitHub) it can be passed to /auth/login as the token URL parameter and the user will be authenticated to buildbot with those credentials.
GitHubCommentPushcan comment on GitHub PRs
GitPollernow supports polling tags in a git repository.
MultipleFilUploadnow supports the glob parameter. If glob is set to True all workersrcs parameters will be run through glob and the result will be uploaded to masterdest
OpenStackLatentWorkerto default to v2 of the Nova API. The novaclient package has had a deprecation warning about v1.1 and would use v2 anyway.
5.57. Release Notes for Buildbot
5.57.2. Bug fixes¶
buildbot upgrade-masterwill now erase an old pidfile if the process is not live anymore instead of just failing.
Change properties ‘value’ changed from String(1024) to Text. Requires upgrade master. (bug #3197)
When using REST API, it is now possible to filter and sort in descending order at the same time.
Fix issue with
datetime is not JSON serializableerror.
Fix issue with log viewer not properly rendering color codes.
Fixed log viewer selection and copy-paste for Firefox (bug #3662).
Fix issue with
DelayedCalledalready called, and worker missing notification email never received.
setuptoolsis now explicitly marked as required. The dependency was previously implicit.
requestsif available and will default to HTTP if a bogus SSL implementation is found. It will also correctly send information about the platform type.
Buildbot now uses JWT to store its web UI Sessions. Sessions now persist upon buildbot restart. Sessions are shared between masters. Session expiration time is configurable with
Builders page has been optimized and can now be displayed with 4 http requests whatever is the builder count (previously, there was one http request per builder).
Builder and Worker page build list now have the
numbuilds=option which allows to show more builds.
Masters page now shows more information about a master (workers, builds, activity timer)
Workers page improvements:
Shows which master the worker is connected to.
Shows correctly the list of builders that this master is configured on (not the list of
buildermasterwhich nobody cares about).
Shows list of builds per worker similar to the builders page.
New worker details page displays the list of builds built by this worker using database optimized query.
5.57.4. Deprecations and Removals¶
Some deprecated broken Contrib Scripts were removed.
buildbot.www.hooks.googlecodehas been removed, since the Google Code service has been shut down.
buildbot.util.jsonhas been deprecated in favor of the standard library
simplejsonwill not be used anymore if found in the virtualenv.
5.58. Release Notes for Buildbot
5.58.1. Bug fixes¶
ep should start with /assertion error.
Fix duplicate worker use case, where a worker with the same name would make the other worker also disconnect (bug #3656)
buildPushesWithNoCommitsnow rebuilds for a known branch that was updated to an existing commit.
Fix issue with log viewer not staying at bottom of the log when loading log lines.
Fixed addBuildURLs in
Triggerto use results from triggered builds to include in the URL name exposed by API.
fix issue with factory.workdir AttributeError are not properly reported.
Optimize the memory consumption of the log compression process. Buildbot do not load the whole log into memory anymore. This should improve a lot buildbot memory footprint.
Changed the build page so that the preview of the logs are shown in live. It is a preview means the last lines of log. How many lines is configurable per user in the user settings page.
Log viewer line numbers are no longer selectable, so that it is easier to copy paste.
DockerLatentWorkeraccepts now renderable Dockerfile
SetPropertieswhich allows to generate and transform properties separately.
Handle new workers in windows_service.py script.
Sort the builders in the waterfall view by name instead of ID.
5.59. Release Notes for Buildbot
5.59.1. Bug fixes¶
GitHubAuthto retrieve all organizations instead of only those publicly available.
Fixed ref to point to branch instead of commit sha in
maybeColorizeis able to highlight single words and stop colorization at the end. The previous implementation only stopped colorization but not boldface.
fix compatibility issue with mysql5 (do not set default value for TEXT column).
Fixed addChange in
Changeto use the revlink configuration option to generate the revlink.
fix threading issue in
GerritEventLogPollerpoller to poll Gerrit changes via http API.
GerritVerifyStatusPushcan send multiple review status for the same Gerrit change.
IRCappends the builder URL to a successful/failed build if available
useSmtpsparameter for initiating connection over an SSL/TLS encrypted connection (SMTPS)
HyperLatentWorker, can be None. In that case, they will be auto-generated from random number.
verboseparameters to control the JSON sent to Stash.
Buildbot can now be configured to deny read access to REST api resources based on authorization rules.