NoSuchMethodException when generating offline Oracle migration script

Description

Since upgrading from Liquibase 3.3.1 to 3.3.2 I can no longer generate an offline Oracle migration script using the liquibase-maven-plugin. Other database types seem to be unaffected. A quick search on JIRA suggests that this might be related to the fix for CORE-2174.

Maven returns the following error message:
Failed to execute goal org.liquibase:liquibase-maven-plugin:3.3.2:updateSQL (liquibase-oracle-offline) on project liquibase-test: Error setting up or running Liquibase: liquibase.exception.UnexpectedLiquibaseException: java.lang.NoSuchMethodException: liquibase.database.OfflineConnection.getWrappedConnection()

The relevant section from the POM is as follows:
<plugin>
<groupId>org.liquibase</groupId>
<artifactId>liquibase-maven-plugin</artifactId>
<version>3.3.2</version>
<executions>
<execution>
<id>liquibase-oracle-offline</id>
<configuration>
<changeLogFile>src/main/resources/liquibase/db-changelog-master.xml</changeLogFile>
<url>offline:oracle</url>
<migrationSqlOutputFile>${project.build.directory}/liquibase/oracle/migrate.sql</migrationSqlOutputFile>
<outputFileEncoding>UTF-8</outputFileEncoding>
</configuration>
<phase>process-resources</phase>
<goals>
<goal>updateSQL</goal>
</goals>
</execution>
</executions>
</plugin>

The full stacktrace provided by Maven is as follows:
org.apache.maven.lifecycle.LifecycleExecutionException: Failed to execute goal org.liquibase:liquibase-maven-plugin:3.3.2:updateSQL (liquibase-oracle-offline) on project liquibase-test: Error setting up or running Liquibase: liquibase.exception.UnexpectedLiquibaseException: java.lang.NoSuchMethodException: liquibase.database.OfflineConnection.getWrappedConnection()
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:216)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:153)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:145)
at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:84)
at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:59)
at org.apache.maven.lifecycle.internal.LifecycleStarter.singleThreadedBuild(LifecycleStarter.java:183)
at org.apache.maven.lifecycle.internal.LifecycleStarter.execute(LifecycleStarter.java:161)
at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:317)
at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:152)
at org.apache.maven.cli.MavenCli.execute(MavenCli.java:555)
at org.apache.maven.cli.MavenCli.doMain(MavenCli.java:214)
at org.apache.maven.cli.MavenCli.main(MavenCli.java:158)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
at org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced(Launcher.java:289)
at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:229)
at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.java:415)
at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java:356)
Caused by: org.apache.maven.plugin.MojoExecutionException: Error setting up or running Liquibase: liquibase.exception.UnexpectedLiquibaseException: java.lang.NoSuchMethodException: liquibase.database.OfflineConnection.getWrappedConnection()
at org.liquibase.maven.plugins.AbstractLiquibaseMojo.execute(AbstractLiquibaseMojo.java:373)
at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.java:106)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:208)
... 19 more
Caused by: liquibase.exception.DatabaseException: liquibase.exception.UnexpectedLiquibaseException: java.lang.NoSuchMethodException: liquibase.database.OfflineConnection.getWrappedConnection()
at liquibase.integration.commandline.CommandLineUtils.createDatabaseObject(CommandLineUtils.java:69)
at org.liquibase.maven.plugins.AbstractLiquibaseMojo.execute(AbstractLiquibaseMojo.java:321)
... 21 more
Caused by: liquibase.exception.UnexpectedLiquibaseException: java.lang.NoSuchMethodException: liquibase.database.OfflineConnection.getWrappedConnection()
at liquibase.database.core.OracleDatabase.setConnection(OracleDatabase.java:62)
at liquibase.database.DatabaseFactory.findCorrectDatabaseImplementation(DatabaseFactory.java:123)
at liquibase.database.DatabaseFactory.openDatabase(DatabaseFactory.java:143)
at liquibase.integration.commandline.CommandLineUtils.createDatabaseObject(CommandLineUtils.java:50)
... 22 more
Caused by: java.lang.NoSuchMethodException: liquibase.database.OfflineConnection.getWrappedConnection()
at java.lang.Class.getMethod(Class.java:1665)
at liquibase.database.core.OracleDatabase.setConnection(OracleDatabase.java:58)
... 25 more

Environment

Windows Server 2003, Maven 3.1.1, Java 1.7.0_45

Activity

Show:

Nathan Voxland March 10, 2015 at 9:21 PM

JoãoM February 25, 2015 at 12:13 PM
Edited

Hope this is fixed in 3.3.3, I decided to apply the patch to the 3.3.2 tag and release a special version to a local repository because this offline thing suits me just fine.

Paul Mendelson January 14, 2015 at 8:04 PM

I don't use maven but I am having the same problem. In previous versions I got the warning

"INFO 1/14/15 3:00 PM: liquibase: Could not set remarks reporting on OracleDatabase: com.smdi.dbtools.lifecycle.utils.SchemaManagerOfflineConnection.getWrappedConnection()"

Now I blow up.

Fixed

Details

Reporter

Components

Fix versions

Affects versions

Priority

Created January 13, 2015 at 6:29 PM
Updated March 10, 2015 at 9:21 PM
Resolved March 10, 2015 at 9:21 PM