DocsReleasesCommunityGuidesBlog

GitHub Actions

The easiest way to build, package and test your unikernel application with GitHub workflows is to use the official Unikraft GitHub Action available on the marketplace.

The Unikraft GitHub Actions is designed to programmatically manage repositories that can be built as a Unikraft unikernel via GitHub Workflows:

  • Build projects that have a Kraftfile;
  • Test unikernels in emulation mode or run the internal test suite;
  • Package images into an OCI image and push to compatible registries.

View the Action on the GitHub Marketplace:
https://github.com/marketplace/actions/build-unikernel-images-with-unikraft

Basic Usage#

In the following example, a repository that has been initialized with a top-level Kraftfile that contains a target for qemu/x86_64 will be built every time a PR is opened, synchronized or re-opened:

name: example1
on:
pull_request:
types: [opened, synchronize, reopened]
jobs:
build:
steps:
- uses: actions/checkout@v3
- uses: unikraft/kraftkit@stable
with:
workdir: .
kraftfile: Kraftfile
arch: x86_64
plat: qemu

Using matrices to build multiple targets#

If your project has multiple targets, you can use the workflow matrix syntax which enumerates matrices to build each target independently:

name: example2
jobs:
build:
strategy:
fail-fast: false
matrix:
include:
- plat: qemu
arch: x86_64
- plat: qemu
arch: arm64
steps:
- uses: actions/checkout@v3
- uses: unikraft/kraftkit@stable
with:
workdir: .
kraftfile: Kraftfile
plat: ${{matrix.plat}}
arch: ${{matrix.arch}}

Testing run-to-completion-type unikernels#

Applications which are designed as run-to-completion, meaning that they execute a single task non-continuously and exit, can be executed by the GitHub action via QEMU's TCG (which emulates hardware ISA). Simply enable the execute: true attribute of the action. This is useful for applications which perform a single task, or run a suite of tests:

name: example3
on:
pull_request:
types: [opened, synchronize, reopened]
jobs:
build:
steps:
- uses: actions/checkout@v3
- uses: unikraft/kraftkit@stable
with:
workdir: .
kraftfile: Kraftfile
arch: x86_64
plat: qemu
execute: true

See an example with Unikraft's official workflow which runs the internal test suite uktest.

Inline-Kraftfile#

For more complex scenarios where you may wish to do variable substitutions in the workflow file, it is possible to embed the Kraftfile directly in the action, this is possible using the following syntax:

name: example4
on:
pull_request:
types: [opened, synchronize, reopened]
jobs:
build:
steps:
- uses: actions/checkout@v3
- uses: unikraft/kraftkit@stable
with:
workdir: .
kraftfile: |
specification: v0.5
unikraft: stable
libraries:
musl: stable
targets:
- plat: qemu
arch: x86_64
arch: x86_64
plat: qemu

Packaging and publishing images#

The GitHub action, for now, only supports packaging the resulting unikernel image in OCI Image format. This allows you to distribute the image using conventional OCI Image Registries, such as the one provided by GitHub (GHCR). This image format is also recognized by kraft. To publish your image in a registry, you must first login to the registry and then specify the canonical name via output: oci://... and indicate you wish to push the image:

name: example5
on:
pull_request:
types: [opened, synchronize, reopened]
jobs:
build:
steps:
- uses: actions/checkout@v3
- name: Login to OCI registry
uses: docker/login-action@v2
with:
registry: ghcr.io
username: ${{ secrets.REG_USERNAME }}
password: ${{ secrets.REG_TOKEN }}
- uses: unikraft/kraftkit@stable
with:
workdir: .
kraftfile: Kraftfile
arch: x86_64
plat: qemu
output: oci://ghcr.io/username/repo:latest
push: true
Edit this page on GitHub

Connect with the community

Feel free to ask questions, report issues, and meet new people.

Join us on Discord!
®

Getting Started

What is a unikernel?Install CLI companion toolUnikraft InternalsRoadmap

© 2025  The Unikraft Authors. All rights reserved. Documentation distributed under CC BY-NC 4.0.