{
  "timestamp": "2026-04-22T15:14:28.217176+08:00",
  "batch_dir": "/srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f",
  "profile": "grammy",
  "concurrency": 3,
  "resume_mode": "each",
  "pending_song_count": 6,
  "groups": [
    {
      "group_index": 1,
      "songs": [
        "/srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f/01_Ocean Eyes_20260422",
        "/srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f/02_Bad Guy_20260422",
        "/srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f/03_When the Party's Over_20260422"
      ],
      "success_count": 3,
      "failed_count": 0,
      "results": [
        {
          "status": "success",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f/01_Ocean Eyes_20260422",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f/01_Ocean Eyes_20260422/step2_json_b.json",
          "agent_summary": "API direct: 潮水线",
          "returncode": 0,
          "stderr": "",
          "attempt": 1,
          "attempts": [
            {
              "status": "success",
              "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f/01_Ocean Eyes_20260422",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f/01_Ocean Eyes_20260422/step2_json_b.json",
              "agent_summary": "API direct: 潮水线",
              "returncode": 0,
              "stderr": "",
              "attempt": 1
            }
          ]
        },
        {
          "status": "success",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f/02_Bad Guy_20260422",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f/02_Bad Guy_20260422/step2_json_b.json",
          "agent_summary": "API direct: 钝刺",
          "returncode": 0,
          "stderr": "",
          "attempt": 2,
          "attempts": [
            {
              "status": "error",
              "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f/02_Bad Guy_20260422",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f/02_Bad Guy_20260422/step2_json_b.json",
              "error_type": "api_error",
              "error": "All 2 attempts failed: JSON parse error: Expecting ',' delimiter: line 6 column 164 (char 4759)",
              "agent_summary": null,
              "returncode": 1,
              "stderr": "All 2 attempts failed: JSON parse error: Expecting ',' delimiter: line 6 column 164 (char 4759)",
              "attempt": 1
            },
            {
              "status": "success",
              "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f/02_Bad Guy_20260422",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f/02_Bad Guy_20260422/step2_json_b.json",
              "agent_summary": "API direct: 钝刺",
              "returncode": 0,
              "stderr": "",
              "attempt": 2
            }
          ]
        },
        {
          "status": "success",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f/03_When the Party's Over_20260422",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f/03_When the Party's Over_20260422/step2_json_b.json",
          "agent_summary": "API direct: 半截蜡烛",
          "returncode": 0,
          "stderr": "",
          "attempt": 1,
          "attempts": [
            {
              "status": "success",
              "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f/03_When the Party's Over_20260422",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f/03_When the Party's Over_20260422/step2_json_b.json",
              "agent_summary": "API direct: 半截蜡烛",
              "returncode": 0,
              "stderr": "",
              "attempt": 1
            }
          ]
        }
      ]
    }
  ],
  "resume": {
    "status": "success",
    "returncode": 0,
    "stdout_tail": "g 2: pop | 低61/中37/高1%\n[15:19:27] ✅ [03_When the Party's Over_20260422] Step 3.5: 40.0s | 2 songs mixed\n[15:19:27] ⚠️  [04_Bury a Friend_20260422] Step 2 API originality retry 3 failed: Expecting value: line 1 column 1 (char 0)\n[15:19:27] ⚠️  [04_Bury a Friend_20260422] Step 2 API: best originality 57% after 3 retries\n[15:19:27] ✅ [04_Bury a Friend_20260422] Step 2 API: 《Shed Skin》 | 113.0s | in=52940 out=6514 | ~$0.257\n[15:19:27] ✅ [04_Bury a Friend_20260422] Step 2.5: originality 57% ✓\n[15:19:27] ✅ [04_Bury a Friend_20260422] Step 2: 《Shed Skin》\n[15:19:27] 📁 [04_Bury a Friend_20260422] Renamed → 04_Bury a Friend_Shed_Skin_20260422\n  📝 [04_Bury a Friend_Shed_Skin_20260422] lyrics stripped: 4350c → 4345c\n[15:19:27] 🎵 [04_Bury a Friend_Shed_Skin_20260422] Step 3: Suno generation (weirdness=50, style_influence=50)...\n[15:19:27] 🎨 [04_Bury a Friend_Shed_Skin_20260422] Step 4: SeeDream cover (parallel)...\n[15:19:48]    🎚️ [01_Ocean Eyes_20260422] Song 1: rnb | 低60/中38/高2%\n[15:20:08]    🎚️ [02_Bad Guy_20260422] Song 1: edm | 低85/中13/高2%\n  ⏱  poll timeout, retry...\n  ✅ submitted: ['5fd7c523', '457368c4']\n[15:20:08] ⚠️  [03_When the Party's Over_20260422] Cover download failed: \n[15:20:08] ✅ [03_When the Party's Over_20260422] Step 4: 15.6s | https://platform.cdn.acedata.cloud/seedream/378d9bca-1aea-476e-99e6-674d2b3962d9.jpg\n  🎵 5fd7c523... → streaming\n  🎵 457368c4... → streaming\n[15:20:29]    🎚️ [01_Ocean Eyes_20260422] Song 2: rnb | 低65/中33/高2%\n[15:20:29] ✅ [01_Ocean Eyes_20260422] Step 3.5: 78.7s | 2 songs mixed\n[15:20:47]    🎚️ [02_Bad Guy_20260422] Song 2: edm | 低88/中11/高1%\n[15:20:47] ✅ [02_Bad Guy_20260422] Step 3.5: 96.5s | 2 songs mixed\n  🎵 ca6eb41c... → streaming\n  🎵 7220c007... → streaming\n[15:20:48] ✅ [01_Ocean Eyes_20260422] Step 4: 15.7s | /srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f/01_Ocean Eyes_20260422/cover_seedream.jpg\n[15:20:49] ✅ [02_Bad Guy_20260422] Step 4: 16.2s | /srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f/02_Bad Guy_20260422/cover_seedream.jpg\n  🎵 ca6eb41c... → complete\n  🎵 5fd7c523... → complete\n  🎵 7220c007... → complete\n[15:21:30]    🎧 [05_Everything I Wanted_Tide_Marks_20260422] Song 1: https://cdn1.suno.ai/ca6eb41c-fe6b-4487-8440-48fa29d64947.mp3\n[15:21:30]    🎧 [05_Everything I Wanted_Tide_Marks_20260422] Song 2: https://cdn1.suno.ai/7220c007-663f-42cc-8509-6081bc985ff4.mp3\n[15:21:30] 🎛️ [05_Everything I Wanted_Tide_Marks_20260422] Step 3.5: 混音...\n[15:21:53]    🎚️ [05_Everything I Wanted_Tide_Marks_20260422] Song 1: pop | 低71/中28/高1%\n  🎵 457368c4... → complete\n[15:21:53]    🎧 [04_Bury a Friend_Shed_Skin_20260422] Song 1: https://cdn1.suno.ai/5fd7c523-f137-4c8f-a1fe-2222a1ebde9d.mp3\n[15:21:53]    🎧 [04_Bury a Friend_Shed_Skin_20260422] Song 2: https://cdn1.suno.ai/457368c4-3ff2-4591-bde8-1348ddf474d6.mp3\n[15:21:53] 🎛️ [04_Bury a Friend_Shed_Skin_20260422] Step 3.5: 混音...\n[15:22:15]    🎚️ [05_Everything I Wanted_Tide_Marks_20260422] Song 2: pop | 低71/中27/高2%\n[15:22:15] ✅ [05_Everything I Wanted_Tide_Marks_20260422] Step 3.5: 44.9s | 2 songs mixed\n[15:22:34]    🎚️ [04_Bury a Friend_Shed_Skin_20260422] Song 1: pop | 低53/中41/高6%\n[15:22:34] ✅ [05_Everything I Wanted_Tide_Marks_20260422] Step 4: 28.0s | /srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f/05_Everything I Wanted_Tide_Marks_20260422/cover_seedream.jpg\n[15:22:55]    🎚️ [04_Bury a Friend_Shed_Skin_20260422] Song 2: pop | 低74/中21/高5%\n[15:22:55] ✅ [04_Bury a Friend_Shed_Skin_20260422] Step 3.5: 61.8s | 2 songs mixed\n[15:22:57] ✅ [04_Bury a Friend_Shed_Skin_20260422] Step 4: 79.8s | /srv/music-files-platform-next/pipeline/batch-20260422-151014-29323f/04_Bury a Friend_Shed_Skin_20260422/cover_seedream.jpg\n\n======================================================================\nSUMMARY | 368s (6.1min)\n======================================================================\n✅ Done: 5 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 1\n[MasterDB] ✅ 批次 batch-20260422-151014-29323f → +5 新增, ~0 更新 | 总计 573 首\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-22T15:22:57.296429+08:00",
      "wall_clock": 368.1,
      "total": 7,
      "success": 5,
      "awaiting_step2": 0,
      "failed": 1
    }
  },
  "status": "success"
}