Skip to main content

Build Galaxy things in virtualized environments

This project has been archived.

The maintainers of this project have marked this project as archived. No new releases are expected.

Project description

Starforge Logo

Starforge: Build Galaxy things in virtualization

Things you can do with Starforge:

These things will be built in Docker. Additionally, wheels can be built in QEMU/KVM virtualized systems.

Documentation can be found at starforge.readthedocs.org

Quick Start

For all types of builds, begin by installing Docker.

Tool Shed Dependencies

There are two scripts that can be used, depending on the package recipes available:

$ ./build.sh <package>
$ python build.py <package> --version 1.0

build.sh is the older format, and simply uses a single <package>build.sh file, like Atlas. build.py is the newer format, and uses yaml metadata in <package>/<version>/build.yml.

The base image for Galaxy packages is Debian Squeeze. This will hopefully produce binaries usable on Galaxy’s targeted platforms (at time of writing: CentOS 6+, Debian 6.0+, Ubuntu 12.04+).

$ ./build galaxy <package>
$ python build.py <package>

To build packages against a different OS, you can use the –image flag, e.g.:

$ ./build <dist>[:tag] <package>
$ python build.py <package> --image <dist>[:tag]

e.g.

$ ./build ubuntu:trusty nginx
$ python build.py nginx --image debian:squeeze

Building all the things:

There’s a separate build-all.sh which allows you to build all of the packages using their preferred build mechanism

Notes on the two build scripts

build.py

The <version> option is optional, and defaults to the string 'default', which is useful for recipes that don’t have version specific changes (E.g. bcftools 1.0 builds identically to 1.2)

Python Wheels

Starforge can build both pure Python and C-extension Python modules into wheels for Linux under Docker and for Mac OS X under QEMU/KVM. To do this, you’ll want to install Starforge (preferably in a Python virtualenv) using pip install starforge (to install from PyPI) or python setup.py install to install from the source.

Docker (and QEMU) images to use are specified in starforge/config/default.yml. To modify this file, copy it to $XDG_CONFIG_HOME/galaxy-starforge/config.yml ($XDG_CONFIG_HOME is, by default ~/.config). The sample file wheels/build/wheels.yml is used to determine what wheels can be built and their rules for building. To use this file, use the --wheels-config argument to starforge wheel or copy wheels.yml to $XDG_CONFIG_HOME/galaxy-starforge/wheels.yml.

Wheels can be built using starforge wheel <package>, e.g.:

$ starforge wheel pycrypto
$ starforge wheel --no-qemu pysam   # only build on docker

See the output of starforge --help for help using the Starforge command-line interface.

Pull Request wheel builder

Pull requests to the Starforge repository on Github that modify wheels/build/wheels.yml can automatically be built for all specified platforms on a dedicated Starforge build server by the Galaxy Jenkins service. To utilize, modify wheels.yml as appropriate and create a pull request. Any member of the Galaxy Committers group can then authorize Jenkins to initiate the build. If it fails, you can modify the pull request and further builds can be triggered.

Notes on images

Linux

Images used to build wheels are uploaded to the Starforge Docker Hub repo and will be pulled as necessary. Typically you will only use the manylinux1-wheel and manylinux1-32-wheel images, which are manylinux CentOS 5-based images that will usually produce wheels usable on all Galaxy-supported platforms.

You can also produce “platform-specific” wheels by using the full-wheel imageset. This is useful if you want to link to distribution-specific system versions of non-standard libraries without bundling them in to the wheel.

Mac OS X

Mac OS X images are not provided due to legal reasons. Consult the osx documentation for details.

Starforge is maintained by the Galaxy Project and community. A list of contributors to the project can be found on GitHub.

History

0.3.5 (2017-10-01)

0.3.4 (2017-09-12)

  • Native support for auditwheel and delocate. (#160)

0.3.3 (2017-09-08)

  • Do not build sdists with the wheel subcommand by default. (#155)

0.3.2 (2017-09-08)

  • Fix a bug where the wrong working directory was set when building wheels with multiple sources. (#154)

0.3.1 (2017-09-08)

  • Fix a bug with sudo and brew install on macOS. (#151).

  • Short circuit platform caching on OS X (#150).

0.3 (2017-01-10)

  • Drop the dependency on the “Galaxy” wheel fork, which makes installation much easier. “Platform-specific” wheels can still be built.

  • When building Docker images, install Starforge from the local source instead of installing from PyPI or Github.

0.2.1 (2016-05-27)

  • Do a case-insensitive comparison for cached tarball names (uWSGI’s project name is uWSGI but its source tarballs are named uwsgi-*). 7672547

0.2 (2016-05-19)

  • Added support for building manylinux1 wheels. 0dbecb7

0.1.1 (2016-01-20)

  • Only running prebuild during wheel builds (and not sdists) was too naive, since this prevents changing the version number of sdists in the prebuild action (a common use of the prebuild action). Instead, allow for separate wheel, sdist, and all prebuild actions. Reverts the behavior of 9008c57. Issue 64

  • Install Galaxy pip from Github instead of wheels.galaxyproject.org so that Starforge images can be built with new versions of Galaxy pip before they are released. 97b4ba4

0.1 (2016-01-12)

  • Reimplemented the wheel building scripts as a library and starforge command line

  • Wrote some documentation

Older than 0.1

Originally Galaxy docker-build and later renamed Starforge, but as a collection of disjointed shell scripts, Python, and YAML used to build Galaxy Tool Shed dependencies, as well as rebuilding Debian and Ubuntu source packages with modifications (which itself came from a project created to do the same via Vagrant and Ansible called vadebuildsible).

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

starforge-0.3.5.tar.gz (25.9 kB view details)

Uploaded Source

Built Distribution

starforge-0.3.5-py2-none-any.whl (35.6 kB view details)

Uploaded Python 2

File details

Details for the file starforge-0.3.5.tar.gz.

File metadata

  • Download URL: starforge-0.3.5.tar.gz
  • Upload date:
  • Size: 25.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for starforge-0.3.5.tar.gz
Algorithm Hash digest
SHA256 a2135ddea6c2108956d4924134c74c3c6746f8a32ee8e73e0f443b01c25f96ec
MD5 fcfb6df0aaaaac61271b73a763915fa4
BLAKE2b-256 c7780ff493e4aa52505ea1eba1f6a667899826466682292fb914f9590dd788e1

See more details on using hashes here.

File details

Details for the file starforge-0.3.5-py2-none-any.whl.

File metadata

File hashes

Hashes for starforge-0.3.5-py2-none-any.whl
Algorithm Hash digest
SHA256 4a26c6bcef1708cb7a823be5684915641b393fb3e07ef0a722f0313e57f7f50a
MD5 0a85b8a5c67f64477ad6d82b267c6828
BLAKE2b-256 56160a96f16a71d1babdb7d2e2bd180a553ea2ff2099e218c5a3a0e42437a273

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page