Compare commits

...

20 Commits

Author SHA1 Message Date
Palash Tyagi
9da2b1f645
Merge 2249babc2a547ad79525ea9cbcba496a00af0ba2 into fc508bb1a99f8b95b4dea8027677e25ac101aa25 2025-05-04 01:08:04 +01:00
2249babc2a
Merge branch 'main' into floatops 2025-05-04 01:08:03 +01:00
fc508bb1a9
Merge pull request #37 from Magnus167/wkflow-update
Run workflows on self-hosted x86 and ARM runners
2025-05-04 01:01:21 +01:00
Palash Tyagi
c7f3cc6ef9 testing runners 2025-05-04 00:58:27 +01:00
Palash Tyagi
eb28b93781 reorganized GH runner setups 2025-05-04 00:53:19 +01:00
Palash Tyagi
33d021072e Refactor unit test steps for clarity and organization 2025-05-04 00:47:13 +01:00
Palash Tyagi
8ba39f8e87 Reorder steps in unit tests workflow to clarify coverage generation process 2025-05-04 00:42:34 +01:00
Palash Tyagi
cae230783e Enhance output messages for code coverage and documentation steps in unit tests workflow 2025-05-04 00:39:23 +01:00
Palash Tyagi
101ee8c1c7 Fix description for github-token input in runner fallback action 2025-05-04 00:35:07 +01:00
Palash Tyagi
b25c6d358e Add checkout step to runner selection in workflows 2025-05-04 00:33:28 +01:00
Palash Tyagi
aaac6bfc3b Update runner fallback action 2025-05-04 00:31:41 +01:00
Palash Tyagi
6076e0c8e3 Implement runner fallback mechanism for docs and unit test workflows 2025-05-04 00:29:06 +01:00
Palash Tyagi
d15aaf437f Add runner fallback action to select self-hosted or fallback GitHub-hosted runners 2025-05-04 00:28:58 +01:00
3b67d6e477
Merge branch 'main' into wkflow-update 2025-05-04 00:06:50 +01:00
Palash Tyagi
f084eae72c Add Docker setup files for ARM GitHub Actions self-hosted runner 2025-05-03 23:53:23 +01:00
Palash Tyagi
860cd4d081 Update workflows to support self-hosted runners 2025-05-03 23:17:47 +01:00
0a9d9e38c3
Merge branch 'main' into floatops 2025-05-03 01:32:25 +01:00
4d846287e8
Merge branch 'main' into floatops 2025-05-02 23:38:46 +01:00
bdd3293c65
Merge branch 'main' into floatops 2025-05-01 01:08:16 +01:00
Palash Tyagi
bda1298397 empty commit 2025-05-01 01:05:37 +01:00
13 changed files with 199 additions and 22 deletions

View File

@ -0,0 +1,61 @@
# actions/runner-fallback/action.yml
name: "Runner Fallback"
description: |
Chooses a self-hosted runner when one with the required labels is online,
otherwise returns a fallback GitHub-hosted label.
inputs:
primary-runner:
description: 'Comma-separated label list for the preferred self-hosted runner (e.g. "self-hosted,linux")'
required: true
fallback-runner:
description: 'Comma-separated label list or single label for the fallback (e.g. "ubuntu-latest")'
required: true
github-token:
description: "PAT or GITHUB_TOKEN with `repo` scope"
required: true
outputs:
use-runner:
description: "JSON array of labels you can feed straight into runs-on"
value: ${{ steps.pick.outputs.use-runner }}
runs:
using: "composite"
steps:
- name: Check self-hosted fleet
id: pick
shell: bash
env:
TOKEN: ${{ inputs.github-token }}
PRIMARY: ${{ inputs.primary-runner }}
FALLBACK: ${{ inputs.fallback-runner }}
run: |
# -------- helper -----------
to_json_array () {
local list="$1"; IFS=',' read -ra L <<<"$list"
printf '['; printf '"%s",' "${L[@]}"; printf ']'
}
# -------- query API ---------
repo="${{ github.repository }}"
runners=$(curl -s -H "Authorization: Bearer $TOKEN" \
-H "Accept: application/vnd.github+json" \
"https://api.github.com/repos/$repo/actions/runners?per_page=100")
# Split wanted labels
IFS=',' read -ra WANT <<<"$PRIMARY"
online_found=0
while read -r row; do
labels=$(jq -r '.labels[].name' <<<"$row")
ok=1
for w in "${WANT[@]}"; do
grep -Fxq "$w" <<<"$labels" || { ok=0; break; }
done
[ "$ok" -eq 1 ] && { online_found=1; break; }
done < <(jq -c '.runners[] | select(.status=="online")' <<<"$runners")
if [ "$online_found" -eq 1 ]; then
echo "✅ Self-hosted runner online."
echo "use-runner=$(to_json_array "$PRIMARY")" >>"$GITHUB_OUTPUT"
else
echo "❌ No matching self-hosted runner online - using fallback."
echo "use-runner=$(to_json_array "$FALLBACK")" >>"$GITHUB_OUTPUT"
fi

