如何配置gradle以使用logback-classic仅适用于Android中的单元测试? [英] How to configure gradle to use logback-classic ONLY for unit tests in Android?
问题描述
我有一个使用slf4j + logback的Android应用程序。
Gradle文件如下所示:
I have an Android app thich uses slf4j + logback. Gradle file looks like this:
...
compile('com.github.tony19:logback-android-core:1.1.1-6') {
exclude group: 'ch.qos.logback.core.net'
}
compile('com.github.tony19:logback-android-classic:1.1.1-6') {
exclude group: 'ch.qos.logback.core.net'
}
compile 'org.slf4j:slf4j-api:1.7.25'
我在资产中有logback.xml /。当我按预期运行应用程序日志记录工作时。最近我决定添加新的单元测试(常规的,而不是android单元测试),但是我看到日志消息没有显示。
And I have logback.xml in assets/. When I run the app logging work as expected. Recently I've decided to add new unit tests (regular, not android unit tests) but I saw that log messages are not shown.
我添加了以下内容gragle file:
I've added following to the gragle file:
testCompile('ch.qos.logback:logback-classic:1.2.3') {
exclude group: 'com.github.tony19'
}
现在显示日志消息但是在单元测试的每一次运行中,我都会得到这样的警告:
and now log messages are shown but on each run of the unit tests I get this warning:
SLF4J: Class path contains multiple SLF4J bindings.
SLF4J: Found binding in [jar:file:/home/o/.gradle/caches/modules-2/files-2.1/ch.qos.logback/logback-classic/1.2.3/7c4f3c474fb2c041d8028740440937705ebb473a/logback-classic-1.2.3.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in [jar:file:/home/o/.gradle/caches/modules-2/files-2.1/com.github.tony19/logback-android-classic/1.1.1-6/614c66c9ece69eef48c65a8558de4fd7266d9f69/logback-android-classic-1.1.1-6.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation.
有没有一种方法可以指定哪些slf4j绑定用于常规应用程序运行,单元测试(或任何其他解决方案)?
Is there a way to specify exclusively which slf4j binding to be used for the regular app runs and which for unit tests only (or any other solution)?
依赖关系图:
Dependencies graph:
compile - Classpath for compiling the main sources.
+--- com.bolyartech.forge.android:forge-android:7.1.0
| +--- com.bolyartech.forge:base:5.1.0
| | +--- org.slf4j:slf4j-api:1.7.7 -> 1.7.25
| | +--- com.darwinsys:hirondelle-date4j:1.5.1
| | +--- com.google.guava:guava:20.0
| | +--- javax.inject:javax.inject:1
| | \--- com.squareup.okhttp3:okhttp:3.1.2
| | \--- com.squareup.okio:okio:1.6.0
| +--- com.google.dagger:dagger:2.9
| | \--- javax.inject:javax.inject:1
| +--- com.android.support:support-annotations:25.3.1 -> 26.0.1
| +--- javax.annotation:jsr250-api:1.0
| +--- com.android.support.test.espresso:espresso-idling-resource:2.2.2
| \--- net.sourceforge.streamsupport:streamsupport:1.5.1
+--- com.bolyartech.scram_sasl:scram_sasl:2.0.1
+--- com.android.support:multidex:1.0.1
+--- com.squareup:otto:1.3.8
+--- com.google.code.gson:gson:2.7
+--- com.github.franmontiel:PersistentCookieJar:v0.9.3
| \--- com.squareup.okhttp3:okhttp:3.1.2 (*)
+--- com.github.tony19:logback-android-core:1.1.1-6
+--- com.github.tony19:logback-android-classic:1.1.1-6
| +--- com.github.tony19:logback-android-core:1.1.1-6
| \--- com.github.tony19:apktool-lib:1.4.4-3
| \--- com.google.android:android:2.1_r1
| +--- commons-logging:commons-logging:1.1.1
| +--- org.apache.httpcomponents:httpclient:4.0.1
| | +--- org.apache.httpcomponents:httpcore:4.0.1
| | +--- commons-logging:commons-logging:1.1.1
| | \--- commons-codec:commons-codec:1.3
| +--- org.khronos:opengl-api:gl1.1-android-2.1_r1
| +--- xerces:xmlParserAPIs:2.6.2
| \--- xpp3:xpp3:1.1.4c
+--- ch.acra:acra:4.7.0
| \--- com.android.support:support-v4:23.0.1 -> 26.0.1
| +--- com.android.support:support-compat:26.0.1
| | \--- com.android.support:support-annotations:26.0.1
| +--- com.android.support:support-media-compat:26.0.1
| | +--- com.android.support:support-annotations:26.0.1
| | \--- com.android.support:support-compat:26.0.1 (*)
| +--- com.android.support:support-core-utils:26.0.1
| | +--- com.android.support:support-annotations:26.0.1
| | \--- com.android.support:support-compat:26.0.1 (*)
| +--- com.android.support:support-core-ui:26.0.1
| | +--- com.android.support:support-annotations:26.0.1
| | \--- com.android.support:support-compat:26.0.1 (*)
| \--- com.android.support:support-fragment:26.0.1
| +--- com.android.support:support-compat:26.0.1 (*)
| +--- com.android.support:support-core-ui:26.0.1 (*)
| \--- com.android.support:support-core-utils:26.0.1 (*)
+--- org.slf4j:slf4j-api:1.7.25
+--- javax.inject:javax.inject:1
+--- javax.annotation:jsr250-api:1.0
+--- com.google.dagger:dagger:2.9 (*)
\--- com.android.support:appcompat-v7:26.0.1
+--- com.android.support:support-annotations:26.0.1
+--- com.android.support:support-v4:26.0.1 (*)
+--- com.android.support:support-vector-drawable:26.0.1
| +--- com.android.support:support-annotations:26.0.1
| \--- com.android.support:support-compat:26.0.1 (*)
\--- com.android.support:animated-vector-drawable:26.0.1
+--- com.android.support:support-vector-drawable:26.0.1 (*)
\--- com.android.support:support-core-ui:26.0.1 (*)
testCompile - Classpath for compiling the test sources.
+--- ch.qos.logback:logback-classic:1.2.3
| +--- ch.qos.logback:logback-core:1.2.3
| \--- org.slf4j:slf4j-api:1.7.25
+--- junit:junit:4.12
| \--- org.hamcrest:hamcrest-core:1.3
\--- org.mockito:mockito-core:1.10.19
+--- org.hamcrest:hamcrest-core:1.1 -> 1.3
\--- org.objenesis:objenesis:2.1
推荐答案
implementation 'org.slf4j:slf4j-api:1.7.25'
runtimeOnly 'com.github.tony19:logback-android-core:1.1.1-6'
这篇关于如何配置gradle以使用logback-classic仅适用于Android中的单元测试?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!