From cfc284bbe9c54aa7da5de77d2f49994385bdf1ec Mon Sep 17 00:00:00 2001 From: Martin Kouba Date: Tue, 10 Nov 2020 09:20:13 +0100 Subject: [PATCH] Quartz - replace Arc.container() with Instance - so that the UserTransaction is not removed if no other injection point exists --- .../java/io/quarkus/quartz/runtime/QuartzScheduler.java | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/extensions/quartz/runtime/src/main/java/io/quarkus/quartz/runtime/QuartzScheduler.java b/extensions/quartz/runtime/src/main/java/io/quarkus/quartz/runtime/QuartzScheduler.java index b51588818b611..9d8cbc48a768b 100644 --- a/extensions/quartz/runtime/src/main/java/io/quarkus/quartz/runtime/QuartzScheduler.java +++ b/extensions/quartz/runtime/src/main/java/io/quarkus/quartz/runtime/QuartzScheduler.java @@ -79,7 +79,8 @@ org.quartz.Scheduler produceQuartzScheduler() { } public QuartzScheduler(SchedulerContext context, QuartzSupport quartzSupport, Config config, - SchedulerRuntimeConfig schedulerRuntimeConfig, Event skippedExecutionEvent, Instance jobs) { + SchedulerRuntimeConfig schedulerRuntimeConfig, Event skippedExecutionEvent, Instance jobs, + Instance userTransation) { enabled = schedulerRuntimeConfig.enabled; if (!enabled) { LOGGER.info("Quartz scheduler is disabled by config property and will not be started"); @@ -92,10 +93,10 @@ public QuartzScheduler(SchedulerContext context, QuartzSupport quartzSupport, Co Map invokers = new HashMap<>(); UserTransaction transaction = null; - try (InstanceHandle handle = Arc.container().instance(UserTransaction.class)) { + try { boolean manageTx = quartzSupport.getBuildTimeConfig().storeType.isNonManagedTxJobStore(); - if (manageTx && handle.isAvailable()) { - transaction = handle.get(); + if (manageTx && userTransation.isResolvable()) { + transaction = userTransation.get(); } Properties props = getSchedulerConfigurationProperties(quartzSupport);