Улучшен CI/CD

This commit is contained in:
RoyceDa
2026-03-22 16:08:24 +02:00
parent 329e6d7825
commit b300fa4d03
4 changed files with 80 additions and 125 deletions

View File

@@ -13,6 +13,10 @@ on:
jobs: jobs:
build: build:
runs-on: macos runs-on: macos
strategy:
fail-fast: false
matrix:
arch: [x64, arm64]
steps: steps:
- name: Checkout code - name: Checkout code
uses: actions/checkout@v6 uses: actions/checkout@v6
@@ -31,6 +35,7 @@ jobs:
restore-keys: | restore-keys: |
${{ runner.os }}-npm- ${{ runner.os }}-npm-
if-no-files-found: ignore if-no-files-found: ignore
# Кэш для electron-builder # Кэш для electron-builder
- name: Cache electron-builder - name: Cache electron-builder
uses: actions/cache@v5 uses: actions/cache@v5
@@ -42,32 +47,35 @@ jobs:
restore-keys: | restore-keys: |
${{ runner.os }}-electron-builder- ${{ runner.os }}-electron-builder-
if-no-files-found: ignore if-no-files-found: ignore
- name: NPM offline setup - name: NPM offline setup
shell: bash shell: bash
run: | run: |
npm config set cache "$HOME/.npm-cache" --global npm config set cache "$HOME/.npm-cache" --global
npm config set prefer-offline true --global npm config set prefer-offline true --global
- name: Install npm dependencies - name: Install npm dependencies
run: npm install --prefer-offline --no-audit --no-fund run: npm install --prefer-offline --no-audit --no-fund
- name: Build the application
run: npm run kernel:mac - name: Build the application (${{ matrix.arch }})
#Загружаем на удаленный сервер по SSH используя scp и пароль из секретов
#Загружаем из двух папок dist/builds/darwin/x64 и dist/builds/darwin/arm64, так как electron-builder может создавать разные файлы для разных архитектур
#Вызываем файл sshupload.sh и передаем ему параметры из секретов, чтобы не хранить пароль в открытом виде в workflow
- name: Upload to SSH using scp
shell: bash
run: | run: |
chmod +x "$GITHUB_WORKSPACE/.gitea/workflows/sshupload.sh" npx electron-vite build
sh "$GITHUB_WORKSPACE/.gitea/workflows/sshupload.sh" \ npx electron-builder --mac --${{ matrix.arch }}
-l "$GITHUB_WORKSPACE/dist/builds/darwin/x64/Rosetta-*.pkg" \
-r "${{ secrets.SDU_SSH_KERNEL }}/darwin/x64" \ - name: Check if files exist (${{ matrix.arch }})
-s "${{ secrets.SDU_SSH_HOST }}" \ run: |
-u "${{ secrets.SDU_SSH_USERNAME }}" \ echo "=== Checking dist structure ==="
-p '${{ secrets.SDU_SSH_PASSWORD }}' find dist/builds/darwin/${{ matrix.arch }} -type f -name "*.pkg" 2>/dev/null || echo "No PKG files found"
sh "$GITHUB_WORKSPACE/.gitea/workflows/sshupload.sh" \ ls -la dist/builds/darwin/${{ matrix.arch }}/ 2>/dev/null || echo "arch folder not found"
-l "$GITHUB_WORKSPACE/dist/builds/darwin/arm64/Rosetta-*.pkg" \
-r "${{ secrets.SDU_SSH_KERNEL }}/darwin/arm64" \ - name: Upload ${{ matrix.arch }} to SSH using SCP
-s "${{ secrets.SDU_SSH_HOST }}" \ uses: appleboy/scp-action@master
-u "${{ secrets.SDU_SSH_USERNAME }}" \ with:
-p '${{ secrets.SDU_SSH_PASSWORD }}' host: ${{ secrets.SDU_SSH_HOST }}
username: ${{ secrets.SDU_SSH_USERNAME }}
password: ${{ secrets.SDU_SSH_PASSWORD }}
port: 22
source: "dist/builds/darwin/${{ matrix.arch }}/Rosetta-*.pkg"
target: "${{ secrets.SDU_SSH_KERNEL }}/darwin/${{ matrix.arch }}"
strip_components: 4
rm: true

View File

