{
  "timestamp": "2026-04-19T13:41:12.189273+08:00",
  "batch_dir": "/srv/music-files-sandbox/pipeline/batch-20260419-133920-c30799",
  "profile": "grammy",
  "concurrency": 3,
  "resume_mode": "each",
  "pending_song_count": 2,
  "groups": [
    {
      "group_index": 1,
      "songs": [
        "/srv/music-files-sandbox/pipeline/batch-20260419-133920-c30799/01_I'm Yours_20260419",
        "/srv/music-files-sandbox/pipeline/batch-20260419-133920-c30799/02_Lucky_20260419"
      ],
      "success_count": 2,
      "failed_count": 0,
      "results": [
        {
          "status": "success",
          "song_dir": "/srv/music-files-sandbox/pipeline/batch-20260419-133920-c30799/01_I'm Yours_20260419",
          "step2_file": "/srv/music-files-sandbox/pipeline/batch-20260419-133920-c30799/01_I'm Yours_20260419/step2_json_b.json",
          "agent_summary": "API direct: Threadbare Jacket",
          "returncode": 0,
          "stderr": "",
          "attempt": 1,
          "attempts": [
            {
              "status": "success",
              "song_dir": "/srv/music-files-sandbox/pipeline/batch-20260419-133920-c30799/01_I'm Yours_20260419",
              "step2_file": "/srv/music-files-sandbox/pipeline/batch-20260419-133920-c30799/01_I'm Yours_20260419/step2_json_b.json",
              "agent_summary": "API direct: Threadbare Jacket",
              "returncode": 0,
              "stderr": "",
              "attempt": 1
            }
          ]
        },
        {
          "status": "success",
          "song_dir": "/srv/music-files-sandbox/pipeline/batch-20260419-133920-c30799/02_Lucky_20260419",
          "step2_file": "/srv/music-files-sandbox/pipeline/batch-20260419-133920-c30799/02_Lucky_20260419/step2_json_b.json",
          "agent_summary": "API direct: Porch Light On",
          "returncode": 0,
          "stderr": "",
          "attempt": 1,
          "attempts": [
            {
              "status": "success",
              "song_dir": "/srv/music-files-sandbox/pipeline/batch-20260419-133920-c30799/02_Lucky_20260419",
              "step2_file": "/srv/music-files-sandbox/pipeline/batch-20260419-133920-c30799/02_Lucky_20260419/step2_json_b.json",
              "agent_summary": "API direct: Porch Light On",
              "returncode": 0,
              "stderr": "",
              "attempt": 1
            }
          ]
        }
      ]
    }
  ],
  "resume": {
    "status": "success",
    "returncode": 0,
    "stdout_tail": "\n======================================================================\nmusic-pipeline3000 v2 | 2 songs\n======================================================================\nGemini concurrency: 2 | Suno concurrency: 3\nOutput: /srv/music-files-sandbox/pipeline/batch-20260419-133920-c30799\nSkip Suno: False | Step1 only: False | Version: v4\n======================================================================\n\n[13:44:32] 🏥 Health check...\n[13:44:34] ✅ qishui: OK\n[13:44:34] ✅ netease: OK\n[13:44:34] ✅ qq: OK\n\n  📝 [01_I'm Yours_20260419] lyrics stripped: 4872c → 4866c\n[13:44:34] 🎵 [01_I'm Yours_20260419] Step 3: Suno generation (weirdness=50, style_influence=50)...\n[13:44:34] 🎨 [01_I'm Yours_20260419] Step 4: SeeDream cover (parallel)...\n  📝 [02_Lucky_20260419] lyrics stripped: 5115c → 5000c\n[13:44:34] 🎵 [02_Lucky_20260419] Step 3: Suno generation (weirdness=50, style_influence=50)...\n[13:44:34] 🎨 [02_Lucky_20260419] Step 4: SeeDream cover (parallel)...\n  ✅ submitted: ['ad0b9b65', '3bc9128c']\n  🎵 ad0b9b65... → submitted\n  🎵 3bc9128c... → submitted\n  ✅ submitted: ['ec4a9b32', 'dcd6bde2']\n  🎵 ec4a9b32... → submitted\n  🎵 dcd6bde2... → submitted\n  🎵 ad0b9b65... → queued\n  🎵 3bc9128c... → queued\n  🎵 ec4a9b32... → queued\n  🎵 dcd6bde2... → queued\n  🎵 ad0b9b65... → streaming\n  🎵 ec4a9b32... → streaming\n  🎵 3bc9128c... → streaming\n  🎵 dcd6bde2... → streaming\n  🎵 ad0b9b65... → complete\n  🎵 3bc9128c... → complete\n[13:46:36]    🎧 [02_Lucky_20260419] Song 1: https://cdn1.suno.ai/ad0b9b65-f500-4162-867e-c6474efb5a82.mp3\n[13:46:36]    🎧 [02_Lucky_20260419] Song 2: https://cdn1.suno.ai/3bc9128c-effa-415f-9812-7e854f1032e7.mp3\n[13:46:36] 🎛️ [02_Lucky_20260419] Step 3.5: 混音...\n[13:46:56]    🎚️ [02_Lucky_20260419] Song 1: edm | 低67/中29/高5%\n[13:47:11]    🎚️ [02_Lucky_20260419] Song 2: edm | 低67/中29/高4%\n[13:47:11] ✅ [02_Lucky_20260419] Step 3.5: 35.6s | 2 songs mixed\n  🎵 ec4a9b32... → complete\n  🎵 dcd6bde2... → complete\n[13:47:11]    🎧 [01_I'm Yours_20260419] Song 1: https://cdn1.suno.ai/ec4a9b32-0a92-41f5-9a7b-d38f505d47ae.mp3\n[13:47:11]    🎧 [01_I'm Yours_20260419] Song 2: https://cdn1.suno.ai/dcd6bde2-f550-4d8b-b0ac-2aa616af069d.mp3\n[13:47:11] 🎛️ [01_I'm Yours_20260419] Step 3.5: 混音...\n[13:47:32]    🎚️ [01_I'm Yours_20260419] Song 1: edm | 低66/中31/高3%\n[13:47:32] ✅ [02_Lucky_20260419] Step 4: 14.6s | /srv/music-files-sandbox/pipeline/batch-20260419-133920-c30799/02_Lucky_20260419/cover_seedream.jpg\n[13:47:53]    🎚️ [01_I'm Yours_20260419] Song 2: edm | 低60/中35/高5%\n[13:47:53] ✅ [01_I'm Yours_20260419] Step 3.5: 41.9s | 2 songs mixed\n[13:47:54] ✅ [01_I'm Yours_20260419] Step 4: 18.1s | /srv/music-files-sandbox/pipeline/batch-20260419-133920-c30799/01_I'm Yours_20260419/cover_seedream.jpg\n\n======================================================================\nSUMMARY | 201s (3.3min)\n======================================================================\n✅ Done: 2 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 0\n[MasterDB] ✅ 批次 batch-20260419-133920-c30799 → +2 新增, ~0 更新 | 总计 538 首\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-19T13:47:54.982111+08:00",
      "wall_clock": 200.6,
      "total": 2,
      "success": 2,
      "awaiting_step2": 0,
      "failed": 0
    }
  },
  "status": "success"
}