Skip to contents

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.

Usage

task_info(id, follow = TRUE, root = NULL)

Arguments

id

A single task id to fetch information for

follow

Logical, indicating if we should follow any retried tasks.

root

A hipercow root, or path to it. If NULL we search up your directory tree.

Value

An object of class hipercow_task_info, which will print nicely. This is just a list with elements:

  • id: the task identifier

  • status: the retrieved status

  • driver: the driver used to run the task (or NA)

  • data: the task data (depends on the type of task)

  • times: a vector of times

  • retry_chain: the retry chain (or NULL)

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