mirror of
https://github.com/RetroDECK/RetroDECK.git
synced 2024-11-22 05:55:38 +00:00
Merge pull request #770 from Libretto7/feat/build-dependencies
Add build dependencies for more distros
This commit is contained in:
commit
df29896100
|
@ -1,6 +1,31 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
# This scritp is installing the required dependencies to correctly run the pipeline and buold the flatpak
|
# This script is installing the required dependencies to correctly run the pipeline and build the flatpak
|
||||||
|
|
||||||
|
unset pkg_mgr
|
||||||
|
|
||||||
|
# rpm-ostree must be checked before dnf because a dnf (wrapper) command also works on rpm-ostree distros (not what we want)
|
||||||
|
for potential_pkg_mgr in apt pacman rpm-ostree dnf; do
|
||||||
|
command -v "$potential_pkg_mgr" &> /dev/null && pkg_mgr="$potential_pkg_mgr" && break
|
||||||
|
done
|
||||||
|
|
||||||
|
case "$pkg_mgr" in
|
||||||
|
apt)
|
||||||
sudo apt install -y flatpak flatpak-builder p7zip-full xmlstarlet bzip2 curl jq
|
sudo apt install -y flatpak flatpak-builder p7zip-full xmlstarlet bzip2 curl jq
|
||||||
|
;;
|
||||||
|
pacman)
|
||||||
|
sudo pacman -S --noconfirm flatpak flatpak-builder p7zip xmlstarlet bzip2
|
||||||
|
;;
|
||||||
|
rpm-ostree)
|
||||||
|
echo "When using a distro with rpm-ostree, you shouldn't build directly on the host. Try using a distrobox."
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
dnf)
|
||||||
|
sudo dnf install -y flatpak flatpak-builder p7zip p7zip-plugins xmlstarlet bzip2 curl
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "Package manager $pkg_mgr not supported. Please open an issue."
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
flatpak remote-add --user --if-not-exists flathub https://flathub.org/repo/flathub.flatpakrepo
|
flatpak remote-add --user --if-not-exists flathub https://flathub.org/repo/flathub.flatpakrepo
|
||||||
flatpak remote-add --user --if-not-exists flathub-beta https://flathub.org/beta-repo/flathub-beta.flatpakrepo
|
flatpak remote-add --user --if-not-exists flathub-beta https://flathub.org/beta-repo/flathub-beta.flatpakrepo
|
|
@ -2,9 +2,6 @@
|
||||||
|
|
||||||
# WARNING: run this script from the project root folder, not from here!!
|
# WARNING: run this script from the project root folder, not from here!!
|
||||||
|
|
||||||
# TODO: FEDORA
|
|
||||||
# sudo dnf install -y flatpak flatpak-builder p7zip p7zip-plugins xmlstarlet bzip2 curl
|
|
||||||
|
|
||||||
git submodule update --init --recursive
|
git submodule update --init --recursive
|
||||||
|
|
||||||
export GITHUB_WORKSPACE="."
|
export GITHUB_WORKSPACE="."
|
||||||
|
|
156
old/removed-workflows/cooker-selfhosted.yml
Normal file
156
old/removed-workflows/cooker-selfhosted.yml
Normal file
|
@ -0,0 +1,156 @@
|
||||||
|
name: "Build cooker"
|
||||||
|
|
||||||
|
on:
|
||||||
|
# push:
|
||||||
|
# branches:
|
||||||
|
# - cooker*
|
||||||
|
# - feat*
|
||||||
|
# paths:
|
||||||
|
# - '.github/workflows/**'
|
||||||
|
# - 'automation_tools/**'
|
||||||
|
# - 'emu-configs/**'
|
||||||
|
# - 'es-configs/**'
|
||||||
|
# - 'functions/**'
|
||||||
|
# - 'rd-submodules/**'
|
||||||
|
# - '*.sh'
|
||||||
|
# - 'net.retrodeck.retrodeck.yml'
|
||||||
|
# - 'net.retrodeck.retrodeck.appdata.xml'
|
||||||
|
# pull_request:
|
||||||
|
# branches:
|
||||||
|
# - cooker*
|
||||||
|
|
||||||
|
# Italy (CET): 11:00 PM
|
||||||
|
# Japan (JST): 7:00 AM
|
||||||
|
schedule:
|
||||||
|
- cron: '0 22 * * *'
|
||||||
|
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
|
||||||
|
Building_RetroDECK:
|
||||||
|
runs-on: self-hosted
|
||||||
|
steps:
|
||||||
|
|
||||||
|
# Circumventing this bug: https://github.com/flatpak/flatpak-builder/issues/317
|
||||||
|
- name: Remove stuck mounts
|
||||||
|
run: sudo umount -f /home/ubuntu/actions-runner/_work/RetroDECK/RetroDECK/.flatpak-builder/rofiles/*
|
||||||
|
continue-on-error: true
|
||||||
|
|
||||||
|
- name: Clone RetroDECK repo
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
submodules: 'true'
|
||||||
|
|
||||||
|
- name: "Install dependencies"
|
||||||
|
run: "automation_tools/install_dependencies.sh"
|
||||||
|
|
||||||
|
- name: Generate cooker build ID
|
||||||
|
run: "/bin/bash ${GITHUB_WORKSPACE}/automation_tools/cooker_build_id.sh"
|
||||||
|
|
||||||
|
# backing up manifest in case download fails and hashes must be recalculated
|
||||||
|
- name: Manifest backup
|
||||||
|
run: "cp ${GITHUB_WORKSPACE}/net.retrodeck.retrodeck.yml ${GITHUB_WORKSPACE}/net.retrodeck.retrodeck.yml.bak"
|
||||||
|
|
||||||
|
- name: Run pre-build automation tasks
|
||||||
|
run : "/bin/bash ${GITHUB_WORKSPACE}/automation_tools/pre_build_automation.sh"
|
||||||
|
|
||||||
|
- name: "Adding flatpak portal for automated updates (cooker only)"
|
||||||
|
run: "/bin/bash ${GITHUB_WORKSPACE}/automation_tools/cooker_flatpak_portal_add.sh"
|
||||||
|
|
||||||
|
- name: "Updating release notes in appdata"
|
||||||
|
run: "automation_tools/appdata_management.sh"
|
||||||
|
|
||||||
|
- name: "[DEBUG] Outputting manifest"
|
||||||
|
run: cat net.retrodeck.retrodeck.yml
|
||||||
|
|
||||||
|
- name: "Build flatpak: download only"
|
||||||
|
id: "flatpak-download"
|
||||||
|
run: "/bin/bash ${GITHUB_WORKSPACE}/automation_tools/flatpak_build_download_only.sh"
|
||||||
|
continue-on-error: true
|
||||||
|
|
||||||
|
# Sometimes flatpak download fails, in this case it tries a second time
|
||||||
|
- name: "Build flatpak: download only (retry)"
|
||||||
|
if: steps.flatpak-download.outcome == 'failure'
|
||||||
|
run: |
|
||||||
|
echo "Download failed, maybe some hash changed since the build start."
|
||||||
|
echo "Recalculating hashes and retrying download..."
|
||||||
|
rm -f "{GITHUB_WORKSPACE}/net.retrodeck.retrodeck.yml"
|
||||||
|
cp "${GITHUB_WORKSPACE}/net.retrodeck.retrodeck.yml.bak" "${GITHUB_WORKSPACE}/net.retrodeck.retrodeck.yml"
|
||||||
|
"${GITHUB_WORKSPACE}/automation_tools/pre_build_automation.sh"
|
||||||
|
"${GITHUB_WORKSPACE}/automation_tools/flatpak_build_download_only.sh"
|
||||||
|
|
||||||
|
- name: Build flatpak
|
||||||
|
run: "/bin/bash ${GITHUB_WORKSPACE}/automation_tools/flatpak_build_only.sh"
|
||||||
|
|
||||||
|
- name: Create Artifact for flathub
|
||||||
|
run: |
|
||||||
|
tar -czf ${GITHUB_WORKSPACE}/RetroDECK-Artifact-cooker.tar.gz -C ${GITHUB_WORKSPACE}/retrodeck-flatpak-cooker .
|
||||||
|
hash=($(sha256sum ${GITHUB_WORKSPACE}/RetroDECK-Artifact-cooker.tar.gz))
|
||||||
|
echo $hash > ${GITHUB_WORKSPACE}/RetroDECK-Artifact-cooker.sha
|
||||||
|
mv -f RetroDECK-Artifact-cooker.* ${{ secrets.ARTIFACT_REPO }}
|
||||||
|
continue-on-error: true
|
||||||
|
|
||||||
|
- name: Create Bundle
|
||||||
|
run: "/bin/bash ${GITHUB_WORKSPACE}/automation_tools/flatpak_build_bundle.sh"
|
||||||
|
|
||||||
|
- name: Set environment variable with current branch name
|
||||||
|
run: echo "GITHUB_REF_SLUG=$(git rev-parse --abbrev-ref HEAD)" >> $GITHUB_ENV
|
||||||
|
|
||||||
|
- name: Get commits since last release
|
||||||
|
run: |
|
||||||
|
# Get the latest release tag
|
||||||
|
LATEST_TAG=$(git describe --tags --abbrev=0)
|
||||||
|
# Get all commits since the latest release tag
|
||||||
|
COMMITS=$(git log $LATEST_TAG..HEAD --pretty=format:"- %s")
|
||||||
|
# Set the output variable
|
||||||
|
echo "::set-output name=commits::$COMMITS"
|
||||||
|
id: commits
|
||||||
|
continue-on-error: true
|
||||||
|
|
||||||
|
- name: Get branch name
|
||||||
|
id: branch_name
|
||||||
|
run: echo "BRANCH_NAME=$(echo $GITHUB_REF | sed 's|refs/heads/||')" >> $GITHUB_ENV
|
||||||
|
|
||||||
|
# if it's a feature branch it will not marked as "latest" cooker version
|
||||||
|
- name: "Set makeLatest (cooker only)"
|
||||||
|
run: |
|
||||||
|
if [[ "$BRANCH_NAME" == 'feat/'* ]]; then
|
||||||
|
echo "MAKE_LATEST=false" >> $GITHUB_ENV
|
||||||
|
else
|
||||||
|
echo "MAKE_LATEST=true" >> $GITHUB_ENV
|
||||||
|
fi
|
||||||
|
|
||||||
|
- name: Publish the flatpak in a new cooker release
|
||||||
|
uses: ncipollo/release-action@v1
|
||||||
|
with:
|
||||||
|
tag: "${{env.BRANCH_NAME}}-${{ env.buildid }}"
|
||||||
|
body: |
|
||||||
|
# Release Notes (Cooker)
|
||||||
|
This is a cooker snapshot based on the commit: ${{ github.event.repository.full_name }}@${{github.sha}}.
|
||||||
|
On branch [${{env.BRANCH_NAME}}](https://github.com/XargonWan/RetroDECK/tree/${{env.BRANCH_NAME}}).
|
||||||
|
|
||||||
|
## Commits since last release
|
||||||
|
${{ steps.commits.outputs.commits }}
|
||||||
|
|
||||||
|
For the full release note for this build please refer to the channel [#BETA-TESTING](https://discord.gg/qQcrFvaA2C) on our Discord server.
|
||||||
|
|
||||||
|
Cooker channel is provided for the community to test fixes and explore new functionality.
|
||||||
|
Please DO NOT open issues or ask support on this build.
|
||||||
|
|
||||||
|
artifacts: "RetroDECK-cooker.flatpak,RetroDECK-Artifact.tar.gz"
|
||||||
|
allowUpdates: true
|
||||||
|
makeLatest: ${{env.MAKE_LATEST}} # if it's a feat branch is not considered the latest build
|
||||||
|
token: ${{ secrets.TRIGGER_BUILD_TOKEN }}
|
||||||
|
repo: RetroDECK-cooker
|
||||||
|
continue-on-error: true
|
||||||
|
|
||||||
|
# In case it cannot publish the release at least it's providing the flatpak file for creating a manual release
|
||||||
|
- name: Upload RetroDECK-cooker.flatpak
|
||||||
|
uses: actions/upload-artifact@v3
|
||||||
|
with:
|
||||||
|
name: retrodeck-flatpak
|
||||||
|
path: RetroDECK-cooker.flatpak
|
||||||
|
continue-on-error: true
|
||||||
|
|
Loading…
Reference in a new issue