Log in

Registration

NeuroDebian: NeuroDebian nd* tools

Posted: April 15, 2012 / in: Articles / No comments


NeuroDebian nd* tools

One of the goals of NeuroDebian is to provide recent versions of
scientific software on stable Debian (and Ubuntu) deployments. That
is why we build (whenever possible) every new package not only for the
Debian unstable (the entry point of packages into Debian) but also for
Debian testing and stable, and Ubuntu releases. To automate such
procedure we prepared few rudimentary wrappers around cowbuilder
allowing to build packages in isolated environment. Also we provide a
backport-dsc script to ease backporting with optional application of
per-release patchsets. In this blog post we would like to introduce
you to these tools. They will be of use for anyone working on a
package intended to be uploaded to NeuroDebian repository or anyone
interested to verify if package could be easily backported. With a
single command you will be able to build a given Debian source package
across distributions. As a result you will verify that there are no
outstanding backport-ability issues or compatibility problems with
core components (e.g. supported versions of Python) if your source
package excercises test suites at build time.

Procedure

  • [1-20 min] If you are not running Debian-based distribution,
    Install NeuroDebian VM; otherwise just add apt
    sources for NeuroDebian repository
    .

  • [<1 min] Install the neurodebian-dev package providing nd* tools:

    sudo apt-get install neurodebian-dev
  • [1-5 min] Adjust default configuration (sudo vim
    /etc/neurodebian/cmdsettings.sh
    ) used by nd commands to

    • point cowbuilderroot variable to some directory under
      brain account, e.g. ~brain/debs (should be created by you)
    • remove undesired releases (e.g. deprecated karmic) from
      allnddist and alldist
    • adjust mirror entries to use the Debian mirror and Ubuntu
      mirror
      of your choice or may be even point to your approx apt-caching server
  • [10-60 min] Create the COWs for all releases you left in the
    configuration file:

    sudo nd_adddistall

Building

At this point you should be all set to build packages for all
distributions with a single command. E.g.:

sudo nd_build4all blah_1-1.dsc

should take the .dsc file you provide, and build it for main Debian
sid and all ND-supported releases of Debian and Ubuntu.
nd_build4allnd would build only for the later omitting the vanilla
Debian sid. The highlevel summary either builds succeed or failed get
reported in summary.log in the same directory, pointing to
.build log files for the corresponding architecture/release.

Troubleshooting Failing Build

Provide --hookdir cmdline pbuilder argument to point to a hook
which would get kicked in by pbuilder upon failure, e.g.:

sudo apt-get install git
git clone https://github.com/neurodebian/neurodebian
sudo nd_build4debianmain *.dsc -- --hookdir $PWD/neurodebian/tools/hooks

If you have any comments (typos, improvements, etc) – feel welcome to
leave a comment below, or contact us .

Article source: Go to Source
Feed source: http://planet.debian.org/rss20.xml
License: The original licenses are retained – MIT (Expat) License

Tags: , , , , , , , , , , , , , , , ,

© Copyrights and Licenses, 2014 - Linux-Support.com The Professional Linux and OSS Services Portal