Hermetic Execution Mode

A Hermetic Build is a release engineering best practice for increasing the reliability and consistency of software builds. They are self-contained, and do not depend on anything outside of the build environment. This means they do not have network access, and cannot fetch dependencies at runtime.

When hermetic execution mode is enabled, all TaskRun steps will be run without access to a network. Note: hermetic execution mode does NOT apply to sidecar containers

Hermetic execution mode is currently an alpha experimental feature.

Enabling Hermetic Execution Mode

To enable hermetic execution mode:

  1. Make sure enable-api-fields is set to "alpha" in the feature-flags configmap, see install.md for details
  2. Set the following annotation on any TaskRun you want to run hermetically:
experimental.tekton.dev/execution-mode: hermetic

Sample Hermetic TaskRun

This example TaskRun demonstrates running a container in a hermetic environment.

The Step attempts to install curl, but this step SHOULD FAIL if the hermetic environment is working as expected.

kind: TaskRun
apiVersion: tekton.dev/v1beta1
metadata:
  generateName: hermetic-should-fail
  annotations:
    experimental.tekton.dev/execution-mode: hermetic
spec:
  timeout: 60s
  taskSpec:
    steps:
    - name: hermetic
      image: ubuntu
      script: |
        #!/usr/bin/env bash
        apt-get update
        apt-get install -y curl        

Further Details

To learn more about hermetic execution mode, check out the TEP.