/fabian-multi-buildpack

Cloud Foundry buildpack for running multiple buildpacks

Primary LanguageGoApache License 2.0Apache-2.0

Cloud Foundry Multi-buildpack

CF Slack Join us on Slack

The multi-buildpack buildpack provides older Cloud Foundry deployments with the same multi-buildpack support that is available in Cloud Foundry's CAPI v3 API. See Understanding Buildpacks for more info.

Usage

  • This buildpack looks for a multi-buildpack.yml file in the root of the application directory with structure:
buildpacks:
  - https://github.com/cloudfoundry/go-buildpack
  - https://github.com/cloudfoundry/ruby-buildpack/releases/download/v1.6.23/ruby_buildpack-cached-v1.6.23.zip
  - https://github.com/cloudfoundry/nodejs-buildpack#v1.5.18
  - https://github.com/cloudfoundry/python-buildpack#develop
  • The multi-buildpack will download + run all the buildpacks in this list in the specified order.

  • It will use the app start command given by the final buildpack (the last buildpack in your multi-buildpack.yml).

  • The multi-buildpack buildpack will not work with system buildpacks. You must use URLs as shown above. Ex. the following multi-buildpack.yml file will not work:

buildpacks:
  - ruby_buildpack
  - go_buildpack

Testing

Buildpacks use the Cutlass framework for running integration tests against Cloud Foundry. Before running the integration tests, you need to login to your Cloud Foundry using the cf cli:

cf login -a https://api.your-cf.com -u name@example.com -p pa55woRD

Note that your user requires permissions to run cf create-buildpack and cf update-buildpack. To run the integration tests, run the following commands from the buildpack's directory:

  1. Source the .envrc file in the buildpack directory.

    source .envrc

    To simplify the process in the future, install direnv which will automatically source .envrc when you change directories.

  2. Run unit tests

    ./scripts/unit.sh
  3. Run integration tests

    ./scripts/integration.sh

More information can be found on Github cutlass.

Contributing

Find our guidelines here.

Help and Support

Join the #buildpacks channel in our Slack community if you need any further assistance.

Reporting Issues

Please fill out the issue template fully if you'd like to start an issue for the buildpack.

Active Development

The project backlog is on Pivotal Tracker.