Skip to content
This repository has been archived by the owner on Sep 28, 2024. It is now read-only.

Latest commit

 

History

History
60 lines (42 loc) · 2.01 KB

README.dev.md

File metadata and controls

60 lines (42 loc) · 2.01 KB

Developer README

Developer README. Not intended for end users.

Running workflow tests

Inside a hocus workspace run:

sudo ./ops/bin/dev/run-agent-tests.sh

You can set the following environment variable before running jest to see performance tracing:

PERF_MONITORING_ENABLED=1

This builds test virtual machines, attaches to the running Hocus agent, and starts an E2E test suite using https://github.com/hocus-dev/tests

You may also attach to the agent container manually. The following runs a single E2E test of the prebuild workflow:

OCI_PROXY=host.docker.internal:9999 yarn jest 'app/agent/workflows.test.ts' -t 'runBuildfsAndPrebuilds' --testTimeout 600000

Add another BuildKite runner

cp resources/buildkite/buildkite-agent.cfg.example resources/buildkite/buildkite-agent.cfg
cp resources/buildkite/hooks/secrets.rc.example resources/buildkite/hooks/secrets.rc
# Change what you need in buildkite-agent.cfg
vim resources/buildkite/buildkite-agent.cfg
# And in secrets.rc
vim resources/buildkite/hooks/secrets.rc
# This will build a new VM based on resources/docker/buildkite-agent.Dockerfile and start it in qemu.
# 16GB of host memory is passed to the VM as a balloon device with free page reporting enabled :)
# Half of the host cores are passed to the VM
sudo ./ops/bin/dev/run-buildkite.sh

Running Hocus locally with an init configuration

Init configuration is a YAML file that defines users, projects, and repositories that Hocus creates when it starts. It gets continuously updated by the control plane as users create new entities. Here's how to enable it.

First, create a directory for the init configuration:

INIT_CONFIG_DIR_PATH="$(pwd)/hocus-init"
mkdir -p "$INIT_CONFIG_DIR_PATH"

Hocus will create a file called config.yaml in this directory.

Then start Hocus with the environment variable INIT_CONFIG_DIR_PATH. Make sure it is an absolute path.

INIT_CONFIG_DIR_PATH="$INIT_CONFIG_DIR_PATH" HOCUS_HOSTNAME="localhost" ops/bin/local-up.sh