@@ -12,7 +12,11 @@ on:
jobs: jobs:
build: build:
runs-on: linux runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
arch: [x64, arm64]
steps: steps:
- name: Checkout code - name: Checkout code
uses: actions/checkout@v6 uses: actions/checkout@v6
@@ -49,38 +53,28 @@ jobs:
- name: Install npm dependencies - name: Install npm dependencies
run: npm install --no-audit --no-fund run: npm install --no-audit --no-fund
- name: Build the application - name: Build the application (${{ matrix.arch }})
run: npm run kernel:linux run: |
npx electron-vite build
npx electron-builder --linux --${{ matrix.arch }}
- name: Check if files exist - name: Check if files exist (${{ matrix.arch }})
run: | run: |
echo "=== Checking dist structure ===" echo "=== Checking dist structure ==="
find dist/builds -type f -name "*.AppImage" 2>/dev/null || echo "No AppImage files found" find dist/builds/linux/${{ matrix.arch }} -type f -name "*.AppImage" 2>/dev/null || echo "No AppImage files found"
ls -la dist/builds/linux/ 2>/dev/null || echo "linux folder not found" ls -la dist/builds/linux/${{ matrix.arch }}/ 2>/dev/null || echo "arch folder not found"
- name: Install SCP in Docker container - name: Install SCP in Docker container
run: apt-get install -y openssh-client run: apt-get install -y openssh-client
- name: Upload x64 to SSH using SCP - name: Upload ${{ matrix.arch }} to SSH using SCP
uses: appleboy/scp-action@master uses: appleboy/scp-action@master
with: with:
host: ${{ secrets.SDU_SSH_HOST }} host: ${{ secrets.SDU_SSH_HOST }}
username: ${{ secrets.SDU_SSH_USERNAME }} username: ${{ secrets.SDU_SSH_USERNAME }}
password: ${{ secrets.SDU_SSH_PASSWORD }} password: ${{ secrets.SDU_SSH_PASSWORD }}
port: 22 port: 22
source: "dist/builds/linux/x64/Rosetta-*.AppImage" source: "dist/builds/linux/${{ matrix.arch }}/Rosetta-*.AppImage"
target: "${{ secrets.SDU_SSH_KERNEL }}/linux/x64" target: "${{ secrets.SDU_SSH_KERNEL }}/linux/${{ matrix.arch }}"
strip_components: 4 strip_components: 4
rm: true rm: true
- name: Upload arm64 to SSH using SCP
uses: appleboy/scp-action@master
with:
host: ${{ secrets.SDU_SSH_HOST }}
username: ${{ secrets.SDU_SSH_USERNAME }}
password: ${{ secrets.SDU_SSH_PASSWORD }}
port: 22
source: "dist/builds/linux/arm64/Rosetta-*.AppImage"
target: "${{ secrets.SDU_SSH_KERNEL }}/linux/arm64"
strip_components: 4
rm: true

View File

