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 b51588818b611d..9d8cbc48a768b0 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);