Wait for a single task to complete (or to start). This function is very similar to task_log_watch, except that it errors if the task does not complete (so that it can be used easily to ensure a task has completed) and does not return any logs.
Usage
task_wait(
id,
for_start = FALSE,
timeout = NULL,
poll = 1,
progress = NULL,
follow = TRUE,
root = NULL
)
Arguments
- id
The task identifier
- for_start
Logical value, indicating if we only want to wait for the task to start rather than complete. This will block until the task moves away from
submitted
, and will return when it takes the statusrunning
or any terminal status (success
,failure
,cancelled
). Note that this does not guarantee that your task will still be running by the timetask_wait
exits, your task may have finished by then!- timeout
The time to wait for the task to complete. The default is to wait forever.
- poll
Time, in seconds, used to throttle calls to the status function. The default is 1 second
- progress
Logical value, indicating if a progress spinner should be used. The default
NULL
uses the optionhipercow.progress
, and if unset displays a progress bar in an interactive session.- 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.
Details
The progress spinners here come from the cli package and will
respond to cli's options. In particular cli.progress_clear
and
cli.progress_show_after
.
Examples
cleanup <- hipercow_example_helper()
#> ℹ This example uses a special helper
id <- task_create_expr(sqrt(2))
#> ✔ Submitted task 'b4e860a7446c4b8d92568681cc24d667' using 'example'
task_wait(id)
#> [1] TRUE
cleanup()
#> ℹ Cleaning up example