< Summary

Information
Class: Elsa.Workflows.Runtime.Tasks.RestartInterruptedWorkflowsTask
Assembly: Elsa.Workflows.Runtime
File(s): /home/runner/work/elsa-core/elsa-core/src/modules/Elsa.Workflows.Runtime/Tasks/RestartInterruptedWorkflowsTask.cs
Line coverage
95%
Covered lines: 21
Uncovered lines: 1
Coverable lines: 22
Total lines: 47
Line coverage: 95.4%
Branch coverage
50%
Covered branches: 1
Total branches: 2
Branch coverage: 50%
Method coverage

Feature is only available for sponsors

Upgrade to PRO version

Metrics

MethodBranch coverage Crap Score Cyclomatic complexity Line coverage
.ctor(...)100%11100%
ExecuteAsync()50%2287.5%
CreateWorkflowInstanceFilter()100%11100%

File(s)

/home/runner/work/elsa-core/elsa-core/src/modules/Elsa.Workflows.Runtime/Tasks/RestartInterruptedWorkflowsTask.cs

#LineLine coverage
 1using Elsa.Common;
 2using Elsa.Common.RecurringTasks;
 3using Elsa.Workflows.Management;
 4using Elsa.Workflows.Management.Filters;
 5using Elsa.Workflows.Runtime.Options;
 6using JetBrains.Annotations;
 7using Microsoft.Extensions.Logging;
 8using Microsoft.Extensions.Options;
 9
 10namespace Elsa.Workflows.Runtime.Tasks;
 11
 12[SingleNodeTask]
 13[UsedImplicitly]
 1114public class RestartInterruptedWorkflowsTask(
 1115    IWorkflowInstanceStore workflowInstanceStore,
 1116    IWorkflowRestarter workflowRestarter,
 1117    IOptions<RuntimeOptions> options,
 1118    ISystemClock systemClock,
 1119    ILogger<RestartInterruptedWorkflowsTask> logger) : RecurringTask
 20{
 21    /// <inheritdoc />
 22    public override async Task ExecuteAsync(CancellationToken cancellationToken)
 23    {
 1624        var workflowInstanceFilter = CreateWorkflowInstanceFilter();
 1625        var batchSize = options.Value.RestartInterruptedWorkflowsBatchSize;
 1626        var workflowInstances = workflowInstanceStore.EnumerateSummariesAsync(workflowInstanceFilter, batchSize, cancell
 27
 1628        logger.LogInformation("Restarting interrupted workflows.");
 3229        await foreach (var workflowInstance in workflowInstances)
 30        {
 031            await workflowRestarter.RestartWorkflowAsync(workflowInstance.Id, cancellationToken: cancellationToken);
 32        }
 1633        logger.LogInformation("Finished restarting interrupted workflows.");
 1634    }
 35
 36    private WorkflowInstanceFilter CreateWorkflowInstanceFilter()
 37    {
 1638        var livenessThreshold = options.Value.InactivityThreshold;
 1639        var now = systemClock.UtcNow;
 1640        var cutoffTimestamp = now - livenessThreshold;
 1641        return new()
 1642        {
 1643            IsExecuting = true,
 1644            BeforeLastUpdated = cutoffTimestamp
 1645        };
 46    }
 47}