30
.github/runners/runner-arm/Dockerfile vendored Normal file
View File

@ -0,0 +1,30 @@
FROM ubuntu:latest
ARG RUNNER_VERSION="2.323.0"
# Prevents installdependencies.sh from prompting the user and blocking the image creation
ARG DEBIAN_FRONTEND=noninteractive
RUN apt update -y && apt upgrade -y && useradd -m docker
RUN apt install -y --no-install-recommends \
curl jq build-essential libssl-dev libffi-dev python3 python3-venv python3-dev python3-pip \
# dot net core dependencies
libicu74 libssl3 libkrb5-3 zlib1g libcurl4
RUN cd /home/docker && mkdir actions-runner && cd actions-runner \
&& curl -O -L https://github.com/actions/runner/releases/download/v${RUNNER_VERSION}/actions-runner-linux-arm64-${RUNNER_VERSION}.tar.gz \
&& tar xzf ./actions-runner-linux-arm64-${RUNNER_VERSION}.tar.gz
RUN chown -R docker ~docker && /home/docker/actions-runner/bin/installdependencies.sh
COPY entrypoint.sh entrypoint.sh
# make the script executable
RUN chmod +x entrypoint.sh
# since the config and run script for actions are not allowed to be run by root,
# set the user to "docker" so all subsequent commands are run as the docker user
USER docker
ENTRYPOINT ["./entrypoint.sh"]

View File

@ -0,0 +1,18 @@
# docker-compose.yml
services:
github-runner:
build:
context: .
args:
RUNNER_VERSION: 2.323.0
# container_name commented to allow for multiple runners
# container_name: github-runner
env_file:
- .env
volumes:
- runner-work:/home/runner/actions-runner/_work
restart: unless-stopped
volumes:
runner-work:

View File

