⇤ ← Revision 1 as of 2010-07-07 19:56:16
Size: 7567
Comment:
|
Size: 5983
Comment: Removed sections not relevant to "daily build" usage.
|
Deletions are marked like this. | Additions are marked like this. |
Line 215: | Line 215: |
=== Automatically uploading the result to a PPA === `bzr-builder` can also sign and upload the resulting source package to a PPA (or any other `dput` upload target that accepts source packages). You can use the `--key-id` option to specify the GPG key id to sign with, in the same way as you can to `debsign` and `debuild`. In order to upload to a PPA you use the `--dput` option, specifying the dput target for the PPA. For example {{{ $ bzr dailydeb package.recipe working-dir --key-id E3B4482 --dput ppa:dailydebs-team/ppa }}} === Putting this in cron === In order to have daily packages you need to run the command every day. You can do this by hand, or you could automate it. The difficulty with automating it is with the GPG key, as it needs to be used un-attended. To save having to create and remove temporary directories you can have the command do this for you by not specifying a working directory. {{{ $ bzr dailydeb package.recipe --key-id E3B4482 --dput ppa:dailydebs-team/ppa }}} If you wish to go this route then you should ensure the things that can be done with the GPG key are limited in case it is compromised. This means that you should create a new Launchpad user account purely for doing daily builds, and only associate the key with that account. You should not grant access to anything on Launchpad except the PPAs that it will upload to. Also, if you have a `~/.dput.conf` with a [ppa] section in it it will override this command, so you'll want to make sure it's not named "ppa" or remove it completely. |
bzr-builder is a bzr plugin that helps you in setting up Packaging/SourceBuilds.
Installation
You can install it using the PPA at
or by running
$ mkdir -p ~/.bazaar/plugins/ $ bzr branch lp:bzr-builder ~/.bazaar/plugins/builder
You can check it is installed by running
$ bzr plugins -v
and looking for "builder" in the listed plugins.
Getting Help
Help for the plugin is available by running
$ bzr help builder
and help for the individual commands is available as
$ bzr help build $ bzr help dailydeb
Recipes
bzr-builder works with "recipes" that are descriptions of the steps needed to construct a package from the various bzr branches. You create one by writing a text file with a certain format.
The start of the file always looks similar to
# bzr-builder format 0.2 deb-version 1.0+{time}
The # bzr-builder format 0.2 is the same for each, and just specifies the version of the format in use. The current format is 0.2, and is increased as the format changes.
deb-version 1.0+{time} specifies the version to use for the generated package. {time} here is a substitution variable, more information on those will be given later.
The next line specifies the branch to base the package on:
lp:bzr
This says that we will use the trunk of the bzr project.
Then there is any number of other lines to specify other branches to include. The usual way to do this is to use the merge keyword to specify a simple merge of the branch.
merge fix-build lp:~bzr/bzr/fix-build
fix-build is the id of the branch within this file, it doesn't have to be the same as any part of the branch URL, but it has to be unique within the file. lp:~bzr/bzr/fix-build is again the location of the branch. What we are doing here is merging in a branch that we know we need in order to fix the build, but that hasn't landed in lp:bzr yet.
The other way to include code is to use the nest keyword.
nest pyfoo lp:pyfoo foo
The nest keyword specifies nesting another branch, instead of merging it. In this case we are nesting lp:pyfoo in to lp:bzr. We are using pyfoo to refer to it in the file, and we want it nested in the foo directory, so we specify that last.
It is possible to act on the nested branch in the same way as with the main branch. Any lines that are indented by two spaces under a nest line will act on the nested branch, e.g.
merge branding lp:~bob/pyfoo/ubuntu-branding
would merge the ubuntu-branding branch in to foo.
The resulting branch needs to already have the debian directory in place with the packaging in it, as it can't be auto-generated. Therefore you will often need to merge one or more packaging branches:
merge packaging lp:~bzr/bzr/packaging
In total this recipe would look like
# bzr-builder format 0.2 deb-version 1.0+{time} lp:bzr merge fix-build lp:~bzr/bzr/fix-build nest pyfoo lp:pyfoo foo merge branding lp:~bob/pyfoo/ubuntu-branding merge packaging lp:~bzr/bzr/packaging
Specifying revisions
Sometimes you want to specify a specific revision of a branch to use, rather than the tip. You can do this by including a revision specifier at the end of any branch line, e.g.
merge packaging lp:~bzr/bzr/packaging revno:2355
or, for the first branch line
lp:bzr tag:1.0
would mean that every time the recipe was used it would use the "1.0" tag from that branch.
Version numbers
The deb-version specifier allow you to specify a version number for the resulting package, but it's not very useful if it is only ever a single version number, as you need it to increase.
The example above (1.0+{time}), use a substitution variable. This will be replaced when the version number is needed with the current date and time (UTC). This will ensure that later packages get higher version numbers.
There is a second variable that you can use as well: {revno}. This will be replaced the revision number of the revision that was used from the primary branch. You can use the revision number of any branch by using {revno:<branch id>}.
You can use as many substitution variables as you like, e.g.
deb-version 1.0+{revno}-0ubuntu0+{revno:packaging}+{time}
Which would expand to something like
deb-version 1.0+4264-0ubuntu0+2145+200907201627
Running Commands
Sometimes it is necessary to run a command in order to prepare a branch for packaging, and bzr-builder supports this. If you add
run autoreconf -i
at one point in the recipe it will run the command (autoreconf -i here) when it reaches that point while building the package.
It is recommended to avoid arbitrary network access, as you do not know the environment in which the command will be run.
Note that run can also be used in nest sections, where it will be run in the nested location.
nest packaging lp:~team/project/ubuntu debian run cat control
would run cat control in the debian directory.
The command is passed through the shell, so you can use shell constructs.
run touch a && touch b
If the command exits with a non-zero error code then it will stop the building of the package.
Building the recipe
In order to build the recipe you need to use the bzr dailydeb command.
$ bzr dailydeb package.recipe working-dir
This will perform the steps specified in package.recipe. It will create working-dir and put the resulting source tree and the source package there.
You can examine the unpacked source tree and then build the source package and install the results.