Skip to content

Improve stats logs and add build flavor split #83

Improve stats logs and add build flavor split

Improve stats logs and add build flavor split #83

Workflow file for this run

name: Code tests & eval
on:
push:
branches: [ main ]
pull_request:
branches: [ main ]
permissions:
contents: read
jobs:
build-modules:
name: Build apps
runs-on: ubuntu-24.04
steps:
- name: Checkout source code
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd #v6.0.2
with:
persist-credentials: false
- name: Setup project and build environment
uses: ./.github/actions/common-setup
- name: Build modules
run: ./gradlew assemble
build-docker-image:
name: Build Docker image
runs-on: ubuntu-24.04
steps:
- name: Checkout source code
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd #v6.0.2
with:
persist-credentials: false
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@4d04d5d9486b7bd6fa91e7baf45bbb4f8b9deedd #v4.0.0
- name: Build Docker image
uses: docker/build-push-action@d08e5c354a6adb9ed34480a06d141179aa583294 #v7.0.0
with:
context: .
platforms: linux/amd64
push: false
run-tests:
name: Run tests
runs-on: ubuntu-24.04
container: ubuntu:24.04
env:
# The container image ships with the POSIX locale, which makes the JVM use ASCII
# for sun.jnu.encoding. Kotlin then can't write .class files for backticked test
# names containing non-ASCII characters (em-dashes, etc.). C.UTF-8 is built into
# glibc on Ubuntu, no `locales` package needed.
LANG: C.UTF-8
LC_ALL: C.UTF-8
steps:
- name: Checkout source code
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd #v6.0.2
with:
persist-credentials: false
- name: Setup project and build environment
uses: ./.github/actions/common-setup
- name: Check code and run tests
run: ./gradlew check
regression-synthetic-replay:
name: Cross-version regression (synthetic replay)
runs-on: ubuntu-24.04
needs: [run-tests, build-docker-image]
steps:
- name: Checkout source code
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd #v6.0.2
with:
persist-credentials: false
- name: Setup project and build environment
uses: ./.github/actions/common-setup
- name: Generate synthetic data tree (~500 accounts)
run: ./gradlew generateSyntheticData -PsyntheticOutputDir="$GITHUB_WORKSPACE/regression-data" -PsyntheticAccountCount=500
- name: Build Docker image
uses: docker/build-push-action@d08e5c354a6adb9ed34480a06d141179aa583294 #v7.0.0
with:
context: .
tags: octi-server:regression
load: true
push: false
platforms: linux/amd64
- name: Boot server with synthetic data and probe
run: |
set -euo pipefail
docker run -d --name octi-regression \
-p 18082:8080 \
-e OCTI_DEBUG=true \
-v "$GITHUB_WORKSPACE/regression-data:/etc/octi-server" \
octi-server:regression
# Give recovery a moment to walk the tree.
for attempt in $(seq 1 30); do
if curl -sf http://127.0.0.1:18082/v1/status > /dev/null; then
echo "server up after ${attempt}s"
break
fi
sleep 1
if [ "$attempt" = "30" ]; then
echo "server did not respond within 30s" >&2
docker logs octi-regression || true
exit 1
fi
done
curl -sf http://127.0.0.1:18082/v1/status
- name: Verify recovery did not log malformed entries
run: |
set -euo pipefail
# Production code never logs `recovery.*malformed` for legitimate trees; any hit
# means the synthetic fixture is shaped wrong OR a real recovery regression. Either
# way we want CI to fail loud.
if docker logs octi-regression 2>&1 | grep -E "recovery\.[a-z_]+_malformed"; then
echo "found recovery.*malformed in logs — failing" >&2
exit 1
fi
- name: Cleanup
if: always()
run: |
docker logs octi-regression 2>&1 | tail -200 || true
docker rm -f octi-regression || true
rm -rf "$GITHUB_WORKSPACE/regression-data" || true