Skip to main content
Version: QB11

Working with Bazaar

Prerequisites

QuickBuild utilizes the Bazaar command (bzr) to interact with remote Bazaar repository. If this command is not in system path, you will need to specify location of the command by configuring Bazaar plugin as below:

warning

Please also install bazaar plugin bzr-xmloutput: https://launchpad.net/bzr-xmloutput

Further more, Bazaar command (bzr) location can be specified on a per-node basis by following below steps:

  1. Open Bazaar plugin setting page and define the Bazaar path property as:

    ${node.getAttribute("bzrPath")}
  2. For each node that does not have Bazaar on system path, define the user attribute bzrPath to point to the actual Bazaar path like below:

NOTE: example above is just for demonstration, you can use any other user attribute name instead of bzrPath.

Creating a Bazaar Repository

You may refer to this page on how to add a repository.

Supported URL prefixes

Currently, below URL prefixes are supported:

aftp://Access using active FTP.
bzr://Fast access using the Bazaar smart server.
bzr+ssh://Fast access using the Bazaar smart server over SSH.
file://Access using the standard filesystem (default)
ftp://Access using passive FTP.
http://Read-only access of branches exported on the web.
https://Read-only access of branches exported on the web using SSL.
sftp://Access using SFTP (most SSH servers provide SFTP).
svn://Access using the Subversion smart server.
svn+ssh://Access using the Subversion smart server tunneled over SSH.

If https is used, and your credential need password, you need first add the credential manually to the nodes which you want check out code to.

If bzr+ssh is used, please use public key without password for authorization and you need not specify the password when you create the repository. You can reference your SSH manual on how to create public key without password.

Proof build support

Your developers might need to push their local commits in local branches to a central official Bazaar repository occasionally. In this case, QuickBuild can validate these commits by running proof build before pushing them.

Test proof build as administrator

Since proof build set up is a bit tricky, we first set up proof build for the administrator account and make sure it works before we proceed to enable it for all developers. To set up proof build for administrator, please follow below steps:

  1. Login as administrator and download user agent by switching to My tab.
  2. Install and start user agent on your own desktop. For testing purpose, please start the agent as a foreground process. On windows, this can be done by running agent.bat ; on Unix platforms, this can be done by running agent.sh console
  3. Set up a test configuration on QuickBuild server, define a Bazaar repository, enable the proof build option in advanced section like below:
  4. Make sure the bazaar command exists in the system path of both server machine and your desktop. If not, please follow the prerequisites section to tell QuickBuild location of bazaar command.
  5. Add a repository/checkout step into step execution graph and have it checkout from the repository defined above.

Now proof build has been enabled for your account, please make some local commits into your local repository specified above, and then run the test configuration. If set up correctly, your local commits will be picked up and reflected in the build result. A local change tab will also appear to display local commits after build finishes. Your local commits will be pushed automatically if build is successful.

Enable proof build for all developers

Now that we have a concept of how proof build works. In order to get proof build works for all developers, we need to parameterize various proof build properties, so that different properties can be used for different developers. To do this, you will need to:

  1. Define configuration variables like below:

  2. Script various properties in proof build section to make use of above variables like below:

    Property NameProperty Value
    Local Repository Path${vars.get("localRepositoryPath")}
    Revision Spec to Verify${vars.get("revisionSpecToVerify")}
    Merge Conditionvars.get("merge").asBoolean()
    Push Conditionbuild.successful && vars.get("push").asBoolean()

In this way, various proof build properties will be prompted when your developer runs the build. Once they've been specified by your developer for the first time, the values will be remembered for subsequent triggers for that user.

At last we suggest to set up the configuration to enable concurrent builds so that multiple builds in the same configuration can run concurrently. This is vital to get fast feedback in case multiple developers are requesting proof builds in the same time.