Big News!  Tilt is joining Docker
Photo by Iris Aldeguer on Flickr.

Using Pack and Buildpacks

Commit of the Month: A Buildpack Extension

In April we introduced Tilt Extensions. Extensions are open-source packaged functions that extend the capability of Tilt, right inside your Tiltfile. Since releasing them we’ve seen several great extensions contributed by members of the community and we’re highlighting one of them as April’s Commit of the Month: an extension to use pack and buildbacks to build container images by Gareth Rushgrove!

What is a buildpack? What is pack?

From the docs: A buildpack is a unit of work that inspects your app source code and formulates a plan to build and run your application.

Typical buildpacks are a set of at least three files:

  • buildpack.toml – provides metadata about your buildpack
  • bin/detect – determines whether buildpack should be applied
  • bin/build – executes buildpack logic

pack is a command line tool that takes your source code and invokes the appropriate buildpack(s) to create a Docker image, or deploy it straight in to the cloud of your choice.

How does the Tilt pack extension work?

This extension makes the pack function available in your Tiltfile, which is used the same way as docker_build to allow Tilt to automatically build a container image with a known name.

load('ext://pack', 'pack')

pack('example-image')
k8s_yaml('kubernetes.yaml')
k8s_resource('example-deployment', port_forwards=8000)

Example taken from the extension README

It’s implemented as a light wrapper around custom_build:

def pack(name, path=".", builder="gcr.io/paketo-buildpacks/builder:base", **kwargs):
     custom_build(
         name,
         "pack build $EXPECTED_REF -p %s --builder %s" % (path, builder),
         [path],
         **kwargs
     )

Due to the use of **kwargs you can pass any custom_build parameter like so:

pack('example-image', ignore=['.vim'])

We love this method of providing an easy abstraction to use something complex like custom_build, without losing access to the full power of custom_build if you need it.

Have an idea for an extension?

Do you have an idea for an extension? We’d love to chat about it and help you contribute it to the Tilt Extensions Repository.

Related

Already have a Dockerfile and a Kubernetes config?

You’ll be able to setup Tilt in no time and start getting things done. Check out the docs! 

Having trouble developing your servers in Kubernetes?