ci #380
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: build targets | |
on: [push, pull_request, workflow_dispatch] | |
jobs: | |
build: | |
strategy: | |
matrix: | |
include: | |
- os: windows-latest | |
configurePreset: msbuild-x64 | |
buildPreset: msbuild-x64-release | |
name: ezQuake-windows-x64 | |
artifact: "ezquake.exe" | |
container: null | |
- os: macos-latest | |
configurePreset: macos-arm64-release-ci | |
buildPreset: macos-arm64-release-ci | |
name: ezQuake-macOS-arm64 | |
artifact: "ezQuake.zip" | |
packages: ["autoconf", "automake", "libtool"] | |
container: null | |
- os: macos-latest | |
configurePreset: macos-x64-release-ci | |
buildPreset: macos-x64-release-ci | |
name: ezQuake-macOS-x64 | |
artifact: "ezQuake.zip" | |
packages: ["autoconf", "automake", "libtool"] | |
container: null | |
- os: ubuntu-latest | |
configurePreset: dynamic | |
buildPreset: dynamic-release | |
name: ezQuake-linux-x86_64 | |
artifact: "ezQuake-x86_64.AppImage" | |
cflags: "-march=nehalem" | |
packages: ["build-essential", "ca-certificates", "cmake", "curl", "file", "git", "libcurl4-openssl-dev", "libexpat1-dev", "libfreetype-dev", "libfuse2", "libjansson-dev", "libjpeg-dev", "libminizip-dev", "libpcre2-dev", "libpng-dev", "libsdl2-2.0-0", "libsdl2-dev", "libsndfile1-dev", "libspeex-dev", "libspeexdsp-dev", "ninja-build", "sudo", "unzip"] | |
container: | |
image: debian:testing | |
options: --privileged | |
name: ${{ matrix.name }} | |
runs-on: ${{ matrix.os }} | |
container: ${{ matrix.container }} | |
steps: | |
- name: Prepare Linux environment | |
run: | | |
apt-get -qq update && apt-get -qq install --no-install-recommends ${{ join(matrix.packages, ' ') }} | |
git config --global --add safe.directory $PWD | |
if: matrix.os == 'ubuntu-latest' | |
- name: Prepare macOS environment | |
run: brew install -q ${{ join(matrix.packages, ' ') }} | |
if: matrix.os == 'macos-latest' | |
- name: Check out code | |
uses: actions/checkout@v4 | |
with: | |
submodules: true | |
fetch-depth: 0 # To get correct revision | |
- name: Fetch upstream tags for version metadata | |
run: | | |
git remote add upstream https://github.com/QW-Group/ezquake-source.git | |
git fetch --tags --no-recurse-submodules upstream | |
if: github.repository != 'QW-Group/ezquake-source' | |
- uses: lukka/get-cmake@latest | |
with: | |
cmakeVersion: "~3.22.0" | |
if: matrix.os != 'ubuntu-latest' | |
- name: Setup vcpkg | |
uses: lukka/run-vcpkg@v11 | |
if: matrix.os != 'ubuntu-latest' # Only used for static builds | |
- name: Run CMake | |
uses: lukka/run-cmake@v10 | |
with: | |
configurePreset: ${{ matrix.configurePreset }} | |
buildPreset: ${{ matrix.buildPreset }} | |
env: | |
CFLAGS: ${{ matrix.cflags }} | |
- name: Generate Linux AppImage | |
run: | | |
export EXECUTABLE=$(echo build-${{ matrix.configurePreset }}/Release/ezquake*) | |
./misc/appimage/appimage-manual_creation.sh | |
mv ezQuake-x86_64.AppImage build-${{ matrix.configurePreset }}/Release/ | |
if: matrix.os == 'ubuntu-latest' | |
- name: Preserve macOS executable bit | |
run: | | |
zip -r -9 ezQuake.zip ezQuake.app | |
working-directory: build-${{ matrix.configurePreset }}/Release | |
if: matrix.os == 'macos-latest' | |
- name: Archive client | |
uses: actions/upload-artifact@v4 | |
with: | |
name: ${{ matrix.name }} | |
path: | | |
build-${{ matrix.configurePreset }}/Release/${{ matrix.artifact }} | |
compression-level: 9 | |
macos-universal: | |
needs: build | |
runs-on: macos-latest | |
steps: | |
- name: Check out code | |
uses: actions/checkout@v4 | |
- name: Download ARM64 Build | |
uses: actions/download-artifact@v4 | |
with: | |
name: ezQuake-macOS-arm64 | |
path: artifacts/arm64 | |
- name: Download Intel Build | |
uses: actions/download-artifact@v4 | |
with: | |
name: ezQuake-macOS-x64 | |
path: artifacts/x64 | |
- name: Create Universal Binary | |
run: | | |
(cd artifacts/x64 && unzip -qq ezQuake.zip) && (cd artifacts/arm64 && unzip -qq ezQuake.zip) | |
cp -r artifacts/arm64/ezQuake.app . | |
lipo -create -output ezQuake.app/Contents/MacOS/ezQuake \ | |
artifacts/x64/ezQuake.app/Contents/MacOS/ezQuake \ | |
artifacts/arm64/ezQuake.app/Contents/MacOS/ezQuake | |
codesign --force --sign - --entitlements dist/macOS/ezquake.entitlements.plist --options runtime --timestamp ezQuake.app | |
zip -r ezQuake-macOS-universal.zip ezQuake.app | |
- name: Delete macOS arch specific builds | |
uses: geekyeggo/delete-artifact@v5 | |
with: | |
name: | | |
ezQuake-macOS-arm64 | |
ezQuake-macOS-x64 | |
- name: Upload Build Artifact | |
uses: actions/upload-artifact@v4 | |
with: | |
name: ezQuake-macOS-universal | |
path: ezQuake-macOS-universal.zip | |
compression-level: 9 | |
upload: | |
needs: [macos-universal] | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
with: | |
path: ezquake | |
submodules: true | |
fetch-depth: 0 # To get correct revision | |
# if: github.event_name == 'release' | |
- name: Get release date | |
run: | | |
RELEASE_DATE=$(git log -1 --format=%cI "${{ github.ref_name }}") | |
echo "RELEASE_DATE=$RELEASE_DATE" >> $GITHUB_ENV | |
working-directory: ezquake | |
# if: github.event_name == 'release' | |
- name: Download Artifacts | |
uses: actions/download-artifact@v4 | |
with: | |
path: artifacts | |
- name: Collect GitHub release artifacts | |
run: | | |
set -x | |
dist_dir="${GITHUB_WORKSPACE}/dist" | |
mkdir "${dist_dir}" | |
# Reset timestamp to time of tag before compression | |
find "artifacts" -type f -exec touch --date="${RELEASE_DATE}" {} + | |
# Recompress before attaching to release, avoiding double-zip of macOS | |
( | |
cd artifacts | |
for target in *; do | |
if ls "${target}"/*.zip &> /dev/null; then | |
cp "${target}"/*.zip "${dist_dir}/${target}.zip" | |
else | |
(cd "${target}"; zip -o -9 "${dist_dir}/${target}.zip" *) | |
fi | |
done; | |
) | |
# Generate source release with submodule, version.json etc | |
( | |
cd "${GITHUB_WORKSPACE}/ezquake" | |
dist/gen-release.sh | |
mv *.tar.gz "${dist_dir}/" | |
) | |
find "${dist_dir}" -type f -execdir sha256sum {} \; > "checksums.txt" | |
mv "checksums.txt" "${dist_dir}/" | |
# Reset timestamp to time of tag for all release artifacts | |
find "${dist_dir}" -type f -exec touch --date="${RELEASE_DATE}" {} + | |
ls -l "${dist_dir}" | |
cat "${dist_dir}/checksums.txt" | |
echo "GITHUB_ARTIFACTS=$dist_dir" >> $GITHUB_ENV | |
# if: github.event_name == 'release' | |
- name: Attach artifacts to GitHub release | |
uses: softprops/action-gh-release@v2 | |
with: | |
files: ${{ env.GITHUB_ARTIFACTS }}/* | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
if: github.event_name == 'release' | |
- name: Prepare Upload Environemnt | |
run: | | |
sudo apt-get -qq update | |
sudo apt-get -qq --no-install-recommends install openssh-client | |
# - name: Setup SSH | |
# run: | | |
# ssh-agent -a $SSH_AUTH_SOCK > /dev/null | |
# ssh-add - <<< "${{ secrets.SSH_PRIVATE_KEY }}" | |
# env: | |
# SSH_AUTH_SOCK: /tmp/ssh_agent.sock | |
- name: Do upload stuff | |
run: | | |
# Build file structure for uploading | |
# snapshots: | |
# upload/snapshots/latest/$os/$arch/$filename | |
# upload/snapshots/$os/$arch/$prefix_$filename | |
# releases: | |
# upload/releases/latest/$os/$arch/$filename | |
# upload/releases/$tag/$os/$arch/$filename | |
set -x | |
upload_dir="${GITHUB_WORKSPACE}/upload" | |
if [[ $GITHUB_REF == refs/tags/* ]]; then | |
main_dir="${upload_dir}/releases/${{ github.ref_name }}" | |
latest_dir="${upload_dir}/releases/latest" | |
prefix="" | |
else | |
main_dir="${upload_dir}/snapshots" | |
latest_dir="${upload_dir}/snapshots/latest" | |
date=$(TZ="Europe/Amsterdam" date "+%Y%m%d-%H%M%S") | |
prefix="${date}_${GITHUB_SHA::7}_" | |
fi | |
#snapshots | |
find artifacts | |
for platform in {linux/x86_64,windows/x64,macOS}; do | |
mkdir -p "${main_dir}/${platform}" | |
mkdir -p "${latest_dir}/${platform}" | |
done | |
for artifact in artifacts/*/*; do | |
IFS='-' read -r ezq os arch <<< "$string" | |
artifact_file=$(basename "${artifact}") | |
artifact_dir=$(dirname "${artifact}") | |
echo $ezq $os $arch $artifact_file $artifact_dir | |
done | |
find ${upload_dir} | |
# | |
# cp .vs/${{ matrix.platform }}/${{ matrix.config }}/Output/ezQuake.exe | |
# upload/snapshots/windows/${{ matrix.platform }}/${{ matrix.config }}/${{ env.DATE }}_${GITHUB_SHA::7}_ezquake.exe | |
# cp .vs/${{ matrix.platform }}/${{ matrix.config }}/Output/ezQuake.md5 | |
# upload/snapshots/windows/${{ matrix.platform }}/${{ matrix.config }}/${{ env.DATE }}_${GITHUB_SHA::7}_ezquake.md5 | |
# cp .vs/${{ matrix.platform }}/${{ matrix.config }}/Output/ezQuake.exe | |
# upload/snapshots/latest/windows/${{ matrix.platform }}/${{ matrix.config }}/ezquake.exe | |
# cp .vs/${{ matrix.platform }}/${{ matrix.config }}/Output/ezQuake.md5 | |
# upload/snapshots/latest/windows/${{ matrix.platform }}/${{ matrix.config }}/ezquake.md5 | |
# | |
# sftp -rp -o 'StrictHostKeyChecking no' -o 'UserKnownHostsFile /dev/null' -P ${{ secrets.SFTP_PORT }} ${{ secrets.SFTP_USERNAME }}@${{ secrets.SFTP_HOST }}:/snapshots <<< $'put -rp upload/snapshots/*' | |
# | |
# cp ezQuake-${{ matrix.platform }}.AppImage upload/snapshots/linux/${{ matrix.platform }}/${{ env.DATE }}_${GITHUB_SHA::7}_ezQuake-${{ matrix.platform }}.AppImage | |
# cp ezQuake-${{ matrix.platform }}.AppImage.md5 upload/snapshots/linux/${{ matrix.platform }}/${{ env.DATE }}_${GITHUB_SHA::7}_ezQuake-${{ matrix.platform }}.AppImage.md5 | |
# cp ezQuake-${{ matrix.platform }}.AppImage upload/snapshots/latest/linux/${{ matrix.platform }}/ezQuake-${{ matrix.platform }}.AppImage | |
# cp ezQuake-${{ matrix.platform }}.AppImage.md5 upload/snapshots/latest/linux/${{ matrix.platform }}/ezQuake-${{ matrix.platform }}.AppImage.md5 | |
# sftp -rp -o 'StrictHostKeyChecking no' -o 'UserKnownHostsFile /dev/null' -P ${{ secrets.SFTP_PORT }} ${{ secrets.SFTP_USERNAME }}@${{ secrets.SFTP_HOST }}:/snapshots <<< $'put -rp upload/snapshots/*' | |
# | |
# #release | |
# cp .vs/${{ matrix.platform }}/${{ matrix.config }}/Output/ezQuake.exe upload/releases/${{ github.ref_name }}/windows/${{ matrix.platform }}/${{ matrix.config }}/ezquake.exe | |
# cp .vs/${{ matrix.platform }}/${{ matrix.config }}/Output/ezQuake.md5 upload/releases/${{ github.ref_name }}/windows/${{ matrix.platform }}/${{ matrix.config }}/ezquake.md5 | |
# cp .vs/${{ matrix.platform }}/${{ matrix.config }}/Output/ezQuake.exe upload/releases/latest/windows/${{ matrix.platform }}/${{ matrix.config }}/ezquake.exe | |
# cp .vs/${{ matrix.platform }}/${{ matrix.config }}/Output/ezQuake.md5 upload/releases/latest/windows/${{ matrix.platform }}/${{ matrix.config }}/ezquake.md5 | |
# sftp -rp -o 'StrictHostKeyChecking no' -o 'UserKnownHostsFile /dev/null' -P ${{ secrets.SFTP_PORT }} ${{ secrets.SFTP_USERNAME }}@${{ secrets.SFTP_HOST }}:/releases <<< $'put -rp upload/releases/*' | |
# | |
# cp ezQuake-${{ matrix.platform }}.AppImage upload/releases/${{ github.ref_name }}/linux/ezQuake-${{ matrix.platform }}.AppImage | |
# cp ezQuake-${{ matrix.platform }}.AppImage.md5 upload/releases/${{ github.ref_name }}/linux/ezQuake-${{ matrix.platform }}.AppImage.md5 | |
# cp ezQuake-${{ matrix.platform }}.AppImage upload/releases/latest/linux/${{ matrix.platform }}/ezQuake-${{ matrix.platform }}.AppImage | |
# cp ezQuake-${{ matrix.platform }}.AppImage.md5 upload/releases/latest/linux/${{ matrix.platform }}/ezQuake-${{ matrix.platform }}.AppImage.md5 | |
# sftp -rp -o 'StrictHostKeyChecking no' -o 'UserKnownHostsFile /dev/null' -P ${{ secrets.SFTP_PORT }} ${{ secrets.SFTP_USERNAME }}@${{ secrets.SFTP_HOST }}:/releases <<< $'put -rp upload/releases/*' | |
# | |
# echo "hello!" | |
# - name: Upload to builds.quakeworld.nu/ktx/snapshots | |
# env: | |
# SSH_AUTH_SOCK: /tmp/ssh_agent.sock | |
# shell: bash | |
# run: | | |
# sftp -rp -o 'StrictHostKeyChecking no' -o 'UserKnownHostsFile /dev/null' -P ${{ secrets.SFTP_PORT }} ${{ secrets.SFTP_USERNAME }}@${{ secrets.SFTP_HOST }}:/snapshots <<< $'put -rp upload/snapshots/*' | |
# if: github.event_name == 'push' | |
# | |
# - name: Upload to builds.quakeworld.nu/ktx/releases | |
# env: | |
# SSH_AUTH_SOCK: /tmp/ssh_agent.sock | |
# shell: bash | |
# run: | | |
# sftp -rp -o 'StrictHostKeyChecking no' -o 'UserKnownHostsFile /dev/null' -P ${{ secrets.SFTP_PORT }} ${{ secrets.SFTP_USERNAME }}@${{ secrets.SFTP_HOST }}:/releases <<< $'put -rp upload/releases/*' | |
# if: github.event_name == 'release' |