From c0fdc2ed48291983dd3337d979fbb48c42578d9d Mon Sep 17 00:00:00 2001 From: victorskl Date: Thu, 18 May 2017 04:10:25 +1000 Subject: [PATCH] Same patch fix as BullyElectionManagementService startWaitingTimer --- .../FastBullyElectionManagementService.java | 34 ++++++++++++++++--- 1 file changed, 29 insertions(+), 5 deletions(-) diff --git a/strike-server/src/main/java/strike/service/election/FastBullyElectionManagementService.java b/strike-server/src/main/java/strike/service/election/FastBullyElectionManagementService.java index df96881..36f83f2 100644 --- a/strike-server/src/main/java/strike/service/election/FastBullyElectionManagementService.java +++ b/strike-server/src/main/java/strike/service/election/FastBullyElectionManagementService.java @@ -46,11 +46,35 @@ public void setAnswerReceivedFlag() { public void resetWaitingForCoordinatorMessageTimer(JobExecutionContext context, TriggerKey triggerKey, Long timeout) { try { - Trigger simpleTrigger = TriggerBuilder.newTrigger() - .withIdentity("election_trigger", "group_fast_bully") - .startAt(DateBuilder.futureDate(Math.toIntExact(timeout), DateBuilder.IntervalUnit.SECOND)) - .build(); - context.getScheduler().rescheduleJob(triggerKey, simpleTrigger); + JobDetail jobDetail = context.getJobDetail(); + if (scheduler.checkExists(jobDetail.getKey())) { + + logger.debug(String.format("Job get trigger again [%s]", jobDetail.getKey().getName())); + scheduler.triggerJob(jobDetail.getKey()); + + } else { + + Trigger simpleTrigger = TriggerBuilder.newTrigger() + .withIdentity("election_trigger", "group_fast_bully") + .startAt(DateBuilder.futureDate(Math.toIntExact(timeout), DateBuilder.IntervalUnit.SECOND)) + .build(); + context.getScheduler().rescheduleJob(triggerKey, simpleTrigger); + } + + } catch (ObjectAlreadyExistsException oe) { + logger.debug(oe.getLocalizedMessage()); + + try { + + JobDetail jobDetail = context.getJobDetail(); + logger.debug(String.format("Job get trigger again [%s]", jobDetail.getKey().getName())); + + scheduler.triggerJob(jobDetail.getKey()); + + } catch (SchedulerException e) { + e.printStackTrace(); + } + } catch (SchedulerException e) { e.printStackTrace(); }