{
  "timestamp": "2026-04-18T17:22:43.495536+08:00",
  "batch_dir": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3",
  "agent": "v3",
  "profile": "grammy",
  "thinking": "low",
  "timeout": 600,
  "concurrency": 3,
  "resume_mode": "each",
  "pending_song_count": 5,
  "groups": [
    {
      "group_index": 1,
      "songs": [
        "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/01_BULLY (feat. CeeLo Green)_20260418",
        "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/02_KING_20260418",
        "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/03_ALL THE LOVE (feat. Andre Troutman)_20260418"
      ],
      "success_count": 3,
      "failed_count": 0,
      "results": [
        {
          "status": "success",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/01_BULLY (feat. CeeLo Green)_20260418",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/01_BULLY (feat. CeeLo Green)_20260418/step2_json_b.json",
          "run_id": null,
          "agent_summary": "API direct: 咬牙根",
          "returncode": 0,
          "stderr": "",
          "attempt": 1,
          "attempts": [
            {
              "status": "success",
              "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/01_BULLY (feat. CeeLo Green)_20260418",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/01_BULLY (feat. CeeLo Green)_20260418/step2_json_b.json",
              "run_id": null,
              "agent_summary": "API direct: 咬牙根",
              "returncode": 0,
              "stderr": "",
              "attempt": 1
            }
          ]
        },
        {
          "status": "success",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/02_KING_20260418",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/02_KING_20260418/step2_json_b.json",
          "run_id": null,
          "agent_summary": "API direct: 烟灰账本",
          "returncode": 0,
          "stderr": "",
          "attempt": 1,
          "attempts": [
            {
              "status": "success",
              "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/02_KING_20260418",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/02_KING_20260418/step2_json_b.json",
              "run_id": null,
              "agent_summary": "API direct: 烟灰账本",
              "returncode": 0,
              "stderr": "",
              "attempt": 1
            }
          ]
        },
        {
          "status": "success",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/03_ALL THE LOVE (feat. Andre Troutman)_20260418",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/03_ALL THE LOVE (feat. Andre Troutman)_20260418/step2_json_b.json",
          "run_id": null,
          "agent_summary": "API direct: 闷烧",
          "returncode": 0,
          "stderr": "",
          "attempt": 1,
          "attempts": [
            {
              "status": "success",
              "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/03_ALL THE LOVE (feat. Andre Troutman)_20260418",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/03_ALL THE LOVE (feat. Andre Troutman)_20260418/step2_json_b.json",
              "run_id": null,
              "agent_summary": "API direct: 闷烧",
              "returncode": 0,
              "stderr": "",
              "attempt": 1
            }
          ]
        }
      ]
    },
    {
      "group_index": 2,
      "songs": [
        "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/04_White Ferrari_20260418",
        "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/05_Pink + White_20260418"
      ],
      "success_count": 0,
      "failed_count": 2,
      "results": [
        {
          "status": "error",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/04_White Ferrari_20260418",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/04_White Ferrari_20260418/step2_json_b.json",
          "error_type": "api_error",
          "error": "step1_json_a.json not found",
          "run_id": null,
          "agent_summary": null,
          "returncode": 1,
          "stderr": "step1_json_a.json not found",
          "attempt": 2,
          "attempts": [
            {
              "status": "error",
              "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/04_White Ferrari_20260418",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/04_White Ferrari_20260418/step2_json_b.json",
              "error_type": "api_error",
              "error": "step1_json_a.json not found",
              "run_id": null,
              "agent_summary": null,
              "returncode": 1,
              "stderr": "step1_json_a.json not found",
              "attempt": 1
            },
            {
              "status": "error",
              "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/04_White Ferrari_20260418",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/04_White Ferrari_20260418/step2_json_b.json",
              "error_type": "api_error",
              "error": "step1_json_a.json not found",
              "run_id": null,
              "agent_summary": null,
              "returncode": 1,
              "stderr": "step1_json_a.json not found",
              "attempt": 2
            }
          ]
        },
        {
          "status": "error",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/05_Pink + White_20260418",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/05_Pink + White_20260418/step2_json_b.json",
          "error_type": "api_error",
          "error": "step1_json_a.json not found",
          "run_id": null,
          "agent_summary": null,
          "returncode": 1,
          "stderr": "step1_json_a.json not found",
          "attempt": 2,
          "attempts": [
            {
              "status": "error",
              "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/05_Pink + White_20260418",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/05_Pink + White_20260418/step2_json_b.json",
              "error_type": "api_error",
              "error": "step1_json_a.json not found",
              "run_id": null,
              "agent_summary": null,
              "returncode": 1,
              "stderr": "step1_json_a.json not found",
              "attempt": 1
            },
            {
              "status": "error",
              "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/05_Pink + White_20260418",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/05_Pink + White_20260418/step2_json_b.json",
              "error_type": "api_error",
              "error": "step1_json_a.json not found",
              "run_id": null,
              "agent_summary": null,
              "returncode": 1,
              "stderr": "step1_json_a.json not found",
              "attempt": 2
            }
          ]
        }
      ]
    }
  ],
  "resume": {
    "status": "success",
    "returncode": 0,
    "stdout_tail": "17:30:28]    🎧 [05_Pink + White_Grocery_List_20260418] Song 1: https://cdn1.suno.ai/771b920c-7514-4527-983b-95e143da7124.mp3\n[17:30:28]    🎧 [05_Pink + White_Grocery_List_20260418] Song 2: https://cdn1.suno.ai/4fab258e-71f9-4804-b7e2-e341ae320467.mp3\n[17:30:28] 🎛️ [05_Pink + White_Grocery_List_20260418] Step 3.5: 混音...\n[17:30:45]    🎚️ [05_Pink + White_Grocery_List_20260418] Song 1: pop | 低66/中30/高4%\n[17:30:45] ✅ [04_White Ferrari_Loose_Seams_20260418] Step 4: 17.7s | /srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/04_White Ferrari_Loose_Seams_20260418/cover_seedream.jpg\n[17:30:45] 🎤 [04_White Ferrari_Loose_Seams_20260418] Step 3.6: Lyrics alignment (faster-whisper)...\n[17:31:03]    🎚️ [05_Pink + White_Grocery_List_20260418] Song 2: pop | 低57/中39/高4%\n[17:31:03] ✅ [05_Pink + White_Grocery_List_20260418] Step 3.5: 35.0s | 2 songs mixed\n  ✅ submitted: ['d4500e26', '326b408c']\n  🎵 d4500e26... → queued\n  🎵 326b408c... → queued\n[17:31:04] ✅ [05_Pink + White_Grocery_List_20260418] Step 4: 15.0s | /srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/05_Pink + White_Grocery_List_20260418/cover_seedream.jpg\n[17:31:04] 🎤 [05_Pink + White_Grocery_List_20260418] Step 3.6: Lyrics alignment (faster-whisper)...\n[17:31:07] ✅ [03_ALL THE LOVE (feat. Andre Troutman)_20260418] Step 3.6: confidence=1.0 | 29/29 lines | 192.5s\n[17:31:07] 📊 [03_ALL THE LOVE (feat. Andre Troutman)_20260418] Step 3.8: Auto scoring (+ Gemini aesthetic)...\n  🎵 326b408c... → streaming\n[17:31:16] ✅ [03_ALL THE LOVE (feat. Andre Troutman)_20260418] Step 3.8: A (7.99/10) | aesthetic=7.84 | flags=[]\n  🎵 d4500e26... → streaming\n  🎵 d4500e26... → complete\n[17:32:45] ✅ [02_KING_20260418] Step 3.6: confidence=1.0 | 35/35 lines | 97.4s\n[17:32:45] 📊 [02_KING_20260418] Step 3.8: Auto scoring (+ Gemini aesthetic)...\n[17:32:52] ✅ [02_KING_20260418] Step 3.8: A (8.27/10) | aesthetic=8.6 | flags=[]\n[17:34:31] ✅ [04_White Ferrari_Loose_Seams_20260418] Step 3.6: confidence=1.0 | 43/43 lines | 106.2s\n[17:34:31] 📊 [04_White Ferrari_Loose_Seams_20260418] Step 3.8: Auto scoring (+ Gemini aesthetic)...\n  🎵 326b408c... → complete\n[17:34:41]    🎧 [01_BULLY (feat. CeeLo Green)_20260418] Song 1: https://cdn1.suno.ai/d4500e26-806e-45a8-9388-dbe5d560f002.mp3\n[17:34:41]    🎧 [01_BULLY (feat. CeeLo Green)_20260418] Song 2: https://cdn1.suno.ai/326b408c-944d-4e8b-81b2-e9809316dd9a.mp3\n[17:34:41] 🎛️ [01_BULLY (feat. CeeLo Green)_20260418] Step 3.5: 混音...\n[17:35:00]    🎚️ [01_BULLY (feat. CeeLo Green)_20260418] Song 1: pop | 低59/中38/高3%\n[17:35:00] ✅ [04_White Ferrari_Loose_Seams_20260418] Step 3.8: A (8.17/10) | aesthetic=8.97 | flags=[]\n[17:35:34]    🎚️ [01_BULLY (feat. CeeLo Green)_20260418] Song 2: pop | 低62/中36/高3%\n[17:35:34] ✅ [01_BULLY (feat. CeeLo Green)_20260418] Step 3.5: 52.9s | 2 songs mixed\n[17:35:36] ✅ [01_BULLY (feat. CeeLo Green)_20260418] Step 4: 16.1s | /srv/music-files-platform-next/pipeline/batch-20260418-171928-7b56f3/01_BULLY (feat. CeeLo Green)_20260418/cover_seedream.jpg\n[17:35:36] 🎤 [01_BULLY (feat. CeeLo Green)_20260418] Step 3.6: Lyrics alignment (faster-whisper)...\n[17:36:10] ✅ [05_Pink + White_Grocery_List_20260418] Step 3.6: confidence=1.0 | 39/39 lines | 98.8s\n[17:36:10] 📊 [05_Pink + White_Grocery_List_20260418] Step 3.8: Auto scoring (+ Gemini aesthetic)...\n[17:36:17] ✅ [05_Pink + White_Grocery_List_20260418] Step 3.8: A (8.43/10) | aesthetic=9.24 | flags=[]\n[17:39:43] ✅ [01_BULLY (feat. CeeLo Green)_20260418] Step 3.6: confidence=1.0 | 40/40 lines | 213.4s\n[17:39:43] 📊 [01_BULLY (feat. CeeLo Green)_20260418] Step 3.8: Auto scoring (+ Gemini aesthetic)...\n[17:39:55] ✅ [01_BULLY (feat. CeeLo Green)_20260418] Step 3.8: A (8.08/10) | aesthetic=8.71 | flags=[]\n\n======================================================================\nSUMMARY | 948s (15.8min)\n======================================================================\n✅ Done: 5 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 0\n[MasterDB] ✅ 批次 batch-20260418-171928-7b56f3 → +5 新增, ~0 更新 | 总计 451 首\n",
    "stderr_tail": "[profile] ✅ Loaded profile 'grammy' from /srv/repos/3000music-platform-next/services/music-pipeline/scripts/profiles/grammy.yaml\n",
    "summary": {
      "timestamp": "2026-04-18T17:39:55.222316+08:00",
      "wall_clock": 947.6,
      "total": 5,
      "success": 5,
      "awaiting_step2": 0,
      "failed": 0
    }
  },
  "status": "partial_failure"
}