{
  "timestamp": "2026-04-12T17:26:57.701732+08:00",
  "batch_dir": "/srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b",
  "agent": "v3",
  "profile": "grammy",
  "thinking": "low",
  "timeout": 600,
  "concurrency": 3,
  "resume_mode": "each",
  "pending_song_count": 4,
  "groups": [
    {
      "group_index": 1,
      "songs": [
        "/srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/01_Thinkin' Bout You (Ryan Hemsworth Bootleg)_20260412",
        "/srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/02_Stuck On You_20260412",
        "/srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/03_HEARTBREAK ANNIVERSARY_20260412"
      ],
      "success_count": 3,
      "failed_count": 0,
      "results": [
        {
          "status": "success",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/01_Thinkin' Bout You (Ryan Hemsworth Bootleg)_20260412",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/01_Thinkin' Bout You (Ryan Hemsworth Bootleg)_20260412/step2_json_b.json",
          "run_id": null,
          "agent_summary": "API direct: Spare Key",
          "returncode": 0,
          "stderr": "",
          "attempt": 1,
          "attempts": [
            {
              "status": "success",
              "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/01_Thinkin' Bout You (Ryan Hemsworth Bootleg)_20260412",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/01_Thinkin' Bout You (Ryan Hemsworth Bootleg)_20260412/step2_json_b.json",
              "run_id": null,
              "agent_summary": "API direct: Spare Key",
              "returncode": 0,
              "stderr": "",
              "attempt": 1
            }
          ]
        },
        {
          "status": "success",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/02_Stuck On You_20260412",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/02_Stuck On You_20260412/step2_json_b.json",
          "run_id": null,
          "agent_summary": "API direct: Slow Dissolve",
          "returncode": 0,
          "stderr": "",
          "attempt": 1,
          "attempts": [
            {
              "status": "success",
              "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/02_Stuck On You_20260412",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/02_Stuck On You_20260412/step2_json_b.json",
              "run_id": null,
              "agent_summary": "API direct: Slow Dissolve",
              "returncode": 0,
              "stderr": "",
              "attempt": 1
            }
          ]
        },
        {
          "status": "success",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/03_HEARTBREAK ANNIVERSARY_20260412",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/03_HEARTBREAK ANNIVERSARY_20260412/step2_json_b.json",
          "run_id": null,
          "agent_summary": "API direct: Grocery Run",
          "returncode": 0,
          "stderr": "",
          "attempt": 1,
          "attempts": [
            {
              "status": "success",
              "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/03_HEARTBREAK ANNIVERSARY_20260412",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/03_HEARTBREAK ANNIVERSARY_20260412/step2_json_b.json",
              "run_id": null,
              "agent_summary": "API direct: Grocery Run",
              "returncode": 0,
              "stderr": "",
              "attempt": 1
            }
          ]
        }
      ]
    },
    {
      "group_index": 2,
      "songs": [
        "/srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/04_Peaches_20260412"
      ],
      "success_count": 0,
      "failed_count": 1,
      "results": [
        {
          "status": "error",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/04_Peaches_20260412",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/04_Peaches_20260412/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-20260412-172318-a6578b/04_Peaches_20260412",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/04_Peaches_20260412/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-20260412-172318-a6578b/04_Peaches_20260412",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/04_Peaches_20260412/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": "s_20260412] Renamed → 04_Peaches_Second_Rinse_20260412\n  📝 [04_Peaches_Second_Rinse_20260412] lyrics stripped: 4242c → 4237c\n[17:32:28] 🎵 [04_Peaches_Second_Rinse_20260412] Step 3: Suno generation (weirdness=50, style_influence=50)...\n[17:32:28] 🎨 [04_Peaches_Second_Rinse_20260412] Step 4: SeeDream cover (parallel)...\n  🎵 6716967e... → complete\n  🎵 7662c7f0... → complete\n  🎵 499457a5... → complete\n[17:33:12]    🎧 [02_Stuck On You_20260412] Song 1: https://cdn1.suno.ai/7662c7f0-7cc0-4dad-b3ab-8da6b993370b.mp3\n[17:33:12]    🎧 [02_Stuck On You_20260412] Song 2: https://cdn1.suno.ai/499457a5-32fe-45c1-9a97-44e8cbee6238.mp3\n[17:33:12] 🎛️ [02_Stuck On You_20260412] Step 3.5: 混音...\n[17:33:35]    🎚️ [02_Stuck On You_20260412] Song 1: pop | 低74/中24/高1%\n  ✅ submitted: ['e94022b3', 'f7951c87']\n  🎵 abd8bdea... → complete\n[17:33:54]    🎚️ [02_Stuck On You_20260412] Song 2: pop | 低58/中38/高4%\n[17:33:54] ✅ [02_Stuck On You_20260412] Step 3.5: 42.4s | 2 songs mixed\n  🎵 ad791dcf... → complete\n[17:33:55]    🎧 [03_HEARTBREAK ANNIVERSARY_20260412] Song 1: https://cdn1.suno.ai/ad791dcf-ec35-4981-86c4-72efb185860f.mp3\n[17:33:55]    🎧 [03_HEARTBREAK ANNIVERSARY_20260412] Song 2: https://cdn1.suno.ai/6716967e-f361-41b7-8654-f82ee92903dc.mp3\n[17:33:55] 🎛️ [03_HEARTBREAK ANNIVERSARY_20260412] Step 3.5: 混音...\n  🎵 03994eb3... → complete\n[17:33:55]    🎧 [01_Thinkin' Bout You (Ryan Hemsworth Bootleg)_20260412] Song 1: https://cdn1.suno.ai/03994eb3-d077-4797-af5a-120eec4f7d2d.mp3\n[17:33:55]    🎧 [01_Thinkin' Bout You (Ryan Hemsworth Bootleg)_20260412] Song 2: https://cdn1.suno.ai/abd8bdea-e057-4587-ba46-26c4c235c642.mp3\n[17:33:55] 🎛️ [01_Thinkin' Bout You (Ryan Hemsworth Bootleg)_20260412] Step 3.5: 混音...\n  🎵 e94022b3... → streaming\n  🎵 f7951c87... → streaming\n[17:34:16]    🎚️ [03_HEARTBREAK ANNIVERSARY_20260412] Song 1: pop | 低64/中34/高2%\n[17:34:34]    🎚️ [01_Thinkin' Bout You (Ryan Hemsworth Bootleg)_20260412] Song 1: pop | 低62/中36/高2%\n[17:34:34] ⚠️  [02_Stuck On You_20260412] Cover download failed: \n[17:34:34] ✅ [02_Stuck On You_20260412] Step 4: 18.3s | https://platform.cdn.acedata.cloud/seedream/b3943923-6648-4fc6-9e79-36b60a018f0d.jpg\n[17:34:55]    🎚️ [03_HEARTBREAK ANNIVERSARY_20260412] Song 2: rnb | 低79/中21/高0%\n[17:34:55] ✅ [03_HEARTBREAK ANNIVERSARY_20260412] Step 3.5: 60.1s | 2 songs mixed\n[17:35:11]    🎚️ [01_Thinkin' Bout You (Ryan Hemsworth Bootleg)_20260412] Song 2: hip_hop | 低54/中44/高1%\n[17:35:11] ✅ [01_Thinkin' Bout You (Ryan Hemsworth Bootleg)_20260412] Step 3.5: 76.0s | 2 songs mixed\n  🎵 f7951c87... → complete\n[17:35:13] ✅ [03_HEARTBREAK ANNIVERSARY_20260412] Step 4: 16.8s | /srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/03_HEARTBREAK ANNIVERSARY_20260412/cover_seedream.jpg\n[17:35:13] ✅ [01_Thinkin' Bout You (Ryan Hemsworth Bootleg)_20260412] Step 4: 16.9s | /srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/01_Thinkin' Bout You (Ryan Hemsworth Bootleg)_20260412/cover_seedream.jpg\n  🎵 e94022b3... → complete\n[17:35:28]    🎧 [04_Peaches_Second_Rinse_20260412] Song 1: https://cdn1.suno.ai/e94022b3-8bed-4955-aefe-6308c47f0f8c.mp3\n[17:35:28]    🎧 [04_Peaches_Second_Rinse_20260412] Song 2: https://cdn1.suno.ai/f7951c87-ec1b-4cd2-9610-cc4d704e7364.mp3\n[17:35:28] 🎛️ [04_Peaches_Second_Rinse_20260412] Step 3.5: 混音...\n[17:35:46]    🎚️ [04_Peaches_Second_Rinse_20260412] Song 1: pop | 低71/中29/高1%\n[17:36:01]    🎚️ [04_Peaches_Second_Rinse_20260412] Song 2: jazz | 低75/中24/高1%\n[17:36:01] ✅ [04_Peaches_Second_Rinse_20260412] Step 3.5: 32.6s | 2 songs mixed\n[17:36:04] ✅ [04_Peaches_Second_Rinse_20260412] Step 4: 10.4s | /srv/music-files-platform-next/pipeline/batch-20260412-172318-a6578b/04_Peaches_Second_Rinse_20260412/cover_seedream.jpg\n\n======================================================================\nSUMMARY | 396s (6.6min)\n======================================================================\n✅ Done: 4 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 0\n[MasterDB] ✅ 批次 batch-20260412-172318-a6578b → +4 新增, ~0 更新 | 总计 446 首\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-12T17:36:04.080198+08:00",
      "wall_clock": 396.0,
      "total": 4,
      "success": 4,
      "awaiting_step2": 0,
      "failed": 0
    }
  },
  "status": "partial_failure"
}