@@ -11,7 +11,7 @@ on:
jobs: jobs:
build: build:
runs-on: macos runs-on: ubuntu-latest
steps: steps:
- name: Checkout code - name: Checkout code
uses: actions/checkout@v6 uses: actions/checkout@v6
@@ -29,13 +29,13 @@ jobs:
restore-keys: | restore-keys: |
${{ runner.os }}-npm- ${{ runner.os }}-npm-
if-no-files-found: ignore if-no-files-found: ignore
# Кэш для electron-builder (macOS) # Кэш для electron-builder (Linux)
- name: Cache electron-builder (macOS) - name: Cache electron-builder (Linux)
uses: actions/cache@v5 uses: actions/cache@v5
with: with:
path: | path: |
${{ env.HOME }}/Library/Caches/electron-builder ${{ env.HOME }}/.cache/electron-builder
${{ env.HOME }}/Library/Caches/electron ${{ env.HOME }}/.cache/electron
key: ${{ runner.os }}-electron-builder-${{ hashFiles('**/electron-builder.yml') }} key: ${{ runner.os }}-electron-builder-${{ hashFiles('**/electron-builder.yml') }}
restore-keys: | restore-keys: |
${{ runner.os }}-electron-builder- ${{ runner.os }}-electron-builder-
@@ -54,6 +54,11 @@ jobs:
- name: Build the application - name: Build the application
run: npm run kernel:linux run: npm run kernel:linux
- name: Install ZIP in Docker container
run: |
apt-get update
apt-get install -y zip
#Собираем сервисные пакеты для всех платформ #Собираем сервисные пакеты для всех платформ
- name: Build SP - name: Build SP
shell: bash shell: bash
@@ -62,13 +67,28 @@ jobs:
sh "$GITHUB_WORKSPACE/build-packs.sh" sh "$GITHUB_WORKSPACE/build-packs.sh"
#Загружаем на удаленный сервер по SSH используя scp и пароль из секретов #Загружаем на удаленный сервер по SSH используя scp и пароль из секретов
#Загружаем из двух папок dist/builds/darwin/x64 и dist/builds/darwin/arm64, так как electron-builder может создавать разные файлы для разных архитектур #Загружаем из двух папок dist/builds/darwin/x64 и dist/builds/darwin/arm64, так как electron-builder может создавать разные файлы для разных архитектур
- name: Upload to SSH # - name: Upload to SSH
shell: bash # shell: bash
run: | # run: |
chmod +x "$GITHUB_WORKSPACE/.gitea/workflows/sshupload.sh" # chmod +x "$GITHUB_WORKSPACE/.gitea/workflows/sshupload.sh"
sh "$GITHUB_WORKSPACE/.gitea/workflows/sshupload.sh" \ # sh "$GITHUB_WORKSPACE/.gitea/workflows/sshupload.sh" \
-l "$GITHUB_WORKSPACE/packs/*" \ # -l "$GITHUB_WORKSPACE/packs/*" \
-r "${{ secrets.SDU_SSH_PACKS }}" \ # -r "${{ secrets.SDU_SSH_PACKS }}" \
-s "${{ secrets.SDU_SSH_HOST }}" \ # -s "${{ secrets.SDU_SSH_HOST }}" \
-u "${{ secrets.SDU_SSH_USERNAME }}" \ # -u "${{ secrets.SDU_SSH_USERNAME }}" \
-p '${{ secrets.SDU_SSH_PASSWORD }}' # -p '${{ secrets.SDU_SSH_PASSWORD }}'
- name: Install SCP in Docker container
run: apt-get install -y openssh-client
- name: Upload ${{ matrix.arch }} to SSH using SCP
uses: appleboy/scp-action@master
with:
host: ${{ secrets.SDU_SSH_HOST }}
username: ${{ secrets.SDU_SSH_USERNAME }}
password: ${{ secrets.SDU_SSH_PASSWORD }}
port: 22
source: "$GITHUB_WORKSPACE/packs/*"
target: "${{ secrets.SDU_SSH_PACKS }}"
strip_components: 1
rm: true

View File

@@ -1,67 +0,0 @@
#!/usr/bin/env bash
set -euo pipefail
usage() {
cat <<'EOF'
Usage: sshupload.sh -l <local_glob> -r <remote_dir> -s <server> -u <user> -p <password>
EOF
}
local_glob=""
remote_dir=""
server=""
user=""
password=""
while [[ $# -gt 0 ]]; do
case "$1" in
-l|--local) local_glob="$2"; shift 2;;
-r|--remote) remote_dir="$2"; shift 2;;
-s|--server) server="$2"; shift 2;;
-u|--user) user="$2"; shift 2;;
-p|--password) password="$2"; shift 2;;
-h|--help) usage; exit 0;;
*) echo "Unknown arg: $1" >&2; usage; exit 1;;
esac
done
if [[ -z "$local_glob" || -z "$remote_dir" || -z "$server" || -z "$user" || -z "$password" ]]; then
echo "Missing required params" >&2
usage
exit 1
fi
# Ensure sshpass installed
if ! command -v sshpass >/dev/null 2>&1; then
if command -v brew >/dev/null 2>&1; then
brew update
brew install hudochenkov/sshpass/sshpass
elif command -v apt-get >/dev/null 2>&1; then
sudo apt-get update
sudo apt-get install -y sshpass
else
echo "sshpass not found and no supported package manager" >&2
exit 1
fi
fi
user_host="${user}@${server}"
# Ensure remote dir exists and clear it
sshpass -p "$password" ssh -o StrictHostKeyChecking=no "$user_host" "mkdir -p '$remote_dir' && rm -f '$remote_dir'/*"
# Expand glob (supports ~ and patterns) and upload each file (compatible with macOS bash 3.x)
shopt -s nullglob
eval "files=( ${local_glob} )"
shopt -u nullglob
if [[ ${#files[@]} -eq 0 ]]; then
echo "No files matched: $local_glob" >&2
exit 1
fi
for f in "${files[@]}"; do
sshpass -p "$password" scp -o StrictHostKeyChecking=no "$f" "$user_host:$remote_dir/"
done
echo "Upload completed"