dayhoff-tools 1.14.11__py3-none-any.whl → 1.14.12__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- dayhoff_tools/cli/batch/commands/status.py +98 -3
- {dayhoff_tools-1.14.11.dist-info → dayhoff_tools-1.14.12.dist-info}/METADATA +1 -1
- {dayhoff_tools-1.14.11.dist-info → dayhoff_tools-1.14.12.dist-info}/RECORD +5 -5
- {dayhoff_tools-1.14.11.dist-info → dayhoff_tools-1.14.12.dist-info}/WHEEL +0 -0
- {dayhoff_tools-1.14.11.dist-info → dayhoff_tools-1.14.12.dist-info}/entry_points.txt +0 -0
|
@@ -174,15 +174,41 @@ def _show_job_list(user, status_filter, pipeline, base_path):
|
|
|
174
174
|
click.echo("Use 'dh batch status <job-id>' for details.")
|
|
175
175
|
|
|
176
176
|
|
|
177
|
+
def _parse_retry_job_id(job_id: str) -> tuple[str, str | None]:
|
|
178
|
+
"""Parse a job ID to extract parent job ID and retry suffix.
|
|
179
|
+
|
|
180
|
+
Args:
|
|
181
|
+
job_id: Job ID like 'dma-embed-20260120-63ec' or 'dma-embed-20260120-63ec-r1'
|
|
182
|
+
|
|
183
|
+
Returns:
|
|
184
|
+
Tuple of (parent_job_id, retry_id or None)
|
|
185
|
+
"""
|
|
186
|
+
import re
|
|
187
|
+
|
|
188
|
+
# Check for retry suffix like -r1, -r2, etc.
|
|
189
|
+
match = re.match(r"^(.+)(-r\d+)$", job_id)
|
|
190
|
+
if match:
|
|
191
|
+
return match.group(1), job_id
|
|
192
|
+
return job_id, None
|
|
193
|
+
|
|
194
|
+
|
|
177
195
|
def _show_job_details(job_id: str, base_path: str):
|
|
178
196
|
"""Show detailed status for a specific job."""
|
|
197
|
+
# Check if this is a retry job ID
|
|
198
|
+
parent_job_id, retry_id = _parse_retry_job_id(job_id)
|
|
199
|
+
|
|
179
200
|
try:
|
|
180
|
-
manifest = load_manifest(
|
|
201
|
+
manifest = load_manifest(parent_job_id, base_path)
|
|
181
202
|
except FileNotFoundError:
|
|
182
203
|
click.echo(f"Job not found: {job_id}", err=True)
|
|
183
|
-
click.echo(f"Looking in: {base_path}/{
|
|
204
|
+
click.echo(f"Looking in: {base_path}/{parent_job_id}/manifest.json", err=True)
|
|
184
205
|
raise SystemExit(1)
|
|
185
206
|
|
|
207
|
+
# If showing a retry job, show retry-specific details
|
|
208
|
+
if retry_id:
|
|
209
|
+
_show_retry_details(manifest, retry_id)
|
|
210
|
+
return
|
|
211
|
+
|
|
186
212
|
click.echo()
|
|
187
213
|
click.echo(f"Job ID: {manifest.job_id}")
|
|
188
214
|
click.echo(f"Status: {format_status(manifest.status)}")
|
|
@@ -235,7 +261,31 @@ def _show_job_details(job_id: str, base_path: str):
|
|
|
235
261
|
click.echo()
|
|
236
262
|
click.echo("Retries:")
|
|
237
263
|
for retry in manifest.retries:
|
|
238
|
-
|
|
264
|
+
reslice_info = ""
|
|
265
|
+
if retry.reslice_prefix:
|
|
266
|
+
reslice_info = f" (resliced to {retry.reslice_count} chunks)"
|
|
267
|
+
click.echo(f" - {retry.retry_id}: {len(retry.indices)} indices{reslice_info}")
|
|
268
|
+
click.echo(f" Indices: {retry.indices}")
|
|
269
|
+
if retry.batch_job_id:
|
|
270
|
+
# Show brief status for retry job
|
|
271
|
+
try:
|
|
272
|
+
client = BatchClient()
|
|
273
|
+
array_status = client.get_array_job_status(retry.batch_job_id)
|
|
274
|
+
if array_status.is_complete:
|
|
275
|
+
pct = array_status.success_rate * 100
|
|
276
|
+
color = "green" if pct == 100 else "yellow" if pct > 90 else "red"
|
|
277
|
+
click.echo(
|
|
278
|
+
f" Status: Complete - {click.style(f'{pct:.0f}%', fg=color)} "
|
|
279
|
+
f"({array_status.succeeded}/{array_status.total} succeeded)"
|
|
280
|
+
)
|
|
281
|
+
else:
|
|
282
|
+
click.echo(
|
|
283
|
+
f" Status: Running - {array_status.succeeded}/{array_status.total} done, "
|
|
284
|
+
f"{array_status.running} running"
|
|
285
|
+
)
|
|
286
|
+
except BatchError:
|
|
287
|
+
click.echo(f" Status: (could not fetch)")
|
|
288
|
+
click.echo(f" Details: dh batch status {retry.retry_id}")
|
|
239
289
|
|
|
240
290
|
# Suggest next steps
|
|
241
291
|
click.echo()
|
|
@@ -285,3 +335,48 @@ def _show_array_status(batch_job_id: str):
|
|
|
285
335
|
|
|
286
336
|
except BatchError as e:
|
|
287
337
|
click.echo(f" (Could not fetch live status: {e})")
|
|
338
|
+
|
|
339
|
+
|
|
340
|
+
def _show_retry_details(manifest, retry_id: str):
|
|
341
|
+
"""Show detailed status for a retry job."""
|
|
342
|
+
# Find the retry info
|
|
343
|
+
retry_info = None
|
|
344
|
+
for retry in manifest.retries:
|
|
345
|
+
if retry.retry_id == retry_id:
|
|
346
|
+
retry_info = retry
|
|
347
|
+
break
|
|
348
|
+
|
|
349
|
+
if not retry_info:
|
|
350
|
+
click.echo(f"Retry job not found: {retry_id}", err=True)
|
|
351
|
+
click.echo(f"Known retries: {[r.retry_id for r in manifest.retries]}", err=True)
|
|
352
|
+
raise SystemExit(1)
|
|
353
|
+
|
|
354
|
+
click.echo()
|
|
355
|
+
click.echo(f"Retry Job: {retry_id}")
|
|
356
|
+
click.echo(f"Parent Job: {manifest.job_id}")
|
|
357
|
+
click.echo(f"Pipeline: {manifest.pipeline}")
|
|
358
|
+
click.echo(f"User: {manifest.user}")
|
|
359
|
+
click.echo(
|
|
360
|
+
f"Created: {retry_info.created.isoformat()} ({format_time_ago(retry_info.created)})"
|
|
361
|
+
)
|
|
362
|
+
|
|
363
|
+
click.echo()
|
|
364
|
+
click.echo("Retry Config:")
|
|
365
|
+
click.echo(f" Indices: {retry_info.indices}")
|
|
366
|
+
if retry_info.reslice_prefix:
|
|
367
|
+
click.echo(f" Reslice: {retry_info.reslice_prefix} ({retry_info.reslice_count} chunks)")
|
|
368
|
+
else:
|
|
369
|
+
click.echo(f" Reslice: No (retrying original chunks)")
|
|
370
|
+
|
|
371
|
+
if retry_info.batch_job_id:
|
|
372
|
+
click.echo()
|
|
373
|
+
click.echo("Batch:")
|
|
374
|
+
click.echo(f" AWS Job ID: {retry_info.batch_job_id}")
|
|
375
|
+
|
|
376
|
+
# Get live status from AWS Batch
|
|
377
|
+
_show_array_status(retry_info.batch_job_id)
|
|
378
|
+
|
|
379
|
+
click.echo()
|
|
380
|
+
click.echo("Next steps:")
|
|
381
|
+
click.echo(f" View logs: dh batch logs {manifest.job_id}")
|
|
382
|
+
click.echo(f" Parent status: dh batch status {manifest.job_id}")
|
|
@@ -19,7 +19,7 @@ dayhoff_tools/cli/batch/commands/list_jobs.py,sha256=COfxZddDVUAHeTayNAB3ruYNhgr
|
|
|
19
19
|
dayhoff_tools/cli/batch/commands/local.py,sha256=dZeKhNakaM1jS-EoByAwg1nWspRRoOmYzcwzjEKBaIA,3226
|
|
20
20
|
dayhoff_tools/cli/batch/commands/logs.py,sha256=ctgJksdzFmqBdD18ePPsZe2BpuJYtHz2xAaMPnUplmQ,5293
|
|
21
21
|
dayhoff_tools/cli/batch/commands/retry.py,sha256=JgOMiwuESNG4Wp_fQ_vxy1RwyOZPt_kmVbLYdxYTVBY,9897
|
|
22
|
-
dayhoff_tools/cli/batch/commands/status.py,sha256=
|
|
22
|
+
dayhoff_tools/cli/batch/commands/status.py,sha256=4kfii7mgtJKXWwZDsR4mtb_dQgCdryGkGEjNOpDxTT0,13404
|
|
23
23
|
dayhoff_tools/cli/batch/commands/submit.py,sha256=AXbvSReN8fLlzR5swE81pH7yvbCC1GUMCbsDrfoHAws,6786
|
|
24
24
|
dayhoff_tools/cli/batch/job_id.py,sha256=mqr8SwcPlUWIYLaR_C4kACmL2ZFK8jaddd7B-45-XaQ,4246
|
|
25
25
|
dayhoff_tools/cli/batch/manifest.py,sha256=eLyiOFXonAUh5rfHcXyR2CzmRKXQz9-tTbJcWnVbbmE,8857
|
|
@@ -71,7 +71,7 @@ dayhoff_tools/intake/uniprot.py,sha256=BZYJQF63OtPcBBnQ7_P9gulxzJtqyorgyuDiPeOJq
|
|
|
71
71
|
dayhoff_tools/logs.py,sha256=DKdeP0k0kliRcilwvX0mUB2eipO5BdWUeHwh-VnsICs,838
|
|
72
72
|
dayhoff_tools/sqlite.py,sha256=jV55ikF8VpTfeQqqlHSbY8OgfyfHj8zgHNpZjBLos_E,18672
|
|
73
73
|
dayhoff_tools/warehouse.py,sha256=UETBtZD3r7WgvURqfGbyHlT7cxoiVq8isjzMuerKw8I,24475
|
|
74
|
-
dayhoff_tools-1.14.
|
|
75
|
-
dayhoff_tools-1.14.
|
|
76
|
-
dayhoff_tools-1.14.
|
|
77
|
-
dayhoff_tools-1.14.
|
|
74
|
+
dayhoff_tools-1.14.12.dist-info/METADATA,sha256=Sfuw9gESP4Yfum_ySCZoxyuIFUybEcfGvywZaBSBy7c,3185
|
|
75
|
+
dayhoff_tools-1.14.12.dist-info/WHEEL,sha256=3ny-bZhpXrU6vSQ1UPG34FoxZBp3lVcvK0LkgUz6VLk,88
|
|
76
|
+
dayhoff_tools-1.14.12.dist-info/entry_points.txt,sha256=iAf4jteNqW3cJm6CO6czLxjW3vxYKsyGLZ8WGmxamSc,49
|
|
77
|
+
dayhoff_tools-1.14.12.dist-info/RECORD,,
|
|
File without changes
|
|
File without changes
|