Cleaning up and some doc

pull/1416/head
Quentin VIGNAUD 5 days ago
parent 2e8233c041
commit 16a814411d

@ -14,60 +14,6 @@ env:
permissions: {} permissions: {}
jobs: jobs:
#buildTestAyaDirect:
# uses: melodium-tech/github-actions/.github/workflows/melodium-ubuntu.yml@v0.9.1
# with:
# command: |
# run .melodium-ci/Compo.toml buildTestAyaDirect --github_contexts='$''{{{{ { "github": ${{ toJSON(github) }}, "vars": ${{ toJSON(vars) }}, "secrets": { "GITHUB_TOKEN": "'"$GITHUB_TOKEN"'" } } }}}}'
# artifact-path: 'logs/'
# secrets:
# token: ${{ secrets.GITHUB_TOKEN }}
buildTestAya:
strategy:
fail-fast: false
matrix:
arch:
- aarch64-unknown-linux-gnu
- armv7-unknown-linux-gnueabi
- loongarch64-unknown-linux-gnu
- powerpc64le-unknown-linux-gnu
- riscv64gc-unknown-linux-gnu
- s390x-unknown-linux-gnu
- x86_64-unknown-linux-gnu
uses: melodium-tech/github-actions/.github/workflows/melodium-ubuntu.yml@v0.9.1
with:
command: |
run .melodium-ci/Compo.toml buildTestAya --targets='[${{ toJSON( matrix.arch ) }}]' --repository_clone_url='"${{ github.repositoryUrl }}"' --repository_clone_ref='"${{ github.ref_name }}"' --github_contexts='$''{{{{ { "github": { "api_url": ${{ toJSON(github.api_url) }}, "repository": ${{ toJSON(github.repository) }}, "sha": ${{ toJSON(github.sha) }} }, "secrets": { "GITHUB_TOKEN": "'"$GITHUB_TOKEN"'" } } }}}}'
artifact-path: 'logs/'
artifact-name: 'mel_buildTestAya_${{ matrix.arch }}'
secrets:
token: ${{ secrets.GITHUB_TOKEN }}
permissions:
statuses: write
buildTestAyaEbpf:
uses: melodium-tech/github-actions/.github/workflows/melodium-ubuntu.yml@v0.9.1
with:
command: |
run .melodium-ci/Compo.toml buildTestAyaEbpf --repository_clone_url='"${{ github.repositoryUrl }}"' --repository_clone_ref='"${{ github.ref_name }}"' --github_contexts='$''{{{{ { "github": { "api_url": ${{ toJSON(github.api_url) }}, "repository": ${{ toJSON(github.repository) }}, "sha": ${{ toJSON(github.sha) }} }, "secrets": { "GITHUB_TOKEN": "'"$GITHUB_TOKEN"'" } } }}}}'
artifact-path: 'logs/'
artifact-name: 'mel_buildTestAyaEbpf'
secrets:
token: ${{ secrets.GITHUB_TOKEN }}
permissions:
statuses: write
#runs-on: ubuntu-latest
#steps:
# - uses: actions/checkout@v5
# - run: |
# .melodium-ci/melodium run .melodium-ci/Compo.toml buildTestAya --logs_directory '"logs/"' --github_contexts '$''{{{{ { "github": ${{ toJSON(github) }}, "vars": ${{ toJSON(vars) }}, "secrets": { "GITHUB_TOKEN": "'"$GITHUB_TOKEN"'" } } }}}}'
# uses: melodium-tech/github-actions/.github/workflows/melodium-ubuntu.yml@v0.9.0
# with:
# version: 0.9.0
# command: |
# run .melodium-ci/Compo.toml buildTestAya --logs_directory '"logs/"' --github_contexts '$''{{{{ { "github": ${{ toJSON(github) }}, "vars": ${{ toJSON(vars) }}, "secrets": { "GITHUB_TOKEN": "'"$GITHUB_TOKEN"'" } } }}}}'
# artifact-path: logs/
# secrets:
# token: "${{ secrets.GITHUB_TOKEN }}"
lint: lint:
runs-on: ubuntu-latest runs-on: ubuntu-latest
@ -193,6 +139,41 @@ jobs:
--exclude integration-test \ --exclude integration-test \
--feature-powerset --feature-powerset
buildTestAya:
# Calling Aya CI Mélodium implementation
#
# Current pipeline implementation is not independant from Github yet
# as it runs directly on Github Action runners because
# Rust cross build-and-test toolchain rely on specific Github Action runner image.
#
# In consequence:
# 1. we use `localStep` instead of remotely-operable `stepOn`,
# 2. we use a per-arch GA-matrix approach as it is inefficient to
# build multiple targets simultaneously on runners provided by Github,
# 3. there are no front time nor resources consumption improvement in current state.
# However this implementation is a basis to make Aya integration pipelines fully work in agnostic context using Mélodium.
strategy:
fail-fast: false
matrix:
arch:
- aarch64-unknown-linux-gnu
- armv7-unknown-linux-gnueabi
- loongarch64-unknown-linux-gnu
- powerpc64le-unknown-linux-gnu
- riscv64gc-unknown-linux-gnu
- s390x-unknown-linux-gnu
- x86_64-unknown-linux-gnu
uses: melodium-tech/github-actions/.github/workflows/melodium-ubuntu.yml@v0.9.1
with:
command: |
run .melodium-ci/Compo.toml buildTestAya --targets='[${{ toJSON( matrix.arch ) }}]' --repository_clone_url='"${{ github.repositoryUrl }}"' --repository_clone_ref='"${{ github.ref_name }}"' --github_contexts='$''{{{{ { "github": { "api_url": ${{ toJSON(github.api_url) }}, "repository": ${{ toJSON(github.repository) }}, "sha": ${{ toJSON(github.sha) }} }, "secrets": { "GITHUB_TOKEN": "'"$GITHUB_TOKEN"'" } } }}}}'
artifact-path: 'logs/'
artifact-name: 'mel_buildTestAya_${{ matrix.arch }}'
secrets:
token: ${{ secrets.GITHUB_TOKEN }}
permissions:
statuses: write
build-test-aya-ebpf: build-test-aya-ebpf:
runs-on: ubuntu-latest runs-on: ubuntu-latest
@ -263,6 +244,28 @@ jobs:
exit 1 exit 1
fi fi
buildTestAyaEbpf:
# Calling Aya CI Mélodium implementation
#
# Current pipeline implementation is not independant from Github yet
# as it runs directly on Github Action runners because
# Rust cross build-and-test toolchain rely on specific Github Action runner image.
#
# In consequence:
# 1. we use `localStep` instead of remotely-operable `stepOn`,
# 2. there are no front time nor resources consumption improvement in current state.
# However this implementation is a basis to make Aya integration pipelines fully work in agnostic context using Mélodium.
uses: melodium-tech/github-actions/.github/workflows/melodium-ubuntu.yml@v0.9.1
with:
command: |
run .melodium-ci/Compo.toml buildTestAyaEbpf --repository_clone_url='"${{ github.repositoryUrl }}"' --repository_clone_ref='"${{ github.ref_name }}"' --github_contexts='$''{{{{ { "github": { "api_url": ${{ toJSON(github.api_url) }}, "repository": ${{ toJSON(github.repository) }}, "sha": ${{ toJSON(github.sha) }} }, "secrets": { "GITHUB_TOKEN": "'"$GITHUB_TOKEN"'" } } }}}}'
artifact-path: 'logs/'
artifact-name: 'mel_buildTestAyaEbpf'
secrets:
token: ${{ secrets.GITHUB_TOKEN }}
permissions:
statuses: write
run-integration-test: run-integration-test:
strategy: strategy:
fail-fast: false fail-fast: false

