ResultSet::TaskRetries: add missing method, get_retryable_task

Yet again, manual testing is proving to be insufficient. I'm pretty
sure I wrote this code but lost it in a rebase, or perhaps the switch
to result classes.

At any rate, this implements the actual "fetch a retry row and run it"
for the hydra-notify daemon.

Tested by hand.
This commit is contained in:
Graham Christensen
2021-09-07 10:56:52 -04:00
parent d6aa3f8d15
commit b1879132af
3 changed files with 90 additions and 4 deletions

View File

@ -68,4 +68,47 @@ sub save_task {
});
}
=head2 get_retryable_task
=cut
sub get_retryable_task {
my ($self) = @_;
my $row = $self->get_retryable_taskretries_row();
if (!defined($row)) {
return undef;
}
my $event = Hydra::Event->new_event(
$row->get_column("channel"),
$row->get_column("payload")
);
my $task = Hydra::Task->new($event, $row->get_column("pluginname"));
$task->{"record"} = $row;
return $task;
}
=head2 get_retryable_taskretries_row
Fetch the next task to retry.
=cut
sub get_retryable_taskretries_row {
my ($self) = @_;
my $next_retry = $self->search(
{
'retry_at' => { '<=', time() }
}, # any task
{
order_by => {
-asc => 'retry_at'
},
rows => 1,
}
)->first;
}
1;

View File

@ -131,9 +131,8 @@ while (!$queued_only) {
}
}
my $task = $taskretries->getRetryableTask();
my $task = $taskretries->get_retryable_task();
if (defined($task)) {
$task_dispatcher->dispatchTask($task);
$task_dispatcher->dispatch_task($task);
}
}