From 3953218e4128ee2bd7a524b570c8837b63cef380 Mon Sep 17 00:00:00 2001 From: Hera Zhao Date: Tue, 14 Apr 2026 15:32:59 +0000 Subject: [PATCH] =?UTF-8?q?fix:=20CI=20e2e=E5=88=863=E6=89=B9=E8=B7=91?= =?UTF-8?q?=E5=85=A8=E9=83=A832=E4=B8=AAspec=EF=BC=8C=E6=AF=8F=E6=89=B9?= =?UTF-8?q?=E6=96=B0=E5=90=AFElectron=E9=87=8A=E6=94=BE=E5=86=85=E5=AD=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Batch1: API/数据测试(8个) Batch2: UI流程测试(9个) Batch3: 其他测试(15个,含demo-walkthrough) 每批5分钟超时,总共不超过15分钟,避免内存累积导致崩溃。 Co-Authored-By: Claude Opus 4.6 (1M context) --- .gitea/workflows/test.yml | 32 +++++++++++++++++++++++--------- 1 file changed, 23 insertions(+), 9 deletions(-) diff --git a/.gitea/workflows/test.yml b/.gitea/workflows/test.yml index 9ea2f71..3482f11 100644 --- a/.gitea/workflows/test.yml +++ b/.gitea/workflows/test.yml @@ -62,23 +62,37 @@ jobs: exit 1 fi - # Run specs excluding slow/memory-heavy ones + # Run all specs in 3 batches to avoid Electron memory crashes cd frontend - timeout 600 npx cypress run \ - --spec "cypress/e2e/!(demo-walkthrough|recipe-detail|manage-recipes|visual-check).cy.js" \ - --config "video=false,defaultCommandTimeout=5000,pageLoadTimeout=10000,requestTimeout=5000,responseTimeout=10000,baseUrl=http://localhost:$FE_PORT,experimentalMemoryManagement=true,numTestsKeptInMemory=0" \ - --env "ADMIN_TOKEN=$ADMIN_TOKEN" - EXIT_CODE=$? + CYPRESS_CFG="video=false,defaultCommandTimeout=5000,pageLoadTimeout=10000,requestTimeout=5000,responseTimeout=10000,baseUrl=http://localhost:$FE_PORT,experimentalMemoryManagement=true,numTestsKeptInMemory=0" + + echo "=== Batch 1: API & data tests ===" + timeout 300 npx cypress run \ + --spec "cypress/e2e/api-crud.cy.js,cypress/e2e/api-health.cy.js,cypress/e2e/oil-data-integrity.cy.js,cypress/e2e/recipe-cost-parity.cy.js,cypress/e2e/endpoint-parity.cy.js,cypress/e2e/registration-flow.cy.js,cypress/e2e/pr27-features.cy.js,cypress/e2e/kit-export.cy.js" \ + --config "$CYPRESS_CFG" --env "ADMIN_TOKEN=$ADMIN_TOKEN" + B1=$? + + echo "=== Batch 2: UI flow tests ===" + timeout 300 npx cypress run \ + --spec "cypress/e2e/auth-flow.cy.js,cypress/e2e/admin-flow.cy.js,cypress/e2e/navigation.cy.js,cypress/e2e/recipe-detail.cy.js,cypress/e2e/recipe-search.cy.js,cypress/e2e/manage-recipes.cy.js,cypress/e2e/diary-flow.cy.js,cypress/e2e/favorites.cy.js,cypress/e2e/inventory-flow.cy.js" \ + --config "$CYPRESS_CFG" --env "ADMIN_TOKEN=$ADMIN_TOKEN" + B2=$? + + echo "=== Batch 3: Remaining tests ===" + timeout 300 npx cypress run \ + --spec "cypress/e2e/app-load.cy.js,cypress/e2e/account-settings.cy.js,cypress/e2e/audit-log-advanced.cy.js,cypress/e2e/batch-operations.cy.js,cypress/e2e/bug-tracker-flow.cy.js,cypress/e2e/category-modules.cy.js,cypress/e2e/notification-flow.cy.js,cypress/e2e/oil-reference.cy.js,cypress/e2e/performance.cy.js,cypress/e2e/price-display.cy.js,cypress/e2e/projects-flow.cy.js,cypress/e2e/responsive.cy.js,cypress/e2e/search-advanced.cy.js,cypress/e2e/user-management-flow.cy.js,cypress/e2e/visual-check.cy.js,cypress/e2e/demo-walkthrough.cy.js" \ + --config "$CYPRESS_CFG" --env "ADMIN_TOKEN=$ADMIN_TOKEN" + B3=$? # Cleanup kill $BE_PID $FE_PID 2>/dev/null pkill -f "Cypress" 2>/dev/null || true rm -f "$DB_FILE" - if [ $EXIT_CODE -eq 124 ]; then - echo "ERROR: Cypress timed out after 15 minutes" + + echo "Results: Batch1=$B1 Batch2=$B2 Batch3=$B3" + if [ $B1 -ne 0 ] || [ $B2 -ne 0 ] || [ $B3 -ne 0 ]; then exit 1 fi - exit $EXIT_CODE build-check: runs-on: test