Skip to content

Commit

Permalink
fix: allow to resume a running session
Browse files Browse the repository at this point in the history
  • Loading branch information
aneojgurhem committed Nov 26, 2024
1 parent b7646ca commit de4e7e1
Show file tree
Hide file tree
Showing 2 changed files with 6 additions and 16 deletions.
4 changes: 2 additions & 2 deletions Common/src/Storage/SessionTableExtensions.cs
Original file line number Diff line number Diff line change
Expand Up @@ -233,7 +233,7 @@ public static async Task<SessionData> ResumeSessionAsync(this ISessionTable sess
CancellationToken cancellationToken = default)
{
var session = await sessionTable.UpdateOneSessionAsync(sessionId,
data => data.Status == SessionStatus.Paused,
data => data.Status == SessionStatus.Paused || data.Status == SessionStatus.Running,
new UpdateDefinition<SessionData>().Set(model => model.Status,
SessionStatus.Running),
false,
Expand All @@ -251,8 +251,8 @@ public static async Task<SessionData> ResumeSessionAsync(this ISessionTable sess
switch (session.Status)
{
case SessionStatus.Paused:
throw new UnreachableException($"Session status should be {SessionStatus.Running} but is {session.Status}");
case SessionStatus.Running:
throw new UnreachableException($"Session status should be {SessionStatus.Running} but is {session.Status}");
case SessionStatus.Purged:
case SessionStatus.Cancelled:
throw new InvalidSessionTransitionException($"Cannot resume a session with status {session.Status}");
Expand Down
18 changes: 4 additions & 14 deletions Common/src/gRPC/Services/GrpcSessionsService.cs
Original file line number Diff line number Diff line change
Expand Up @@ -35,8 +35,6 @@
using Microsoft.AspNetCore.Authorization;
using Microsoft.Extensions.Logging;

using TaskStatus = ArmoniK.Core.Common.Storage.TaskStatus;

namespace ArmoniK.Core.Common.gRPC.Services;

[Authorize(AuthenticationSchemes = Authenticator.SchemeName)]
Expand Down Expand Up @@ -516,36 +514,28 @@ public override async Task<ResumeSessionResponse> ResumeSession(ResumeSessionReq
catch (SessionNotFoundException e)
{
logger_.LogWarning(e,
"Error while getting session");
"Error while resuming session");
throw new RpcException(new Status(StatusCode.NotFound,
"Session not found"));
}
catch (InvalidSessionTransitionException e)
{
logger_.LogWarning(e,
"Error while cancelling session");
"Error while resuming session");
throw new RpcException(new Status(StatusCode.FailedPrecondition,
"Session is in a state that cannot be cancelled"));
}
catch (ArmoniKException e)
{
logger_.LogWarning(e,
"Error while getting session");
await taskTable_.UpdateManyTasks(data => data.SessionId == request.SessionId && data.Status == TaskStatus.Submitted,
new UpdateDefinition<TaskData>().Set(data => data.Status,
TaskStatus.Paused))
.ConfigureAwait(false);
"Error while resuming session");
throw new RpcException(new Status(StatusCode.Internal,
"Internal Armonik Exception, see application logs"));
}
catch (Exception e)
{
logger_.LogWarning(e,
"Error while getting session");
await taskTable_.UpdateManyTasks(data => data.SessionId == request.SessionId && data.Status == TaskStatus.Submitted,
new UpdateDefinition<TaskData>().Set(data => data.Status,
TaskStatus.Paused))
.ConfigureAwait(false);
"Error while resuming session");
throw new RpcException(new Status(StatusCode.Unknown,
"Unknown Exception, see application logs"));
}
Expand Down

0 comments on commit de4e7e1

Please sign in to comment.