luckyworld/.gitea/workflows/unreal-build.yml
Goran Lazarevski 7123cba930
Some checks failed
Unreal Engine Build / build-and-release (push) Failing after 27m6s
Unreal Engine Build / macos-build (push) Failing after 32m32s
Split build to chunks
2025-04-01 15:41:35 +02:00

665 lines
25 KiB
YAML

name: Unreal Engine Build
on:
workflow_dispatch:
push:
branches: [main, develop]
jobs:
build-and-release:
runs-on: windows
if: github.ref == 'refs/heads/main' || github.ref == 'refs/heads/develop'
steps:
- name: Checkout repository
uses: actions/checkout@v3
with:
lfs: true
fetch-depth: 0
- name: Setup environment
run: |
# Set environment variables for Unreal Engine
echo "UE_ROOT=E:/Games/UE_5.5" >> $GITHUB_ENV
# Set environment variables for Linux toolchain
$env:LINUX_MULTIARCH_ROOT="C:/UnrealToolchains/v23_clang-18.1.0-rockylinux8"
echo "LINUX_MULTIARCH_ROOT=${LINUX_MULTIARCH_ROOT}" >> $GITHUB_ENV
# Create directories for builds (with error handling)
if (!(Test-Path "Builds/Windows")) { New-Item -ItemType Directory -Path "Builds/Windows" -Force }
if (!(Test-Path "Builds/Linux")) { New-Item -ItemType Directory -Path "Builds/Linux" -Force }
if (!(Test-Path "PackagedReleases")) { New-Item -ItemType Directory -Path "PackagedReleases" -Force }
- name: Build for Windows
run: |
# Make sure the script exists
if (Test-Path "./win_build.sh") {
# Use bash to run the shell script in Git Bash
& 'C:\Program Files\Git\bin\bash.exe' -c "./win_build.sh"
} else {
echo "Error: win_build.sh not found"
exit 1
}
- name: Build for Linux
run: |
# Make sure the script exists
if (Test-Path "./linux_build.sh") {
# Use bash to run the shell script in Git Bash
& 'C:\Program Files\Git\bin\bash.exe' -c "./linux_build.sh"
} else {
echo "Error: linux_build.sh not found"
exit 1
}
- name: Package builds
run: |
echo "Preparing Windows and Linux builds for release..."
# Create directories for chunks
mkdir -p PackagedReleases/windows-chunks
mkdir -p PackagedReleases/linux-chunks
# Process Windows build
if (Test-Path "Builds/Windows") {
echo "Packaging Windows build with chunking..."
$WIN_CHUNK_DIR="PackagedReleases/windows-chunks"
# Use PowerShell to create archive and split it
# First create a temporary tar file
Push-Location Builds/Windows
# Use 7zip to create the tar file (needs to be installed)
if (!(Get-Command "7z.exe" -ErrorAction SilentlyContinue)) {
echo "Installing 7-Zip..."
choco install 7zip -y
}
echo "Creating archive of Windows build..."
7z a -ttar "../windows-build.tar" *
Pop-Location
# Now split the tar file
echo "Splitting into chunks..."
$chunkSize = 1800MB
$inputFile = "Builds/windows-build.tar"
$outputFile = "$WIN_CHUNK_DIR/LuckyRobots-Windows-part"
$buffer = [byte[]]::new($chunkSize)
$inputStream = [System.IO.File]::OpenRead($inputFile)
$index = 0
while ($true) {
$bytesRead = $inputStream.Read($buffer, 0, $chunkSize)
if ($bytesRead -eq 0) { break }
$outputStream = [System.IO.File]::Create("$outputFile$index")
$outputStream.Write($buffer, 0, $bytesRead)
$outputStream.Close()
$index++
}
$inputStream.Close()
# Clean up the temporary tar file
Remove-Item "Builds/windows-build.tar"
# Create a checksum file for integrity verification
echo "Creating checksums file..."
Get-ChildItem "$WIN_CHUNK_DIR/LuckyRobots-Windows-part*" | ForEach-Object {
$hash = Get-FileHash -Path $_.FullName -Algorithm MD5
"$($hash.Hash) $($_.Name)" | Out-File -FilePath "$WIN_CHUNK_DIR/LuckyRobots-Windows-checksums.md5" -Append
}
# Create download scripts
echo "Creating download scripts..."
# Windows batch script
@"
@echo off
echo LuckyRobots Windows Build Downloader
echo ==================================
echo.
REM Get the release tag from command line or prompt user
set TAG=%1
if "%TAG%"=="" (
echo Enter the release tag (e.g. v1.0.0):
set /p TAG=
)
echo Downloading Windows build parts for %TAG%...
echo.
REM Create directory for downloads
mkdir windows-build 2>nul
cd windows-build
REM Get the list of files to download
curl -s -L -O https://luckyrobots.com/luckyrobots/luckyworld/releases/download/%TAG%/LuckyRobots-Windows-checksums.md5
REM Extract filenames from the checksums file
for /f "tokens=2 delims= " %%f in (LuckyRobots-Windows-checksums.md5) do (
echo Downloading %%f...
curl -L -O https://luckyrobots.com/luckyrobots/luckyworld/releases/download/%TAG%/%%f
)
echo All parts downloaded. Combining...
copy /b LuckyRobots-Windows-part* LuckyRobots-Windows.tar
echo Extracting files...
tar -xf LuckyRobots-Windows.tar
echo Done! Windows build downloaded and extracted.
cd ..
"@ | Out-File -FilePath "PackagedReleases/download-windows-build.bat" -Encoding ASCII
# Copy the checksum file to the main directory
Copy-Item "$WIN_CHUNK_DIR/LuckyRobots-Windows-checksums.md5" -Destination "PackagedReleases/LuckyRobots-Windows-checksums.md5"
# Create a README for Windows
@"
# LuckyRobots Windows Build
This build is split into multiple files due to size limitations.
## Easy Download
For the easiest download experience:
- Download and run download-windows-build.bat
The script will automatically download all needed files, combine them,
and extract the build to a folder called "windows-build".
## Manual Download
If you prefer to download manually:
1. Download all the part files (LuckyRobots-Windows-part*)
2. Combine them:
- Windows: copy /b LuckyRobots-Windows-part* LuckyRobots-Windows.tar
3. Extract the tar file:
- Using tar -xf LuckyRobots-Windows.tar
Enjoy playing!
"@ | Out-File -FilePath "PackagedReleases/README-Windows.txt" -Encoding ASCII
# Create a downloader zip
Compress-Archive -Path "PackagedReleases/README-Windows.txt","PackagedReleases/download-windows-build.bat" -DestinationPath "PackagedReleases/LuckyRobots-Windows-downloader.zip" -Force
echo "Windows build packaged successfully"
} else {
echo "No Windows build directory found"
}
# Process Linux build using Git Bash
if (Test-Path "Builds/Linux") {
echo "Packaging Linux build with chunking..."
& 'C:\Program Files\Git\bin\bash.exe' -c '
LINUX_CHUNK_DIR="PackagedReleases/linux-chunks"
# Create the tar file and split it
echo "Creating archive of Linux build..."
cd Builds/Linux
tar -cf ../../linux-build.tar *
cd ../..
# Split the tar file
echo "Splitting into chunks..."
split -b 1800m linux-build.tar "$LINUX_CHUNK_DIR/LuckyRobots-Linux-part"
# Clean up temporary tar file
rm linux-build.tar
# Create checksums
echo "Creating checksums file..."
cd "$LINUX_CHUNK_DIR"
md5sum LuckyRobots-Linux-part* > LuckyRobots-Linux-checksums.md5
cd ../..
# Copy the checksum file to the main directory
cp "$LINUX_CHUNK_DIR/LuckyRobots-Linux-checksums.md5" "PackagedReleases/LuckyRobots-Linux-checksums.md5"
# Create download scripts
echo "Creating download scripts..."
# Bash script for Linux
cat > "PackagedReleases/download-linux-build.sh" << 'EOLBASH
#!/bin/bash
echo "LuckyRobots Linux Build Downloader"
echo "=================================="
echo
# Get the release tag from command line or prompt user
TAG=$1
if [ -z "$TAG" ]; then
echo "Enter the release tag (e.g. v1.0.0):"
read TAG
fi
echo "Downloading Linux build parts for $TAG..."
echo
# Create directory for downloads
mkdir -p linux-build
cd linux-build
# Get the list of files to download
curl -s -L -O "https://luckyrobots.com/luckyrobots/luckyworld/releases/download/$TAG/LuckyRobots-Linux-checksums.md5"
# Extract filenames from the checksums file
for file in $(awk '{print $2}' LuckyRobots-Linux-checksums.md5); do
echo "Downloading $file..."
curl -L -O "https://luckyrobots.com/luckyrobots/luckyworld/releases/download/$TAG/$file"
done
echo "All parts downloaded. Combining..."
cat LuckyRobots-Linux-part* > LuckyRobots-Linux.tar
echo "Extracting files..."
tar -xf LuckyRobots-Linux.tar
echo "Done! Linux build downloaded and extracted."
cd ..
EOLBASH
# Make the script executable
chmod +x "PackagedReleases/download-linux-build.sh"
# Create README for Linux
cat > "PackagedReleases/README-Linux.txt" << 'EOLREADME
# LuckyRobots Linux Build
This build is split into multiple files due to size limitations.
## Easy Download
For the easiest download experience:
- Download and run download-linux-build.sh (make it executable first with chmod +x)
The script will automatically download all needed files, combine them,
and extract the build to a folder called "linux-build".
## Manual Download
If you prefer to download manually:
1. Download all the part files (LuckyRobots-Linux-part*)
2. Combine them:
- Linux: cat LuckyRobots-Linux-part* > LuckyRobots-Linux.tar
3. Extract the tar file:
- Using tar -xf LuckyRobots-Linux.tar
Enjoy playing!
EOLREADME
# Create a ZIP with the instructions and downloader
zip -j "PackagedReleases/LuckyRobots-Linux-downloader.zip" \
"PackagedReleases/README-Linux.txt" \
"PackagedReleases/download-linux-build.sh"
echo "Linux build packaged successfully"
'
} else {
echo "No Linux build directory found"
}
echo "=== Packaged releases ==="
ls -la PackagedReleases/
- name: Create Tag
if: github.ref == 'refs/heads/main' || github.ref == 'refs/heads/develop'
run: |
# Fetch all tags
git fetch --tags
# Get the latest version tag, if any
LATEST_TAG=$(git tag -l "v[0-9]*.[0-9]*.[0-9]*" | sort -V | tail -n1)
if [ -z "$LATEST_TAG" ]; then
# No previous version tag, start with 1.0.0
NEW_VERSION="1.0.0"
echo "No previous version tags found, starting with 1.0.0"
else
# Strip 'v' prefix if it exists
VERSION=${LATEST_TAG#v}
# Split version into parts
MAJOR=$(echo $VERSION | cut -d. -f1)
MINOR=$(echo $VERSION | cut -d. -f2)
PATCH=$(echo $VERSION | cut -d. -f3)
# Auto-increment patch version
PATCH=$((PATCH + 1))
NEW_VERSION="${MAJOR}.${MINOR}.${PATCH}"
echo "Auto-incremented patch version from ${VERSION} to ${NEW_VERSION}"
fi
# Final tag with v prefix
TAG="v${NEW_VERSION}"
echo "Creating git tag: $TAG"
# Configure git with token authentication
git config --global user.email "actions@gitea.com"
git config --global user.name "Gitea Actions"
# Direct token approach - simplest method
git remote set-url origin "https://goran:${{ secrets.GITEATOKEN }}@luckyrobots.com/luckyrobots/luckyworld.git"
# Set git to not prompt for input
$env:GIT_TERMINAL_PROMPT=0
# Check if tag exists
if ! git rev-parse "$TAG" >/dev/null 2>&1; then
# Create tag without opening editor (-m flag)
git tag -a "$TAG" -m "Release $TAG"
# Push with timeout and debug
echo "Pushing tag $TAG to origin..."
git push --verbose origin "$TAG" || {
echo "Error: Failed to push tag. Check your token permissions."
exit 1
}
echo "Successfully created and pushed tag: $TAG"
else
echo "Tag $TAG already exists, skipping tag creation"
fi
echo "RELEASE_TAG=$TAG" >> $GITHUB_ENV
- name: Create Release
uses: https://gitea.com/actions/gitea-release-action@main
with:
files: |-
PackagedReleases/*.zip
PackagedReleases/*.md5
PackagedReleases/windows-chunks/*
PackagedReleases/linux-chunks/*
token: '${{ secrets.GITEA_TOKEN }}'
title: 'Release ${{ env.RELEASE_TAG }}'
body: |
## Automated release from CI build #${{ github.run_number }}
### Build Instructions
All builds (Windows, Linux, macOS) are split into parts due to size limitations.
**For easy installation:**
1. Download the appropriate downloader ZIP for your platform:
- LuckyRobots-Windows-downloader.zip
- LuckyRobots-Linux-downloader.zip
- LuckyRobots-macOS-downloader.zip
2. Extract and run the download script which will:
- Automatically download all chunks
- Combine them into a single file
- Extract the game files
Built from commit: ${{ github.sha }}
prerelease: ${{ github.ref != 'refs/heads/main' }}
tag_name: '${{ env.RELEASE_TAG }}'
macos-build:
runs-on: macos
if: github.ref == 'refs/heads/main' || github.ref == 'refs/heads/develop'
steps:
- name: Checkout repository
uses: actions/checkout@v3
with:
lfs: true
fetch-depth: 0
- name: Get Release Tag
run: |
# Fetch all tags
git fetch --tags
# Get the latest version tag
LATEST_TAG=$(git tag -l "v[0-9]*.[0-9]*.[0-9]*" | sort -V | tail -n1)
if [ -z "$LATEST_TAG" ]; then
NEW_VERSION="1.0.0"
else
VERSION=${LATEST_TAG#v}
MAJOR=$(echo $VERSION | cut -d. -f1)
MINOR=$(echo $VERSION | cut -d. -f2)
PATCH=$(echo $VERSION | cut -d. -f3)
PATCH=$((PATCH + 1))
NEW_VERSION="${MAJOR}.${MINOR}.${PATCH}"
fi
TAG="v${NEW_VERSION}"
echo "RELEASE_TAG=$TAG" >> $GITHUB_ENV
echo "Using release tag: $TAG"
- name: Setup Unreal Engine
run: |
# Use the correct path where Unreal Engine is installed
UE_PATH="/Users/Shared/Epic Games/UE_5.5"
if [ ! -d "$UE_PATH" ]; then
echo "Error: Unreal Engine is not installed in the expected location"
echo "Please ensure Unreal Engine is installed at $UE_PATH"
exit 1
fi
# Set environment variable with the correct Engine path
echo "UE_ROOT=$UE_PATH/Engine" >> $GITHUB_ENV
echo "Using Unreal Engine 5.5"
- name: Build Unreal Project
run: |
chmod +x ./mac_build.sh
./mac_build.sh
- name: Prepare Mac release with chunking
run: |
echo "Preparing packaged files for release..."
# Create directories for packaging
mkdir -p PackagedReleases/chunks
# Find the app bundle in the Builds directory
APP_PATH=$(find Builds -type d -name "*.app" | head -1)
BUILD_DIR=""
ZIP_BASE_NAME=""
if [ -n "$APP_PATH" ]; then
echo "Found app bundle: $APP_PATH"
BUILD_DIR=$(dirname "$APP_PATH")
APP_NAME=$(basename "$APP_PATH")
ZIP_BASE_NAME="${APP_NAME%.app}-macOS"
else
echo "No .app bundle found, searching for other build directories"
# Look for a directory that might be a build output
MAIN_BUILD_DIR=$(find Builds -mindepth 1 -maxdepth 1 -type d | head -1)
if [ -n "$MAIN_BUILD_DIR" ]; then
echo "Found main build directory: $MAIN_BUILD_DIR"
BUILD_DIR="$MAIN_BUILD_DIR"
DIR_NAME=$(basename "$MAIN_BUILD_DIR")
ZIP_BASE_NAME="${DIR_NAME}-macOS"
else
echo "No build directory found, using entire Builds folder"
BUILD_DIR="Builds"
ZIP_BASE_NAME="LuckyRobots-macOS"
fi
fi
# Create chunks directory if it doesn't exist
CHUNK_DIR="PackagedReleases/chunks"
mkdir -p "$CHUNK_DIR"
echo "Splitting build into 1.8GB chunks..."
if [ -n "$BUILD_DIR" ]; then
# Create a chunked tar archive directly - fixing the previous syntax error
(cd "$BUILD_DIR" && tar -cf - * | split -b 1800m - "$CHUNK_DIR/${ZIP_BASE_NAME}-part")
echo "Created chunked build files"
# Create a checksum file
(cd "$CHUNK_DIR" && md5 ${ZIP_BASE_NAME}-part* > ${ZIP_BASE_NAME}-checksums.md5)
# Create download scripts for different platforms
# Windows batch script
cat > "PackagedReleases/download-mac-build.bat" << 'EOL'
@echo off
echo LuckyRobots macOS Build Downloader
echo ==================================
echo.
REM Get the release tag from command line or prompt user
set TAG=%1
if "%TAG%"=="" (
echo Enter the release tag (e.g. v1.0.0):
set /p TAG=
)
echo Downloading macOS build parts for %TAG%...
echo.
REM Create directory for downloads
mkdir macos-build 2>nul
cd macos-build
REM Get the list of files to download
curl -s -L -O https://luckyrobots.com/luckyrobots/luckyworld/releases/download/%TAG%/LuckyRobots-macOS-checksums.md5
REM Extract filenames from the checksums file
for /f "tokens=2 delims= " %%f in (LuckyRobots-macOS-checksums.md5) do (
echo Downloading %%f...
curl -L -O https://luckyrobots.com/luckyrobots/luckyworld/releases/download/%TAG%/%%f
)
echo All parts downloaded. Combining...
copy /b LuckyRobots-macOS-part* LuckyRobots-macOS.tar
echo Extracting files...
tar -xf LuckyRobots-macOS.tar
echo Done! macOS build downloaded and extracted.
cd ..
EOL
# macOS/Linux bash script
cat > "PackagedReleases/download-mac-build.sh" << 'EOL'
#!/bin/bash
echo "LuckyRobots macOS Build Downloader"
echo "=================================="
echo
# Get the release tag from command line or prompt user
TAG=$1
if [ -z "$TAG" ]; then
echo "Enter the release tag (e.g. v1.0.0):"
read TAG
fi
echo "Downloading macOS build parts for $TAG..."
echo
# Create directory for downloads
mkdir -p macos-build
cd macos-build
# Get the list of files to download
curl -s -L -O "https://luckyrobots.com/luckyrobots/luckyworld/releases/download/$TAG/LuckyRobots-macOS-checksums.md5"
# Extract filenames from the checksums file
for file in $(awk '{print $2}' LuckyRobots-macOS-checksums.md5); do
echo "Downloading $file..."
curl -L -O "https://luckyrobots.com/luckyrobots/luckyworld/releases/download/$TAG/$file"
done
echo "All parts downloaded. Combining..."
cat LuckyRobots-macOS-part* > LuckyRobots-macOS.tar
echo "Extracting files..."
tar -xf LuckyRobots-macOS.tar
echo "Done! macOS build downloaded and extracted."
cd ..
EOL
# Make the shell script executable
chmod +x "PackagedReleases/download-mac-build.sh"
# Create a simple README
cat > "PackagedReleases/README-macOS.txt" << 'EOL'
# LuckyRobots macOS Build
This build is split into multiple files due to size limitations.
## Easy Download
For the easiest download experience:
- Windows: Download and run download-mac-build.bat
- macOS/Linux: Download and run download-mac-build.sh
Both scripts will automatically download all needed files, combine them,
and extract the build to a folder called "macos-build".
## Manual Download
If you prefer to download manually:
1. Download all the part files (LuckyRobots-macOS-part*)
2. Combine them:
- Windows: copy /b LuckyRobots-macOS-part* LuckyRobots-macOS.tar
- macOS/Linux: cat LuckyRobots-macOS-part* > LuckyRobots-macOS.tar
3. Extract the tar file:
- Using tar -xf LuckyRobots-macOS.tar
Enjoy playing!
EOL
# Zip the instructions and scripts for easy download
zip -j "PackagedReleases/LuckyRobots-macOS-downloader.zip" \
"PackagedReleases/README-macOS.txt" \
"PackagedReleases/download-mac-build.bat" \
"PackagedReleases/download-mac-build.sh"
# Also copy the checksum file up one level for the downloader
cp "$CHUNK_DIR/${ZIP_BASE_NAME}-checksums.md5" "PackagedReleases/${ZIP_BASE_NAME}-checksums.md5"
# List the files
echo "Created files:"
ls -la "$CHUNK_DIR"
echo "Created downloader package:"
ls -la "PackagedReleases"
else
echo "Error: Could not find any build directory to package"
exit 1
fi
- name: Create Gitea Release
if: github.ref == 'refs/heads/main' || github.ref == 'refs/heads/develop'
uses: https://gitea.com/actions/gitea-release-action@main
with:
token: ${{ secrets.GITEATOKEN }}
tag_name: ${{ env.RELEASE_TAG }}
title: "Release ${{ env.RELEASE_TAG }}"
body: |
## Automated release from CI build #${{ github.run_number }}
### macOS Build Instructions
**Quick setup:** Download the LuckyRobots-macOS-downloader.zip file first!
This contains scripts that will automatically download and extract all parts.
For manual setup:
1. Download all part files
2. Combine them using: `cat LuckyRobots-macOS-part* > LuckyRobots-macOS.tar`
3. Extract with: `tar -xf LuckyRobots-macOS.tar`
Built from commit: ${{ github.sha }}
files: |-
PackagedReleases/*.zip
PackagedReleases/*.md5
PackagedReleases/chunks/*