@ -1,511 +0,0 @@
use cicd/logging::manageLogs
use cicd/runners::CicdDispatchEngine
use cicd/runners::CicdRunnerEngine
use cicd/runners::setupRunner
use cicd/runners::stopRunner
use cicd/services/github::prepareContexts
use cicd/services/github::postGithubStateContext
use cicd/services/github::|pending
use cicd/services/github::|success
use cicd/services/github::|error
use cicd/services/github::|failure
use cicd/steps::stepOn
use javascript::JavaScriptEngine
use log/logger::Logger
use log/log::logErrorMessage
use process/command::|raw_commands
use process/command::|command
use process/environment::Environment
use process/environment::|environment
use std/data/string_map::|entry
use std/data/string_map::|map
use std/engine/util::startup
use std/flow::waitBlock
use std/flow::trigger
use std/flow/concentrate::Concentrator
use std/flow/concentrate::concentrateBlock
use std/flow/concentrate::concentrated
use std/ops/option::|wrap
use std/text/compose::|format
use work/resources::|container
use work/resources/arch::|amd64
treatment buildTestAya(const api_token: string, const github_contexts: string = "{}", repository_clone_url: string, repository_clone_ref: string)
model logger: Logger()
model dispatcher: CicdDispatchEngine(api_token=api_token)
model finish_concentrator: Concentrator()
model github_contexts: JavaScriptEngine()
{
startup()
prepareContexts[contexts=github_contexts](github_contexts=github_contexts)
manageLogs[logger=logger](output_directory="logs/")
concentratedFinish: concentrated<void>[concentrator=finish_concentrator]()
triggerFinish: trigger<void>()
startup.trigger -> prepareContexts.trigger,ready -> concentratedFinish.trigger,data -> triggerFinish.stream,end -> manageLogs.stop
build_aarch64: /*buildTestAyaForArchUsingImage[logger=logger, dispatcher=dispatcher, github_contexts=github_contexts, finish_concentrator=finish_concentrator](
short_rust_arch="aarch64",
full_rust_arch="aarch64-unknown-linux-gnu",
ubuntu_arch="arm64",
image="ghcr.io/taiki-e/rust-cross-toolchain:aarch64-unknown-linux-gnu-dev-amd64",
repository_clone_ref=repository_clone_ref,
repository_clone_url=repository_clone_url
)*/
buildTestAyaForArch[logger=logger, dispatcher=dispatcher, github_contexts=github_contexts, finish_concentrator=finish_concentrator](
short_rust_arch="aarch64",
full_rust_arch="aarch64-unknown-linux-gnu",
ubuntu_arch="arm64",
repository_clone_ref=repository_clone_ref,
repository_clone_url=repository_clone_url
)
/*build_armv7: buildTestAyaForArch[logger=logger, dispatcher=dispatcher, github_contexts=github_contexts, finish_concentrator=finish_concentrator](
short_rust_arch="armv7",
full_rust_arch="armv7-unknown-linux-gnueabi",
ubuntu_arch="armhf",
repository_clone_ref=repository_clone_ref,
repository_clone_url=repository_clone_url
)
build_powerpc64le: buildTestAyaForArch[logger=logger, dispatcher=dispatcher, github_contexts=github_contexts, finish_concentrator=finish_concentrator](
short_rust_arch="powerpc64le",
full_rust_arch="powerpc64le-unknown-linux-gnu",
ubuntu_arch="ppc64le",
repository_clone_ref=repository_clone_ref,
repository_clone_url=repository_clone_url
)
build_riscv64gc: buildTestAyaForArch[logger=logger, dispatcher=dispatcher, github_contexts=github_contexts, finish_concentrator=finish_concentrator](
short_rust_arch="riscv64gc",
full_rust_arch="riscv64gc-unknown-linux-gnu",
ubuntu_arch="riscv64",
repository_clone_ref=repository_clone_ref,
repository_clone_url=repository_clone_url
)
build_s390x: buildTestAyaForArch[logger=logger, dispatcher=dispatcher, github_contexts=github_contexts, finish_concentrator=finish_concentrator](
short_rust_arch="s390x",
full_rust_arch="s390x-unknown-linux-gnu",
ubuntu_arch="s390x",
repository_clone_ref=repository_clone_ref,
repository_clone_url=repository_clone_url
)
build_x86_64: buildTestAyaForArch[logger=logger, dispatcher=dispatcher, github_contexts=github_contexts, finish_concentrator=finish_concentrator](
short_rust_arch="x86_64",
full_rust_arch="x86_64-unknown-linux-gnu",
ubuntu_arch="amd64",
repository_clone_ref=repository_clone_ref,
repository_clone_url=repository_clone_url
)*/
prepareContexts.ready -> build_aarch64.trigger
/*prepareContexts.ready -> build_armv7.trigger
prepareContexts.ready -> build_powerpc64le.trigger
prepareContexts.ready -> build_riscv64gc.trigger
prepareContexts.ready -> build_s390x.trigger
prepareContexts.ready -> build_x86_64.trigger*/
}
treatment checkout[logger: Logger, runner: CicdRunnerEngine](label: string, executor_name: string = "rust", repository_clone_url: string, repository_clone_ref: string)
input trigger: Block<void>
output success: Block<void>
output finished: Block<void>
output error: Block<void>
{
stepOn[logger=logger, runner=runner](
name = label,
executor_name = |wrap<string>(executor_name),
commands = |raw_commands([
"git config --global url.https://.insteadOf git://",
|format("git clone --branch {repository_clone_ref} --depth 1 {repository_clone_url} /root/aya",
|map([
|entry("repository_clone_ref", repository_clone_ref),
|entry("repository_clone_url", repository_clone_url)
])
)
])
)
Self.trigger -> stepOn.trigger,success -> Self.success
stepOn.finished --------> Self.finished
stepOn.error -----------> Self.error
}
treatment buildTestAyaForArch[logger: Logger, dispatcher: CicdDispatchEngine, github_contexts: JavaScriptEngine, finish_concentrator: Concentrator](short_rust_arch: string, full_rust_arch: string, ubuntu_arch: string, repository_clone_ref: string, repository_clone_url: string)
model runner: CicdRunnerEngine()
input trigger: Block<void>
output finished: Block<void>
{
setupRunner[logger=logger, dispatcher=dispatcher, runner=runner](
name="buildTestAya",
cpu=100,
memory=150,
storage=800,
containers=[
|container("rust", 6000, 1000, 8000, |amd64(), [], "rust:1.90-trixie", _)
]
)
stopRunner[runner=runner]()
concentrateFinish: concentrateBlock<void>[concentrator=finish_concentrator]()
Self.trigger -> setupRunner.trigger
build.finished -> stopRunner.trigger
build.finished -> concentrateFinish.data
prepareSystem: stepOn[logger=logger, runner=runner](
name = |format("prepare_system_{short}", |entry("short", short_rust_arch)),
executor_name = "rust",
commands = |raw_commands([
|format("dpkg --add-architecture {arch}", |entry("arch", ubuntu_arch)),
"apt-get update",
|format("apt-get install -y podman podman-docker liblzma-dev:{arch} qemu-user", |entry("arch", ubuntu_arch)),
${bash -c "curl -L --proto '=https' --tlsv1.2 -sSf https://raw.githubusercontent.com/taiki-e/setup-cross-toolchain-action/refs/tags/v1/main.sh | bash -"},
"cat /tmp/github.env"
]),
environment = |wrap<Environment>(
|environment(
|map([
|entry("INPUT_TARGET", full_rust_arch),
|entry("GITHUB_ENV", "/tmp/github.env")
]),
_, // working_directory
false, // expand_variables
false // clear_env
)
)
)
prepareRust: stepOn[logger=logger, runner=runner](
name = |format("prepare_rust_{short}", |entry("short", short_rust_arch)),
executor_name = "rust",
commands = |raw_commands([
|format("rustup target add {arch}", |entry("arch", full_rust_arch)),
${bash -c "curl -L --proto '=https' --tlsv1.2 -sSf https://raw.githubusercontent.com/cargo-bins/cargo-binstall/main/install-from-binstall-release.sh | bash -"},
"cargo binstall cargo-hack"
])
)
prepare: waitBlock<void>()
setupRunner.ready -> prepareSystem.trigger,success -> prepare.a
setupRunner.ready -> prepareRust.trigger,success ---> prepare.b
checkout[logger=logger, runner=runner](
label = |format("checkout_{short}", |entry("short", short_rust_arch)),
repository_clone_url = repository_clone_url,
repository_clone_ref = repository_clone_ref
)
ready: waitBlock<void>()
setupRunner.ready -> checkout.trigger,success -> ready.a
prepare.awaited -------------------------------> ready.b
build: stepOn[logger=logger, runner=runner](
name = |format("build_{short}", |entry("short", short_rust_arch)),
executor_name = "rust",
commands = |raw_commands([
// Build
${bash -c "set -o allexport && source /tmp/github.env && set +o allexport
cargo hack build --all-targets --feature-powerset --exclude aya-ebpf --exclude aya-ebpf-bindings --exclude aya-log-ebpf --exclude integration-ebpf --exclude xtask --workspace"
},
// Test
${bash -c "set -o allexport && source /tmp/github.env && set +o allexport
cargo hack test --all-targets --feature-powerset --exclude aya-ebpf --exclude aya-ebpf-bindings --exclude aya-log-ebpf --exclude integration-ebpf --exclude integration-test --exclude xtask --workspace"
},
// Doc
${bash -c "set -o allexport && source /tmp/github.env && set +o allexport
cargo hack test --doc --feature-powerset --exclude aya-ebpf --exclude aya-ebpf-bindings --exclude aya-log-ebpf --exclude integration-ebpf --exclude integration-test --exclude xtask --workspace"
},
"echo Build done",
"sleep 1"
]),
environment = |wrap<Environment>(
|environment(
|map([
|entry("RUST_BACKTRACE", "full"),
|entry("CARGO_BUILD_TARGET", full_rust_arch)
]),
"/root/aya", // working_directory
false, // expand_variables
false // clear_env
)
)
)
ready.awaited -> build.trigger,finished -> Self.finished
pendingState: postGithubStateContext[contexts=github_contexts, logger=logger](state = |pending(), name = short_rust_arch, description = "Build and Test Aya on arch", log_response = true)
successState: postGithubStateContext[contexts=github_contexts, logger=logger](state = |success(), name = short_rust_arch, description = "Build and Test Aya on arch", log_response = true)
errorState: postGithubStateContext[contexts=github_contexts, logger=logger](state = |error(), name = short_rust_arch, description = "Build and Test Aya on arch", log_response = true)
failureState: postGithubStateContext[contexts=github_contexts, logger=logger](state = |failure(), name = short_rust_arch, description = "Build and Test Aya on arch", log_response = true)
Self.trigger --> pendingState.trigger
build.success -> successState.trigger
build.error ---> errorState.trigger
build.failed --> failureState.trigger
}
treatment buildTestAyaForArchUsingImage[logger: Logger, dispatcher: CicdDispatchEngine, github_contexts: JavaScriptEngine, finish_concentrator: Concentrator](short_rust_arch: string, full_rust_arch: string, ubuntu_arch: string, image: string, repository_clone_ref: string, repository_clone_url: string)
model runner: CicdRunnerEngine()
input trigger: Block<void>
output finished: Block<void>
{
setupRunner[logger=logger, dispatcher=dispatcher, runner=runner](
name="buildTestAya",
cpu=100,
memory=150,
storage=800,
containers=[
|container("rust", 6000, 1000, 8000, |amd64(), [], image, _)
]
)
stopRunner[runner=runner]()
concentrateFinish: concentrateBlock<void>[concentrator=finish_concentrator]()
Self.trigger -> setupRunner.trigger
build.finished -> stopRunner.trigger
build.finished -> concentrateFinish.data
install: stepOn[logger=logger, runner=runner](
name = |format("install_{short}", |entry("short", short_rust_arch)),
executor_name = "rust",
commands = |raw_commands([
"apt-get update",
"apt-get install -y git"
])
)
checkout[logger=logger, runner=runner](
label = |format("checkout_{short}", |entry("short", short_rust_arch)),
repository_clone_url = repository_clone_url,
repository_clone_ref = repository_clone_ref
)
//ready: waitBlock<void>()
setupRunner.ready -> install.trigger,finished -> checkout.trigger//,success -> ready.a
//prepare.awaited -------------------------------> ready.b
build: stepOn[logger=logger, runner=runner](
name = |format("build_{short}", |entry("short", short_rust_arch)),
executor_name = "rust",
commands = |raw_commands([
// Build
${bash -c "cargo hack build --all-targets --feature-powerset --exclude aya-ebpf --exclude aya-ebpf-bindings --exclude aya-log-ebpf --exclude integration-ebpf --exclude xtask --workspace"
},
// Test
${bash -c "cargo hack test --all-targets --feature-powerset --exclude aya-ebpf --exclude aya-ebpf-bindings --exclude aya-log-ebpf --exclude integration-ebpf --exclude integration-test --exclude xtask --workspace"
},
// Doc
${bash -c "cargo hack test --doc --feature-powerset --exclude aya-ebpf --exclude aya-ebpf-bindings --exclude aya-log-ebpf --exclude integration-ebpf --exclude integration-test --exclude xtask --workspace"
},
"echo Build done",
"sleep 1"
]),
environment = |wrap<Environment>(
|environment(
|map([
|entry("RUST_BACKTRACE", "full"),
|entry("CARGO_BUILD_TARGET", full_rust_arch)
]),
"/root/aya", // working_directory
false, // expand_variables
false // clear_env
)
)
)
/*ready.awaited*/ checkout.finished -> build.trigger,finished -> Self.finished
pendingState: postGithubStateContext[contexts=github_contexts, logger=logger](state = |pending(), name = short_rust_arch, description = "Build and Test Aya on arch", log_response = true)
successState: postGithubStateContext[contexts=github_contexts, logger=logger](state = |success(), name = short_rust_arch, description = "Build and Test Aya on arch", log_response = true)
errorState: postGithubStateContext[contexts=github_contexts, logger=logger](state = |error(), name = short_rust_arch, description = "Build and Test Aya on arch", log_response = true)
failureState: postGithubStateContext[contexts=github_contexts, logger=logger](state = |failure(), name = short_rust_arch, description = "Build and Test Aya on arch", log_response = true)
Self.trigger --> pendingState.trigger
build.success -> successState.trigger
build.error ---> errorState.trigger
build.failed --> failureState.trigger
}
treatment buildTestAyaEbpfEntrypoint(const github_contexts: string = "{}", repository_clone_url: string, repository_clone_ref: string)
model logger: Logger()
model dispatcher: CicdDispatchEngine(location="compose", api_token="")
model github_contexts: JavaScriptEngine()
{
startup()
prepareContexts[contexts=github_contexts](github_contexts=github_contexts)
manageLogs[logger=logger](output_directory="logs/")
startup.trigger -> prepareContexts.trigger,ready -> buildTestAyaEbpf.trigger,finished -> manageLogs.stop
buildTestAyaEbpf[logger=logger, dispatcher=dispatcher, github_contexts=github_contexts](
repository_clone_ref=repository_clone_ref,
repository_clone_url=repository_clone_url
)
}
treatment buildTestAyaEbpf[logger: Logger, dispatcher: CicdDispatchEngine, github_contexts: JavaScriptEngine](repository_clone_ref: string, repository_clone_url: string)
model runner: CicdRunnerEngine()
input trigger: Block<void>
output finished: Block<void>
{
setupRunner[logger=logger, dispatcher=dispatcher, runner=runner](
name="buildTestAya",
cpu=100,
memory=150,
storage=800,
containers=[
|container("rust", 6000, 1000, 8000, |amd64(), [], "rust:1.90-trixie", _)
]
)
stopRunner[runner=runner]()
Self.trigger -> setupRunner.trigger
build.finished -> stopRunner.trigger
prepareSystem: stepOn[logger=logger, runner=runner](
name = "prepare_system",
executor_name = "rust",
commands = |raw_commands([
//|format("dpkg --add-architecture {arch}", |entry("arch", ubuntu_arch)),
"systemctl mask docker.service docker.socket",
"apt-get update"/*,
|format("apt-get install -y liblzma-dev:{arch} qemu-user", |entry("arch", ubuntu_arch)),
${bash -c "curl -L --proto '=https' --tlsv1.2 -sSf https://raw.githubusercontent.com/taiki-e/setup-cross-toolchain-action/refs/tags/v1/main.sh | bash -"},
"cat /tmp/github.env"*/
]),
environment = |wrap<Environment>(
|environment(
|map([
//|entry("INPUT_TARGET", full_rust_arch),
|entry("GITHUB_ENV", "/tmp/github.env")
]),
_, // working_directory
false, // expand_variables
false // clear_env
)
)
)
prepareRust: stepOn[logger=logger, runner=runner](
name = "prepare_rust",
executor_name = "rust",
commands = |raw_commands([
"rustup toolchain install nightly",
"rustup +nightly component install rust-src",
"cargo install --git https://github.com/aya-rs/bpf-linker.git bpf-linker --features llvm-21",
${bash -c "curl -L --proto '=https' --tlsv1.2 -sSf https://raw.githubusercontent.com/cargo-bins/cargo-binstall/main/install-from-binstall-release.sh | bash -"},
"cargo binstall cargo-hack"
])
)
prepare: waitBlock<void>()
setupRunner.ready -> prepareSystem.trigger,success -> prepare.a
setupRunner.ready -> prepareRust.trigger,success ---> prepare.b
checkout[logger=logger, runner=runner](
label = "checkout",
repository_clone_url = repository_clone_url,
repository_clone_ref = repository_clone_ref
)
ready: waitBlock<void>()
setupRunner.ready -> checkout.trigger,success -> ready.a
prepare.awaited -------------------------------> ready.b
build: stepOn[logger=logger, runner=runner](
name = "build",
executor_name = "rust",
commands = [|command("bash", ["-c", ${{{
set -euo pipefail
failures=()
# NB: this hand-rolled shell script is used instead of a matrix
# because the time spent doing useful work per target is about equal
# to the overhead of setting up the job - so this saves a bunch of
# machine time.
for arch in aarch64 arm loongarch64 mips powerpc64 riscv64 s390x x86_64; do
echo "::group::arch=$arch"
export RUSTFLAGS="--cfg bpf_target_arch=\"$arch\""
for target in bpfeb-unknown-none bpfel-unknown-none; do
echo "::group::target=$target"
if ! (
cargo +nightly hack build \
--release \
--target "$target" \
-Z build-std=core \
--package aya-ebpf \
--package aya-ebpf-bindings \
--package aya-log-ebpf \
--package integration-ebpf \
--feature-powerset
); then
failures+=("build: $arch/$target")
fi
echo "::endgroup::"
done
if ! (
RUSTDOCFLAGS=$RUSTFLAGS cargo +nightly hack test --doc \
--package aya-ebpf \
--package aya-ebpf-bindings \
--package aya-log-ebpf \
--package integration-ebpf \
--feature-powerset
); then
failures+=("doctests: $arch")
fi
echo "::endgroup::"
done
if ((${#failures[@]})); then
echo "::error::Some builds/tests failed:"
printf ' %s\n' "${failures[@]}"
sleep 1
exit 1
fi
}}}
])],
environment = |wrap<Environment>(
|environment(
|map([
|entry("RUST_BACKTRACE", "full")
]),
"/root/aya", // working_directory
false, // expand_variables
false // clear_env
)
)
)
ready.awaited -> build.trigger,finished -> Self.finished
pendingState: postGithubStateContext[contexts=github_contexts, logger=logger](state = |pending(), name = "All BPF", description = "Build & test for all BPF architectures", log_response = true)
successState: postGithubStateContext[contexts=github_contexts, logger=logger](state = |success(), name = "All BPF", description = "Build & test for all BPF architectures", log_response = true)
errorState: postGithubStateContext[contexts=github_contexts, logger=logger](state = |error(), name = "All BPF", description = "Build & test for all BPF architectures", log_response = true)
failureState: postGithubStateContext[contexts=github_contexts, logger=logger](state = |failure(), name = "All BPF", description = "Build & test for all BPF architectures", log_response = true)
Self.trigger --> pendingState.trigger
build.success -> successState.trigger
build.error ---> errorState.trigger
build.failed --> failureState.trigger
}
/*
treatment buildTestAya()
{
}
treatment buildTestAyaForArch[logger: Logger](arch: string, short_arch: string)
trigger: Block<void>
{
build: localStep[logger=logger](
name = |format("build_{short_arch}", |entry("short_arch", short_arch)),
description = |format("Build tests for Aya on {arch}", |entry("arch", arch)),
commands = |raw_commands([
// Build
"cargo hack build --all-targets --feature-powerset --exclude aya-ebpf --exclude aya-ebpf-bindings --exclude aya-log-ebpf --exclude integration-ebpf --exclude xtask --workspace",
// Test
"cargo hack test --all-targets --feature-powerset --exclude aya-ebpf --exclude aya-ebpf-bindings --exclude aya-log-ebpf --exclude integration-ebpf --exclude integration-test --exclude xtask --workspace",
// Doc
"cargo hack test --doc --feature-powerset --exclude aya-ebpf --exclude aya-ebpf-bindings --exclude aya-log-ebpf --exclude integration-ebpf --exclude integration-test --exclude xtask --workspace"
]),
variables = |wrap<StringMap>(|map([
|entry("RUST_BACKTRACE", "full"),
|entry("CARGO_BUILD_TARGET", arch)
]))
)
}*/
Loading…
Cancel
Save