Skip to content

Using Container Tools

A Rockface container tool allows a process running within a Linux container to interact with your device via USB.

In the rockface python library, power supply tools are represented using the rockface.tools.container.ContainerTool type:

py
from rockface import Rig
from rockface.tools.container import ContainerTool

rig = Rig.find_by_name("my-rig")
container = rig.tools["my-container"]

assert isinstance(container, ContainerTool)

Examples continue from the above

For brevity, the rest of the examples on this page will continue on from the above example, with the container variable set to a ContainerTool instance.

Running a Container

A container can be invoked using its run method. This takes a container registry location to pull the container image from, as well as the command to run in that container:

py
job = container.run("alpine:latest", ["echo", "Hello Rockface"])

Execution State

After a call to run, the returned Job instance represents the container. The is_running property of this object may be used to determine if the container job is still active:

py
import time

job = container.run("alpine:latest", ["sleep", "3"])

print(job.is_running)
time.sleep(5)
print(job.is_running)

Standard Output and Error

The stdout property of the Job instance provides access to the standard output of the container. This provides a file-like object:

py
print(job.stdout.read())

Similarly, the stderr property provides access ot the standard error output of the container:

py
print(job.stderr.read())

Standard Output and Standard Error are currently only available once a job has completed

Future versions of this tool will make this available during execution.

Return Code

Once the job is complete, the return_code property of the Job instance provides access to the return code of the container:

py
print(f"The container's return code was {job.return_code}")

Termination

A running container may be terminated by either sending it a SIGTERM or a SIGKILL signal:

py
job = container.run("alpine:latest", ["sleep", "infinity"])

# Send a SIGTERM signal to the container
job.terminate()

# Send a SIGKILL signal to the container
job.kill()

Registry Authentication

The username and password for a private container registry can be provided as arguments to the run method:

py
job = container.run("foo.com/baa:latest",
                    ["echo", "Hello Rockface"],
                    username="someone",
                    password="a secret")

Reset

A container tool can be reset using its reset method:

py
container.reset()

This causes the running container to be terminated. A container tool will always be reset at the end of a session (when the rig lock is dropped).