@ -0,0 +1,24 @@
#!/bin/bash
REPOSITORY=$REPO
ACCESS_TOKEN=$GH_TOKEN
LABELS=$RUNNER_LABELS
# echo "REPO ${REPOSITORY}"
# echo "ACCESS_TOKEN ${ACCESS_TOKEN}"
REG_TOKEN=$(curl -X POST -H "Authorization: token ${ACCESS_TOKEN}" -H "Accept: application/vnd.github+json" https://api.github.com/repos/${REPOSITORY}/actions/runners/registration-token | jq .token --raw-output)
cd /home/docker/actions-runner
./config.sh --url https://github.com/${REPOSITORY} --token ${REG_TOKEN} --labels ${LABELS}
cleanup() {
echo "Removing runner..."
./config.sh remove --unattended --token ${REG_TOKEN}
}
trap 'cleanup; exit 130' INT
trap 'cleanup; exit 143' TERM
./run.sh & wait $!

View File

@ -0,0 +1,9 @@
# Repository name
REPO="Magnus167/rustframe"
# GitHub runner token
GH_TOKEN="some_token_here"
# Labels for the runner
RUNNER_LABELS=self-hosted-linux,linux

4
.github/runners/runner-x64/start.sh vendored Normal file
View File

@ -0,0 +1,4 @@
docker compose up -d --build
# docker compose up -d --build --scale github-runner=2

View File

@ -17,8 +17,23 @@ permissions:
pages: write
jobs:
docs-and-testcov:
pick-runner:
runs-on: ubuntu-latest
outputs:
runner: ${{ steps.choose.outputs.use-runner }}
steps:
- uses: actions/checkout@v4
- id: choose
uses: ./.github/actions/runner-fallback
with:
primary-runner: "self-hosted,ubuntu-latest"
fallback-runner: "ubuntu-latest"
github-token: ${{ secrets.GITHUB_TOKEN }}
docs-and-testcov:
needs: pick-runner
runs-on: ${{ fromJson(needs.pick-runner.outputs.runner) }}
steps:
- uses: actions/checkout@v4
@ -28,10 +43,10 @@ jobs:
with:
toolchain: stable
override: true
- name: Build documentation
run: cargo doc --no-deps --release
- name: Prepare documentation for Pages
run: |
@ -45,28 +60,26 @@ jobs:
run: |
mkdir -p testcov
cargo tarpaulin --engine llvm --out Html --out Json
- name: Check for tarpaulin-report.html
run: |
if [ ! -f tarpaulin-report.html ]; then
echo "tarpaulin-report.html not found!"
exit 1
fi
- name: Export tarpaulin coverage badge JSON
# extract raw coverage and round to 2 decimal places
run: |
# extract raw coverage
coverage=$(jq '.coverage' tarpaulin-report.json)
# round to 2 decimal places
formatted=$(printf "%.2f" "$coverage")
# build the badge JSON using the pre-formatted string
jq --arg message "$formatted" \
'{schemaVersion:1,
label:"tarpaulin-report",
message:$message,
color:"blue"}' \
tarpaulin-report.json \
> tarpaulin-badge.json
coverage=$(jq '.coverage' tarpaulin-report.json)
formatted=$(printf "%.2f" "$coverage")
jq --arg message "$formatted" \
'{schemaVersion:1,
label:"tarpaulin-report",
message:$message,
color:"blue"}' \
tarpaulin-report.json \
> tarpaulin-badge.json
- name: Save last commit date JSON
run: |
@ -78,7 +91,7 @@ jobs:
color:"blue"}' \
<(echo '{}') \
> last-commit-date.json
- name: Copy files to output directory
run: |
mkdir output

View File

@ -11,10 +11,24 @@ concurrency:
cancel-in-progress: true
jobs:
pick-runner:
runs-on: ubuntu-latest
outputs:
runner: ${{ steps.choose.outputs.use-runner }}
steps:
- uses: actions/checkout@v4
- id: choose
uses: ./.github/actions/runner-fallback
with:
primary-runner: "self-hosted,ubuntu-latest"
fallback-runner: "ubuntu-latest"
github-token: ${{ secrets.GITHUB_TOKEN }}
run-unit-tests:
needs: pick-runner
if: github.event.pull_request.draft == false
name: run-unit-tests
runs-on: ubuntu-latest
runs-on: ${{ fromJson(needs.pick-runner.outputs.runner) }}
env:
CARGO_TERM_COLOR: always
@ -24,12 +38,16 @@ jobs:
run: rustup update stable
- name: Install cargo-llvm-cov
uses: taiki-e/install-action@cargo-llvm-cov
- name: Generate code coverage
run: cargo llvm-cov --all-features --workspace --lcov --output-path lcov.info
- name: Run doc-tests
- name: Run doctests
run: cargo test --doc --all-features --workspace --release
- name: Run unit tests with code coverage
run: cargo llvm-cov --all-features --release --workspace --lcov --output-path lcov.info
- name: Test docs generation
run: cargo doc --no-deps --release
- name: Upload coverage to Codecov
uses: codecov/codecov-action@v3
with: