From 0e4307059b9c6d2c1deaf9a2f38fe83de340ae3d Mon Sep 17 00:00:00 2001 From: Stanislav Trailov Date: Fri, 27 Dec 2024 11:53:52 +0200 Subject: [PATCH] Fix pause of rollout on error condition (#2161) Signed-off-by: TRS1SF3 --- .../rollout/condition/PauseRolloutGroupAction.java | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/hawkbit-repository/hawkbit-repository-jpa/src/main/java/org/eclipse/hawkbit/repository/jpa/rollout/condition/PauseRolloutGroupAction.java b/hawkbit-repository/hawkbit-repository-jpa/src/main/java/org/eclipse/hawkbit/repository/jpa/rollout/condition/PauseRolloutGroupAction.java index 23d50aadb4..6cd945f7cc 100644 --- a/hawkbit-repository/hawkbit-repository-jpa/src/main/java/org/eclipse/hawkbit/repository/jpa/rollout/condition/PauseRolloutGroupAction.java +++ b/hawkbit-repository/hawkbit-repository-jpa/src/main/java/org/eclipse/hawkbit/repository/jpa/rollout/condition/PauseRolloutGroupAction.java @@ -43,12 +43,23 @@ public RolloutGroup.RolloutGroupErrorAction getAction() { @Override public void exec(final Rollout rollout, final RolloutGroup rolloutG) { + + /* + refresh latest rollout state in order to escape cases when + previous group have matched error condition and paused the rollout + and this one tries to pause the rollout too but throws an exception + and rollbacks rollout processing transaction + */ + Rollout refreshedRollout = rolloutManagement.get(rollout.getId()).orElseThrow(); final JpaRolloutGroup rolloutGroup = (JpaRolloutGroup) rolloutG; systemSecurityContext.runAsSystem(() -> { rolloutGroup.setStatus(RolloutGroupStatus.ERROR); rolloutGroupRepository.save(rolloutGroup); - rolloutManagement.pauseRollout(rollout.getId()); + if (Rollout.RolloutStatus.PAUSED != refreshedRollout.getStatus()) { + // if only the latest state is != paused then pause + rolloutManagement.pauseRollout(rollout.getId()); + } return null; }); }