mirror of
https://github.com/KenanZhu/AutoLibrary.git
synced 2026-06-17 23:13:03 +08:00
59c06b3a19
Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
222 lines
7.7 KiB
YAML
222 lines
7.7 KiB
YAML
name: Build Test
|
|
|
|
# This workflow builds the application for testing purposes.
|
|
# It is triggered when a pull request is opened, synchronized, or reopened against the main branch.
|
|
|
|
on:
|
|
pull_request:
|
|
branches:
|
|
- main
|
|
types:
|
|
- opened
|
|
- synchronize
|
|
- reopened
|
|
workflow_dispatch:
|
|
|
|
#
|
|
# Build Windows
|
|
#
|
|
|
|
jobs:
|
|
build-windows:
|
|
runs-on: windows-latest
|
|
steps:
|
|
- name: Checkout code
|
|
uses: actions/checkout@v6
|
|
with:
|
|
ref: ${{ github.ref }}
|
|
|
|
- name: Get version info
|
|
id: get_version
|
|
run: |
|
|
$version = "pr-test"
|
|
$tagName = "pr-test"
|
|
|
|
Write-Host "✓ Mode: Pull Request Test Build"
|
|
Write-Host "✓ Tag: $tagName"
|
|
Write-Host "✓ Version: $version"
|
|
|
|
"VERSION=$version" | Out-File -FilePath $env:GITHUB_OUTPUT -Encoding utf8 -Append
|
|
"TAG_NAME=$tagName" | Out-File -FilePath $env:GITHUB_OUTPUT -Encoding utf8 -Append
|
|
shell: pwsh
|
|
|
|
- name: Set up Python
|
|
uses: actions/setup-python@v6
|
|
with:
|
|
python-version: '3.13'
|
|
cache: 'pip'
|
|
cache-dependency-path: requirement.txt
|
|
|
|
- name: Install dependencies
|
|
run: |
|
|
python -m pip install --upgrade pip
|
|
pip install -r requirement.txt
|
|
|
|
- name: Solve ddddocr compatibility and copy model files
|
|
run: |
|
|
$ddddocrPath = python -c "import ddddocr, os; print(os.path.dirname(ddddocr.__file__))"
|
|
Write-Host "ddddocr package location: $ddddocrPath"
|
|
|
|
$initFile = Join-Path $ddddocrPath "__init__.py"
|
|
if (Test-Path $initFile) {
|
|
Write-Host "Fixing ddddocr compatibility in: $initFile"
|
|
(Get-Content $initFile) -replace 'Image\.ANTIALIAS', 'Image.Resampling.LANCZOS' | Set-Content $initFile
|
|
Write-Host "✓ Fixed: Image.ANTIALIAS -> Image.Resampling.LANCZOS"
|
|
} else {
|
|
Write-Error "✗ ddddocr __init__.py not found"
|
|
exit 1
|
|
}
|
|
|
|
if (-not (Test-Path "models")) {
|
|
New-Item -ItemType Directory -Path "models" | Out-Null
|
|
Write-Host "✓ Created models directory"
|
|
}
|
|
|
|
$onnxSource = Join-Path $ddddocrPath "common.onnx"
|
|
$onnxDest = "models/common.onnx"
|
|
if (Test-Path $onnxSource) {
|
|
Copy-Item $onnxSource $onnxDest -Force
|
|
Write-Host "✓ Copied ONNX model from: $onnxSource"
|
|
Write-Host "✓ ONNX model copied to: $onnxDest"
|
|
} else {
|
|
Write-Error "✗ ONNX model not found in ddddocr package: $onnxSource"
|
|
exit 1
|
|
}
|
|
|
|
if (Test-Path $onnxDest) {
|
|
$fileSize = (Get-Item $onnxDest).Length / 1MB
|
|
Write-Host "✓ Model file verified: $onnxDest (Size: $([math]::Round($fileSize, 2)) MB)"
|
|
} else {
|
|
Write-Error "✗ Failed to copy model file"
|
|
exit 1
|
|
}
|
|
shell: pwsh
|
|
|
|
- name: Compile Qt Resource files
|
|
run: |
|
|
cd batchs
|
|
./compile_rc.bat
|
|
shell: cmd
|
|
|
|
- name: Compile Qt UI files
|
|
run: |
|
|
cd batchs
|
|
./compile_ui.bat
|
|
shell: cmd
|
|
|
|
- name: Generate 'Main.spec'
|
|
run: |
|
|
$version = "${{ steps.get_version.outputs.VERSION }}"
|
|
$exeName = "AutoLibrary-$version"
|
|
|
|
Write-Host "Generating Main.spec for version: $version"
|
|
Write-Host "Executable name: $exeName"
|
|
|
|
$specLines = @(
|
|
"# -*- mode: python ; coding: utf-8 -*-"
|
|
""
|
|
""
|
|
"a = Analysis("
|
|
" ['src\\Main.py'],"
|
|
" pathex=[],"
|
|
" binaries=[],"
|
|
" datas=["
|
|
" ('models\\common.onnx', 'ddddocr'),"
|
|
" ('src\\gui\\resources\\icons\\AutoLibrary_Logo_64.ico', 'gui\\resources\\icons'),"
|
|
" ],"
|
|
" hiddenimports=[],"
|
|
" hookspath=[],"
|
|
" hooksconfig={},"
|
|
" runtime_hooks=[],"
|
|
" excludes=[],"
|
|
" noarchive=False,"
|
|
" optimize=0,"
|
|
")"
|
|
"pyz = PYZ(a.pure)"
|
|
""
|
|
"exe = EXE("
|
|
" pyz,"
|
|
" a.scripts,"
|
|
" name='AutoLibrary',"
|
|
" debug=False,"
|
|
" bootloader_ignore_signals=False,"
|
|
" strip=False,"
|
|
" upx=True,"
|
|
" upx_exclude=[],"
|
|
" runtime_tmpdir=None,"
|
|
" console=False,"
|
|
" disable_windowed_traceback=False,"
|
|
" argv_emulation=False,"
|
|
" target_arch=None,"
|
|
" codesign_identity=None,"
|
|
" entitlements_file=None,"
|
|
" icon=['src\\gui\\resources\\icons\\AutoLibrary_Logo_64.ico'],"
|
|
")"
|
|
""
|
|
"coll = COLLECT("
|
|
" exe,"
|
|
" a.binaries,"
|
|
" a.datas,"
|
|
" strip=False,"
|
|
" upx=True,"
|
|
" upx_exclude=[],"
|
|
" name='$exeName'"
|
|
")"
|
|
)
|
|
$specLines | Out-File -FilePath "Main.spec" -Encoding UTF8
|
|
|
|
Write-Host "✓ Main.spec (non-single file) generated successfully"
|
|
Write-Host "`n========================================"
|
|
Write-Host "Generated Main.spec"
|
|
Write-Host "========================================"
|
|
Get-Content "Main.spec" | Write-Host
|
|
Write-Host "========================================`n"
|
|
shell: pwsh
|
|
|
|
- name: Build with PyInstaller
|
|
run: |
|
|
pyinstaller Main.spec
|
|
|
|
- name: Zip windows release
|
|
id: zip_release
|
|
run: |
|
|
$tagName = "${{ steps.get_version.outputs.TAG_NAME }}"
|
|
$version = "${{ steps.get_version.outputs.VERSION }}"
|
|
$distDir = "dist/AutoLibrary-$version"
|
|
$zipName = "AutoLibrary.$tagName-windows-x86_64.zip"
|
|
|
|
"ZIP_NAME=$zipName" | Out-File -FilePath $env:GITHUB_OUTPUT -Encoding utf8 -Append
|
|
|
|
Write-Host "Looking for distribution directory: $distDir"
|
|
if (Test-Path $distDir) {
|
|
Compress-Archive -Path "$distDir/*" -DestinationPath $zipName
|
|
Write-Host "✓ Created release archive (directory mode): $zipName"
|
|
} else {
|
|
Write-Error "✗ Distribution directory not found: $distDir"
|
|
Write-Host "Files in dist directory:"
|
|
Get-ChildItem "dist" | ForEach-Object { Write-Host " - $($_.Name)" }
|
|
exit 1
|
|
}
|
|
shell: pwsh
|
|
|
|
- name: Archive artifacts
|
|
uses: actions/upload-artifact@v6
|
|
with:
|
|
name: AutoLibrary.${{ steps.get_version.outputs.TAG_NAME }}-windows-x86_64
|
|
path: |
|
|
${{ steps.zip_release.outputs.ZIP_NAME }}
|
|
retention-days: 7
|
|
|
|
- name: Upload build summary
|
|
run: |
|
|
Write-Host "## Build Test Summary" | Out-File -FilePath $env:GITHUB_STEP_SUMMARY -Encoding utf8
|
|
Write-Host "" | Out-File -FilePath $env:GITHUB_STEP_SUMMARY -Encoding utf8 -Append
|
|
Write-Host "========================================" | Out-File -FilePath $env:GITHUB_STEP_SUMMARY -Encoding utf8 -Append
|
|
Write-Host "✓ Pull request build test completed successfully!" | Out-File -FilePath $env:GITHUB_STEP_SUMMARY -Encoding utf8 -Append
|
|
Write-Host "- Version: ${{ steps.get_version.outputs.VERSION }}" | Out-File -FilePath $env:GITHUB_STEP_SUMMARY -Encoding utf8 -Append
|
|
Write-Host "- Tag: ${{ steps.get_version.outputs.TAG_NAME }}" | Out-File -FilePath $env:GITHUB_STEP_SUMMARY -Encoding utf8 -Append
|
|
Write-Host "- Pull Request #${{ github.event.pull_request.number || 'N/A' }}" | Out-File -FilePath $env:GITHUB_STEP_SUMMARY -Encoding utf8 -Append
|
|
Write-Host "- Branch: ${{ github.event.pull_request.head.ref || github.ref }}" | Out-File -FilePath $env:GITHUB_STEP_SUMMARY -Encoding utf8 -Append
|
|
Write-Host "- Event: ${{ github.event_name }}" | Out-File -FilePath $env:GITHUB_STEP_SUMMARY -Encoding utf8 -Append
|
|
shell: pwsh
|