Now I've succeeded in having the custom logger picked up when running in the unit tests.
What I did to fix this, was to ensure that the getPriority() method of my logger returned a high number:
- package liquibase.ext.logging;
- import liquibase.logging.core.AbstractLogger;
- public class UkelonnLiquibaseLogger extends AbstractLogger {
- ...
- /**
- * The value returned here will determine if liquibase is to use this logger.
- * If the value is too low, liquibase will use the default logger.
- */
- @Override
- public int getPriority() {
- return Integer.MAX_VALUE;
- }
- }
Now this works for me in the unit tests.
However, in the OSGi context liquibase still logs to the console. This happens both in the karaf-based pax exam tests, and in apache karaf itself.
I have exported the liquibase.ext.logger package from the OSGi bundle the UkelonnLiquibaseLogger is implemented in.
FYI The reason I picked ClassLoaderResourceAccessor over the OSGiResourceAccessor, was that I couldn't figure out how to make the OSGiResourceAccessor work in the unit tests, and the ClassLoaderResourceAccessor with the class loader set explicitly, finds the database changeset files both when running in unit tests and when running in OSGi.