Fetch information about a task. This is much more detailed than
the information in task_status
. If a task is running we also
fetch the true status via its driver, which can be slower.
Value
An object of class hipercow_task_info
, which will print
nicely. This is just a list with elements:
id
: the task identifierstatus
: the retrieved statusdriver
: the driver used to run the task (or NA)data
: the task data (depends on the type of task)times
: a vector of timesretry_chain
: the retry chain (orNULL
)
You can see and access these elements more easily by running
unclass()
on the result of task_info()
.
Examples
cleanup <- hipercow_example_helper()
#> ℹ This example uses a special helper
id <- task_create_expr(runif(1))
#> ✔ Submitted task 'ddfd04c459d3fad132857c38eeab9c6b' using 'example'
task_wait(id)
#> [1] TRUE
# Task information at completion includes times:
task_info(id)
#>
#> ── task ddfd04c459d3fad132857c38eeab9c6b (success) ─────────────────────────────
#> ℹ Submitted with 'example'
#> ℹ Task type: expression
#> • Expression: runif(1)
#> • Locals: (none)
#> • Environment: default
#> R_GC_MEM_GROW: 3
#> ℹ Created at 2025-03-28 15:19:42.059453 (moments ago)
#> ℹ Started at 2025-03-28 15:19:42.2323 (moments ago; waited 173ms)
#> ℹ Finished at 2025-03-28 15:19:42.318871 (moments ago; ran for 87ms)
# If you need to work with these times, use the "times" element:
task_info(id)$times
#> created started finished
#> "2025-03-28 15:19:42 UTC" "2025-03-28 15:19:42 UTC" "2025-03-28 15:19:42 UTC"
# If a task is retried, this information appears as a retry chain:
id2 <- task_retry(id)
#> ✔ Submitted task '09536a63e9ae605fbce8a8f76413fdb9' using 'example'
task_info(id2, follow = FALSE)
#>
#> ── task 09536a63e9ae605fbce8a8f76413fdb9 (submitted) ───────────────────────────
#> ℹ Submitted with 'example'
#> ℹ Task type: expression
#> • Expression: runif(1)
#> • Locals: (none)
#> • Environment: default
#> R_GC_MEM_GROW: 3
#> ℹ Created at 2025-03-28 15:19:42.059453 (moments ago)
#> ! Not started yet (waiting for 1.1s)
#> ! Not finished yet (waiting to start)
#> ℹ Last of a chain of a task retried 1 time
task_info(id2)
#>
#> ── task 09536a63e9ae605fbce8a8f76413fdb9 (submitted) ───────────────────────────
#> ℹ Submitted with 'example'
#> ℹ Task type: expression
#> • Expression: runif(1)
#> • Locals: (none)
#> • Environment: default
#> R_GC_MEM_GROW: 3
#> ℹ Created at 2025-03-28 15:19:42.059453 (moments ago)
#> ! Not started yet (waiting for 1.2s)
#> ! Not finished yet (waiting to start)
#> ℹ Last of a chain of a task retried 1 time
cleanup()
#> ℹ Cleaning up example