{
  "timestamp": "2026-04-19T11:53:13.137906+08:00",
  "batch_dir": "/srv/music-files-platform-next/pipeline/batch-20260419-115132-6d7228",
  "profile": "grammy",
  "concurrency": 3,
  "resume_mode": "each",
  "pending_song_count": 2,
  "groups": [
    {
      "group_index": 1,
      "songs": [
        "/srv/music-files-platform-next/pipeline/batch-20260419-115132-6d7228/01_places to be_20260419",
        "/srv/music-files-platform-next/pipeline/batch-20260419-115132-6d7228/02_adore u_20260419"
      ],
      "success_count": 2,
      "failed_count": 0,
      "results": [
        {
          "status": "success",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260419-115132-6d7228/01_places to be_20260419",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260419-115132-6d7228/01_places to be_20260419/step2_json_b.json",
          "agent_summary": "API direct: Skin & Static",
          "returncode": 0,
          "stderr": "",
          "attempt": 1,
          "attempts": [
            {
              "status": "success",
              "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260419-115132-6d7228/01_places to be_20260419",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260419-115132-6d7228/01_places to be_20260419/step2_json_b.json",
              "agent_summary": "API direct: Skin & Static",
              "returncode": 0,
              "stderr": "",
              "attempt": 1
            }
          ]
        },
        {
          "status": "success",
          "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260419-115132-6d7228/02_adore u_20260419",
          "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260419-115132-6d7228/02_adore u_20260419/step2_json_b.json",
          "agent_summary": "API direct: Softer Side",
          "returncode": 0,
          "stderr": "",
          "attempt": 1,
          "attempts": [
            {
              "status": "success",
              "song_dir": "/srv/music-files-platform-next/pipeline/batch-20260419-115132-6d7228/02_adore u_20260419",
              "step2_file": "/srv/music-files-platform-next/pipeline/batch-20260419-115132-6d7228/02_adore u_20260419/step2_json_b.json",
              "agent_summary": "API direct: Softer Side",
              "returncode": 0,
              "stderr": "",
              "attempt": 1
            }
          ]
        }
      ]
    }
  ],
  "resume": {
    "status": "success",
    "returncode": 0,
    "stdout_tail": "\n======================================================================\nmusic-pipeline3000 v2 | 3 songs\n======================================================================\nGemini concurrency: 2 | Suno concurrency: 3\nOutput: /srv/music-files-platform-next/pipeline/batch-20260419-115132-6d7228\nSkip Suno: False | Step1 only: False | Version: v4\n======================================================================\n\n[11:56:01] 🏥 Health check...\n[11:56:05] ✅ qishui: OK\n[11:56:05] ✅ netease: OK\n[11:56:05] ✅ qq: OK\n\n[11:56:05] 🔍 [03_Victory Lap_20260419] Step 0: Fetching...\n  📝 [01_places to be_20260419] lyrics stripped: 5350c → 5000c\n[11:56:05] 🎵 [01_places to be_20260419] Step 3: Suno generation (weirdness=50, style_influence=50)...\n[11:56:05] 🎨 [01_places to be_20260419] Step 4: SeeDream cover (parallel)...\n  📝 [02_adore u_20260419] lyrics stripped: 4775c → 4768c\n[11:56:05] 🎵 [02_adore u_20260419] Step 3: Suno generation (weirdness=50, style_influence=50)...\n[11:56:05] 🎨 [02_adore u_20260419] Step 4: SeeDream cover (parallel)...\n[11:56:05] ⚠️  [qq] Exact source_id '000WA5yN17yRML' not found for 'Victory Lap'\n[11:56:05] 🔄 [03_Victory Lap_20260419] Step 0: retry 1/2 in 5s...\n  ✅ submitted: ['b5248166', '393f3175']\n  🎵 b5248166... → submitted\n  🎵 393f3175... → submitted\n  ✅ submitted: ['4f435ab8', 'c3c89eeb']\n  🎵 4f435ab8... → submitted\n  🎵 c3c89eeb... → submitted\n[11:56:10] ⚠️  [qq] Exact source_id '000WA5yN17yRML' not found for 'Victory Lap'\n[11:56:10] 🔄 [03_Victory Lap_20260419] Step 0: retry 2/2 in 10s...\n  🎵 b5248166... → queued\n  🎵 393f3175... → queued\n  🎵 4f435ab8... → queued\n  🎵 c3c89eeb... → queued\n[11:56:20] ⚠️  [qq] Exact source_id '000WA5yN17yRML' not found for 'Victory Lap'\n[11:56:20] ❌ [03_Victory Lap_20260419] Step 0: No audio URL\n  🎵 c3c89eeb... → streaming\n  🎵 393f3175... → streaming\n  🎵 4f435ab8... → streaming\n  🎵 b5248166... → streaming\n  🎵 4f435ab8... → complete\n  🎵 393f3175... → complete\n  🎵 b5248166... → complete\n[11:58:28]    🎧 [02_adore u_20260419] Song 1: https://cdn1.suno.ai/b5248166-cfcf-4a58-ae8d-fe00afbe8e41.mp3\n[11:58:28]    🎧 [02_adore u_20260419] Song 2: https://cdn1.suno.ai/393f3175-a25b-4b00-92b9-c206fe40533b.mp3\n[11:58:28] 🎛️ [02_adore u_20260419] Step 3.5: 混音...\n[11:58:51]    🎚️ [02_adore u_20260419] Song 1: edm | 低80/中18/高3%\n  🎵 c3c89eeb... → complete\n[11:58:51]    🎧 [01_places to be_20260419] Song 1: https://cdn1.suno.ai/4f435ab8-ed90-4328-8057-7efb2cac19f3.mp3\n[11:58:51]    🎧 [01_places to be_20260419] Song 2: https://cdn1.suno.ai/c3c89eeb-3611-4119-bcc3-ef67385d40b1.mp3\n[11:58:51] 🎛️ [01_places to be_20260419] Step 3.5: 混音...\n[11:59:10]    🎚️ [02_adore u_20260419] Song 2: pop | 低49/中43/高8%\n[11:59:10] ✅ [02_adore u_20260419] Step 3.5: 42.5s | 2 songs mixed\n[11:59:32]    🎚️ [01_places to be_20260419] Song 1: rock | 低70/中25/高5%\n[11:59:32] ✅ [02_adore u_20260419] Step 4: 17.8s | /srv/music-files-platform-next/pipeline/batch-20260419-115132-6d7228/02_adore u_20260419/cover_seedream.jpg\n[11:59:53]    🎚️ [01_places to be_20260419] Song 2: jazz | 低75/中21/高4%\n[11:59:53] ✅ [01_places to be_20260419] Step 3.5: 61.6s | 2 songs mixed\n[11:59:55] ✅ [01_places to be_20260419] Step 4: 19.0s | /srv/music-files-platform-next/pipeline/batch-20260419-115132-6d7228/01_places to be_20260419/cover_seedream.jpg\n\n======================================================================\nSUMMARY | 231s (3.8min)\n======================================================================\n✅ Done: 2 | ⏳ Awaiting Step 2: 0 | ❌ Failed: 1\n[MasterDB] ✅ 批次 batch-20260419-115132-6d7228 → +2 新增, ~0 更新 | 总计 474 首\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-19T11:59:55.731773+08:00",
      "wall_clock": 230.6,
      "total": 3,
      "success": 2,
      "awaiting_step2": 0,
      "failed": 1
    }
  },
  "status": "success"
}