NOTE: This comes from spring-projects/spring-boot#50623 which suggests to open the ticket here instead
With Spring Boot 4.x, having the com.oracle.database.jdbc:ojdbcX dependency in the project results in a failure to run the processAot task.
I'm specifically on com.oracle.database.jdbc:ojdbc11:23.26.2.0.0, but it happens with ojdbc17 as well.
This same library on Spring Boot 3.x isn't causing any issues.
Trying to work around it by adding com.oracle.database.ha:simplefan:23.26.2.0.0 just compounds on the issue as it then breaks and demands for another library, com.oracle.database.xml:xdb:23.26.2.0.0, which then breaks and demands for yet another, and so on and so forth -- all on libraries that I explicitly do not want on the project.
This is tested on Open JDK 17 and 21, both having the same issue.
I'm mentioning the JDK flavor here in particular because it seems Quarkus had a somewhat-similar issue in the past and blamed that, but this didn't help me here -- graalvm/mandrel#252
Exception stacktrace:
Exception in thread "main" org.springframework.beans.factory.aot.AotBeanProcessingException: Error processing bean with name 'myRepository' defined in com.foo.bar.MyRepository defined in @EnableJpaRepositories declared on DataJpaRepositoriesRegistrar.EnableJpaRepositoriesConfiguration: failed to generate code for bean definition
at org.springframework.beans.factory.aot.BeanRegistrationsAotContribution$BeanDefinitionsRegistrationGenerator.lambda$generateRegisterBeanDefinitionMethods$0(BeanRegistrationsAotContribution.java:280)
at java.base/java.lang.Iterable.forEach(Iterable.java:75)
at org.springframework.beans.factory.aot.BeanRegistrationsAotContribution$BeanDefinitionsRegistrationGenerator.generateRegisterBeanDefinitionMethods(BeanRegistrationsAotContribution.java:270)
at org.springframework.beans.factory.aot.BeanRegistrationsAotContribution$BeanDefinitionsRegistrationGenerator.generateBeanRegistrationsCode(BeanRegistrationsAotContribution.java:238)
at org.springframework.beans.factory.aot.BeanRegistrationsAotContribution.lambda$generateBeanRegistrationClass$0(BeanRegistrationsAotContribution.java:116)
at org.springframework.aot.generate.GeneratedMethod.<init>(GeneratedMethod.java:54)
at org.springframework.aot.generate.GeneratedMethods.add(GeneratedMethods.java:112)
at org.springframework.aot.generate.GeneratedMethods.add(GeneratedMethods.java:89)
at org.springframework.beans.factory.aot.BeanRegistrationsAotContribution.generateBeanRegistrationClass(BeanRegistrationsAotContribution.java:110)
at org.springframework.beans.factory.aot.BeanRegistrationsAotContribution.generateBeanRegistrationCode(BeanRegistrationsAotContribution.java:88)
at org.springframework.beans.factory.aot.BeanRegistrationsAotContribution.applyTo(BeanRegistrationsAotContribution.java:77)
at org.springframework.context.aot.BeanFactoryInitializationAotContributions.applyTo(BeanFactoryInitializationAotContributions.java:94)
at org.springframework.context.aot.ApplicationContextAotGenerator.lambda$processAheadOfTime$0(ApplicationContextAotGenerator.java:59)
at org.springframework.context.aot.ApplicationContextAotGenerator.withCglibClassHandler(ApplicationContextAotGenerator.java:68)
at org.springframework.context.aot.ApplicationContextAotGenerator.processAheadOfTime(ApplicationContextAotGenerator.java:54)
at org.springframework.context.aot.ContextAotProcessor.performAotProcessing(ContextAotProcessor.java:107)
at org.springframework.context.aot.ContextAotProcessor.doProcess(ContextAotProcessor.java:84)
at org.springframework.context.aot.ContextAotProcessor.doProcess(ContextAotProcessor.java:49)
at org.springframework.context.aot.AbstractAotProcessor.process(AbstractAotProcessor.java:84)
at org.springframework.boot.SpringApplicationAotProcessor.main(SpringApplicationAotProcessor.java:96)
Caused by: java.lang.IllegalStateException: Failed to introspect Class [oracle.jdbc.driver.HAManager] from ClassLoader [jdk.internal.loader.ClassLoaders$AppClassLoader@5a07e868]
at org.springframework.util.ReflectionUtils.getDeclaredFields(ReflectionUtils.java:756)
at org.springframework.util.ReflectionUtils.doWithLocalFields(ReflectionUtils.java:689)
at org.springframework.data.util.TypeCollector.visitFieldsOfType(TypeCollector.java:284)
at org.springframework.data.util.TypeCollector.processType(TypeCollector.java:221)
at org.springframework.data.util.TypeCollector.processType(TypeCollector.java:228)
at org.springframework.data.util.TypeCollector.processType(TypeCollector.java:228)
at org.springframework.data.util.TypeCollector.processType(TypeCollector.java:228)
at org.springframework.data.util.TypeCollector.processType(TypeCollector.java:228)
at org.springframework.data.util.TypeCollector.processType(TypeCollector.java:228)
at org.springframework.data.util.TypeCollector.processType(TypeCollector.java:228)
at org.springframework.data.util.TypeCollector.processType(TypeCollector.java:228)
at org.springframework.data.util.TypeCollector.processType(TypeCollector.java:228)
at org.springframework.data.util.TypeCollector.processType(TypeCollector.java:228)
at org.springframework.data.util.TypeCollector.process(TypeCollector.java:201)
at org.springframework.data.util.TypeCollector$ReachableTypes.lambda$forEach$0(TypeCollector.java:321)
at java.base/java.lang.Iterable.forEach(Iterable.java:75)
at org.springframework.data.util.TypeCollector$ReachableTypes.forEach(TypeCollector.java:321)
at org.springframework.data.util.TypeCollector$ReachableTypes.collect(TypeCollector.java:335)
at org.springframework.data.util.Lazy.getNullable(Lazy.java:136)
at org.springframework.data.util.Lazy.get(Lazy.java:114)
at org.springframework.data.util.TypeCollector$ReachableTypes.list(TypeCollector.java:330)
at org.springframework.data.repository.config.DefaultAotRepositoryContext.discoverTypes(DefaultAotRepositoryContext.java:138)
at org.springframework.data.util.Lazy.getNullable(Lazy.java:136)
at org.springframework.data.util.Lazy.get(Lazy.java:114)
at org.springframework.data.repository.config.DefaultAotRepositoryContext.getResolvedTypes(DefaultAotRepositoryContext.java:106)
at org.springframework.data.repository.config.RepositoryRegistrationAotProcessor.configureDomainTypeContributions(RepositoryRegistrationAotProcessor.java:260)
at org.springframework.data.repository.config.RepositoryRegistrationAotProcessor.configureTypeContributions(RepositoryRegistrationAotProcessor.java:223)
at org.springframework.data.jpa.repository.config.JpaRepositoryConfigExtension$JpaRepositoryRegistrationAotProcessor.configureTypeContributions(JpaRepositoryConfigExtension.java:394)
at org.springframework.data.repository.config.RepositoryRegistrationAotProcessor.lambda$processAheadOfTime$0(RepositoryRegistrationAotProcessor.java:166)
at org.springframework.data.repository.config.RepositoryRegistrationAotContribution.applyTo(RepositoryRegistrationAotContribution.java:63)
at org.springframework.beans.factory.aot.BeanDefinitionMethodGenerator.lambda$generateBeanDefinitionMethod$0(BeanDefinitionMethodGenerator.java:165)
at java.base/java.util.ArrayList.forEach(ArrayList.java:1596)
at org.springframework.beans.factory.aot.BeanDefinitionMethodGenerator.generateBeanDefinitionMethod(BeanDefinitionMethodGenerator.java:165)
at org.springframework.beans.factory.aot.BeanDefinitionMethodGenerator.generateBeanDefinitionMethod(BeanDefinitionMethodGenerator.java:89)
at org.springframework.beans.factory.aot.BeanRegistrationsAotContribution$BeanDefinitionsRegistrationGenerator.generateBeanRegistration(BeanRegistrationsAotContribution.java:289)
at org.springframework.beans.factory.aot.BeanRegistrationsAotContribution$BeanDefinitionsRegistrationGenerator.lambda$generateRegisterBeanDefinitionMethods$0(BeanRegistrationsAotContribution.java:272)
... 19 more
Caused by: java.lang.NoClassDefFoundError: oracle/simplefan/FanManager
at java.base/java.lang.Class.getDeclaredFields0(Native Method)
at java.base/java.lang.Class.privateGetDeclaredFields(Class.java:3475)
at java.base/java.lang.Class.getDeclaredFields(Class.java:2544)
at org.springframework.util.ReflectionUtils.getDeclaredFields(ReflectionUtils.java:751)
... 54 more
Caused by: java.lang.ClassNotFoundException: oracle.simplefan.FanManager
at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:641)
at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:188)
at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:526)
... 58 more
With Spring Boot 4.x, having the
com.oracle.database.jdbc:ojdbcXdependency in the project results in a failure to run theprocessAottask.I'm specifically on
com.oracle.database.jdbc:ojdbc11:23.26.2.0.0, but it happens withojdbc17as well.This same library on Spring Boot 3.x isn't causing any issues.
Trying to work around it by adding
com.oracle.database.ha:simplefan:23.26.2.0.0just compounds on the issue as it then breaks and demands for another library,com.oracle.database.xml:xdb:23.26.2.0.0, which then breaks and demands for yet another, and so on and so forth -- all on libraries that I explicitly do not want on the project.This is tested on Open JDK 17 and 21, both having the same issue.
I'm mentioning the JDK flavor here in particular because it seems Quarkus had a somewhat-similar issue in the past and blamed that, but this didn't help me here -- graalvm/mandrel#252
Exception stacktrace: