forked from herocode/horus
Update .gitea/workflows/release.yml
This commit is contained in:
@@ -7,48 +7,42 @@ on:
|
|||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build-release:
|
build-release:
|
||||||
name: Build Release Binaries
|
name: Build Release Binaries via hero-git installer
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
env:
|
env:
|
||||||
# Make sure warnings never fail the release build
|
IMAGE_NAME: hero-git:latest
|
||||||
RUSTFLAGS: "--cap-lints=warn"
|
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout code
|
- name: Checkout code
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Setup Rust toolchain
|
|
||||||
uses: actions-rust-lang/setup-rust-toolchain@v1
|
|
||||||
with:
|
|
||||||
toolchain: stable
|
|
||||||
|
|
||||||
- name: Debug TOKEN_GITEA is set
|
|
||||||
run: |
|
|
||||||
if [ -z "$TOKEN_GITEA" ]; then
|
|
||||||
echo "ERROR: TOKEN_GITEA is EMPTY"
|
|
||||||
exit 1
|
|
||||||
else
|
|
||||||
echo "TOKEN_GITEA is set (length: ${#TOKEN_GITEA})"
|
|
||||||
fi
|
|
||||||
env:
|
|
||||||
TOKEN_GITEA: ${{ secrets.TOKEN_GITEA }}
|
|
||||||
|
|
||||||
- name: Extract version from tag
|
- name: Extract version from tag
|
||||||
id: version
|
id: version
|
||||||
run: echo "VERSION=${GITHUB_REF#refs/tags/}" >> "$GITHUB_OUTPUT"
|
run: echo "VERSION=${GITHUB_REF#refs/tags/}" >> "$GITHUB_OUTPUT"
|
||||||
|
|
||||||
- name: Build release binaries
|
- name: Ensure hero-git image exists
|
||||||
run: cargo build --workspace --release --verbose
|
|
||||||
|
|
||||||
- name: Strip binaries
|
|
||||||
run: |
|
run: |
|
||||||
strip target/release/supervisor || true
|
if ! docker image inspect "$IMAGE_NAME" >/dev/null 2>&1; then
|
||||||
strip target/release/coordinator || true
|
echo "ERROR: Docker image '$IMAGE_NAME' not found on runner."
|
||||||
strip target/release/horus || true
|
echo "Build it manually on the runner with:"
|
||||||
strip target/release/osiris || true
|
echo " docker build -t hero-git:latest -f Dockerfile ."
|
||||||
strip target/release/herorunner || true
|
exit 1
|
||||||
strip target/release/runner_osiris || true
|
fi
|
||||||
strip target/release/runner_sal || true
|
|
||||||
|
- name: Prepare bin output dir
|
||||||
|
run: mkdir -p hero-bin
|
||||||
|
|
||||||
|
- name: Run horus_full_install installer in container
|
||||||
|
run: |
|
||||||
|
docker run --rm \
|
||||||
|
-v "$PWD/hero-bin:/root/hero/bin" \
|
||||||
|
-e HEROLIB_REF=development_nile_installers \
|
||||||
|
"$IMAGE_NAME" \
|
||||||
|
bash -lc "cd /opt/herolib && ./examples/installers/horus/horus_full_install.vsh"
|
||||||
|
|
||||||
|
- name: List built binaries
|
||||||
|
run: ls -al hero-bin
|
||||||
|
|
||||||
- name: Create release directory
|
- name: Create release directory
|
||||||
run: mkdir -p release-artifacts
|
run: mkdir -p release-artifacts
|
||||||
@@ -56,9 +50,9 @@ jobs:
|
|||||||
- name: Package binaries
|
- name: Package binaries
|
||||||
run: |
|
run: |
|
||||||
for binary in supervisor coordinator horus osiris herorunner runner_osiris runner_sal; do
|
for binary in supervisor coordinator horus osiris herorunner runner_osiris runner_sal; do
|
||||||
if [ -f "target/release/$binary" ]; then
|
if [ -f "hero-bin/$binary" ]; then
|
||||||
tar -czf "release-artifacts/${binary}-${{ steps.version.outputs.VERSION }}-linux-x86_64.tar.gz" \
|
tar -czf "release-artifacts/${binary}-${{ steps.version.outputs.VERSION }}-linux-x86_64.tar.gz" \
|
||||||
-C target/release "$binary"
|
-C hero-bin "$binary"
|
||||||
echo "Packaged $binary"
|
echo "Packaged $binary"
|
||||||
else
|
else
|
||||||
echo "Warning: $binary not found, skipping"
|
echo "Warning: $binary not found, skipping"
|
||||||
@@ -73,42 +67,36 @@ jobs:
|
|||||||
|
|
||||||
- name: Create Release
|
- name: Create Release
|
||||||
uses: akkuman/gitea-release-action@v1
|
uses: akkuman/gitea-release-action@v1
|
||||||
# or actions/gitea-release-action@v1
|
|
||||||
with:
|
with:
|
||||||
files: release-artifacts/*
|
files: release-artifacts/*
|
||||||
token: ${{ secrets.TOKEN_GITEA }} # make sure this PAT exists in Gitea
|
token: ${{ secrets.TOKEN_GITEA }}
|
||||||
tag_name: ${{ steps.version.outputs.VERSION }}
|
tag_name: ${{ steps.version.outputs.VERSION }}
|
||||||
name: Release ${{ steps.version.outputs.VERSION }}
|
name: Release ${{ steps.version.outputs.VERSION }}
|
||||||
body: |
|
body: |
|
||||||
## Horus Release ${{ steps.version.outputs.VERSION }}
|
## Horus Release ${{ steps.version.outputs.VERSION }}
|
||||||
|
|
||||||
### Binaries
|
### Binaries
|
||||||
This release includes the following binaries for Linux x86_64:
|
Built via the herolib V installer (`horus_full_install.vsh`) inside
|
||||||
- `supervisor` - Hero Supervisor service
|
the `hero-git:latest` image and packaged for Linux x86_64:
|
||||||
- `coordinator` - Hero Coordinator service
|
- `supervisor`
|
||||||
- `horus` - Horus main binary
|
- `coordinator`
|
||||||
- `osiris` - Osiris server
|
- `horus`
|
||||||
- `herorunner` - Hero runner
|
- `osiris`
|
||||||
- `runner_osiris` - Osiris runner
|
- `herorunner`
|
||||||
- `runner_sal` - SAL runner
|
- `runner_osiris`
|
||||||
|
- `runner_sal`
|
||||||
|
|
||||||
### Installation
|
### Installation (example)
|
||||||
Download the appropriate binary for your system:
|
|
||||||
```bash
|
```bash
|
||||||
# Example: Download and install supervisor
|
wget https://git.ourworld.tf/herocode/horus/releases/download/${{ steps.version.outputs.VERSION }}/supervisor-${{ steps.version.outputs.VERSION }}-linux-x86_64.tar.gz
|
||||||
wget https://git.ourworld.tf/peternashaat/horus/releases/download/${{ steps.version.outputs.VERSION }}/supervisor-${{ steps.version.outputs.VERSION }}-linux-x86_64.tar.gz
|
|
||||||
tar -xzf supervisor-${{ steps.version.outputs.VERSION }}-linux-x86_64.tar.gz
|
tar -xzf supervisor-${{ steps.version.outputs.VERSION }}-linux-x86_64.tar.gz
|
||||||
chmod +x supervisor
|
chmod +x supervisor
|
||||||
sudo mv supervisor /usr/local/bin/
|
sudo mv supervisor /usr/local/bin/
|
||||||
```
|
```
|
||||||
|
|
||||||
### Verification
|
### Verification
|
||||||
Verify the integrity of downloaded files using the checksums:
|
|
||||||
```bash
|
```bash
|
||||||
sha256sum -c checksums.txt
|
sha256sum -c checksums.txt
|
||||||
```
|
```
|
||||||
|
|
||||||
### Changes
|
|
||||||
See commit history for detailed changes in this release.
|
|
||||||
draft: false
|
draft: false
|
||||||
prerelease: false
|
prerelease: false
|
||||||
|
|||||||
Reference in New Issue
Block a user