【问题标题】:Class has already been added to output. Please remove duplicate copies类已添加到输出。请删除重复的副本
【发布时间】:2015-08-09 11:38:28
【问题描述】:

我有一些应用程序,如果我在设备上运行它,它运行良好。

但是现在,我需要为这个应用程序编写单元测试,当我尝试运行一些单元测试时,我遇到了问题。

这是我的应用build.gradle

    buildscript {
        repositories {
            jcenter()
            mavenCentral()
            maven { url 'https://maven.fabric.io/public' }
        }
        dependencies {
            classpath 'com.android.tools.build:gradle:1.0.0'
            classpath 'io.fabric.tools:gradle:1.+'
        }
    }
    apply plugin: 'com.android.application'
    apply plugin: 'io.fabric'

    repositories {
        jcenter()
        maven { url 'https://maven.fabric.io/public' }
    }

    configurations {
        all*.exclude group: 'com.android.support', module: 'support-v4'
        all*.exclude group: 'com.google.android.gms', module: 'play-services'
    }

    android {
        compileSdkVersion 21
        buildToolsVersion "19.1"

        defaultConfig {
            applicationId "com.lodoss.shopsterhood"
            minSdkVersion 9
            targetSdkVersion 21
            versionCode 15
            versionName "2.0.1"
        }
        dexOptions {
            preDexLibraries = false
            incremental = false
        }
        buildTypes {
            release {
                minifyEnabled false
                proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
            }
        }

        packagingOptions {
            exclude 'META-INF/DEPENDENCIES.txt'
            exclude 'META-INF/LICENSE.txt'
            exclude 'META-INF/NOTICE.txt'
            exclude 'META-INF/NOTICE'
            exclude 'META-INF/LICENSE'
            exclude 'META-INF/DEPENDENCIES'
            exclude 'META-INF/notice.txt'
            exclude 'META-INF/license.txt'
            exclude 'META-INF/dependencies.txt'
            exclude 'META-INF/LGPL2.1'
        }

        lintOptions {
            abortOnError false
        }
    }

    dependencies {
        compile fileTree(dir: 'lib', include: ['*.jar'])
        compile project (':appcompat')
        compile project(':DragSortListView')
        compile 'com.github.chrisbanes.actionbarpulltorefresh:library:0.9.9'
    //    compile 'com.vk:androidsdk:1.3.6'
        compile project(':facebook')
    //    compile('com.crashlytics.sdk.android:crashlytics:2.2.1@aar') {
    //        transitive = true;
    //    }
        compile('com.twitter.sdk.android:twitter:1.3.0@aar') {
            transitive = true;
        }


    //    androidTestCompile 'com.squareup.assertj:assertj-android:1.0.0'
    //    androidTestCompile 'com.squareup.assertj:assertj-android-support-v4:1.0.0'
    //    androidTestCompile 'com.squareup.assertj:assertj-android-play-services:1.0.0'
        compile 'com.jayway.android.robotium:robotium-solo:5.2.1'
    //    androidTestCompile 'com.android.support.test.espresso:espresso-core:2.0'
    //    androidTestCompile ('com.android.support.test.espresso:espresso-contrib:2.0') {
    //        exclude module: 'support-annotations'
    //    }
    //    androidTestCompile 'org.hamcrest:hamcrest-all:1.3'

    }

这是 build.gradle 的模块,当我尝试运行单元测试时,它会出现编译错误:

buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:1.0.0'
    }
}
apply plugin: 'com.android.library'

repositories {
    jcenter()
}

android {
    compileSdkVersion 21
    buildToolsVersion "19.1"

    defaultConfig {
        minSdkVersion 9
        targetSdkVersion 21
        versionCode 1
        versionName "1.0"
    }

    dexOptions {
        preDexLibraries = false
        incremental = false
    }
    compileOptions {
        sourceCompatibility JavaVersion.VERSION_1_7
        targetCompatibility JavaVersion.VERSION_1_7
    }

    packagingOptions {
        exclude 'META-INF/DEPENDENCIES.txt'
        exclude 'META-INF/LICENSE.txt'
        exclude 'META-INF/NOTICE.txt'
        exclude 'META-INF/NOTICE'
        exclude 'META-INF/LICENSE'
        exclude 'META-INF/DEPENDENCIES'
        exclude 'META-INF/notice.txt'
        exclude 'META-INF/license.txt'
        exclude 'META-INF/dependencies.txt'
        exclude 'META-INF/LGPL2.1'
    }

    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
}

这是我的测试:

package com.lodoss.shopsterhood.activity;

import android.test.ActivityInstrumentationTestCase2;
import com.lodoss.shopsterhood.Activity_Main;
import com.robotium.solo.Solo;

/**
 * Created by Boris on 27.05.15.
 */
public class EmailRegistrationTest extends ActivityInstrumentationTestCase2<Activity_Main> implements ActivityTestCaseConstants {

    private Solo solo;

    public EmailRegistrationTest() {
        super(Activity_Main.class);
    }

    @Override
    protected void setUp() throws Exception {
        super.setUp();
        solo = new Solo(getInstrumentation(), getActivity());
    }

    @Override
    protected void tearDown() throws Exception{
        solo.finishOpenedActivities();
    }

    public void testEmailRegistrationWithCorrectData(){
        // check that we have the right activity
        solo.assertCurrentActivity("Wrong activity", Activity_Main.class);

        Activity_Main activity = (Activity_Main) solo.getCurrentActivity();
    }
}

我知道,它没有任何用处,但它没有运行。

我有 3 错误。

第一个错误

错误:Gradle:任务 ':appcompat:dexDebugTest' 执行失败。

com.android.ide.common.internal.LoggedErrorException:无法运行命令:
/opt/adt-bundle-linux/adt-bundle-linux-x86_64-20140702/sdk/build-tools/19.1.0/dx --dex --no-optimize --output /home/alexander/projects/shopster-gradle/appcompat/build/intermediates/dex/test/debug /home/alexander/projects/shopster-gradle/appcompat/build/intermediates/classes/test/debug /home/alexander/projects/shopster-gradle/appcompat/build/intermediates/bundles/debug/classes.jar /home/alexander/projects/shopster-gradle/appcompat/libs/android-support-v7-appcompat.jar /home/alexander/projects/shopster-gradle/appcompat/build/intermediates/bundles/debug/libs/android-support-v7-appcompat.jar /home/alexander/projects/shopster-gradle/appcompat/libs/android-support-v4.jar /home/alexander/projects/shopster-gradle/appcompat/build/intermediates/bundles/debug/libs/android-support-v4.jar 错误代码:1 输出:UNEXPECTED TOP-LEVEL EXCEPTION:
java.lang.IllegalArgumentException:已添加: Landroid/support/v7/widget/SearchView$OnSuggestionListener; 在 com.android.dx.dex.file.ClassDefsSection.add(ClassDefsSection.java:122) 在 com.android.dx.dex.file.DexFile.add(DexFile.java:161) 在 com.android.dx.command.dexer.Main.processClass(Main.java:685) 在 com.android.dx.command.dexer.Main.processFileBytes(Main.java:634) 在 com.android.dx.command.dexer.Main.access$600(Main.java:78) 在 com.android.dx.command.dexer.Main$1.processFileBytes(Main.java:572) 在 com.android.dx.cf.direct.ClassPathOpener.processArchive(ClassPathOpener.java:284) 在 com.android.dx.cf.direct.ClassPathOpener.processOne(ClassPathOpener.java:166) 在 com.android.dx.cf.direct.ClassPathOpener.process(ClassPathOpener.java:144) 在 com.android.dx.command.dexer.Main.processOne(Main.java:596) 在 com.android.dx.command.dexer.Main.processAllFiles(Main.java:498) 在 com.android.dx.command.dexer.Main.runMonoDex(Main.java:264) 在 com.android.dx.command.dexer.Main.run(Main.java:230) 在 com.android.dx.command.dexer.Main.main(Main.java:199) 在 com.android.dx.command.Main.main(Main.java:103) 意外的顶级异常:java.lang.IllegalArgumentException:已经 添加:Landroid/support/v4/util/TimeUtils; 在 com.android.dx.dex.file.ClassDefsSection.add(ClassDefsSection.java:122) 在 com.android.dx.dex.file.DexFile.add(DexFile.java:161) 在 com.android.dx.command.dexer.Main.processClass(Main.java:685) 在 com.android.dx.command.dexer.Main.processFileBytes(Main.java:634) 在 com.android.dx.command.dexer.Main.access$600(Main.java:78) 在 com.android.dx.command.dexer.Main$1.processFileBytes(Main.java:572) 在 com.android.dx.cf.direct.ClassPathOpener.processArchive(ClassPathOpener.java:284) 在 com.android.dx.cf.direct.ClassPathOpener.processOne(ClassPathOpener.java:166) 在 com.android.dx.cf.direct.ClassPathOpener.process(ClassPathOpener.java:144) 在 com.android.dx.command.dexer.Main.processOne(Main.java:596) 在 com.android.dx.command.dexer.Main.processAllFiles(Main.java:498) 在 com.android.dx.command.dexer.Main.runMonoDex(Main.java:264) 在 com.android.dx.command.dexer.Main.run(Main.java:230) 在 com.android.dx.command.dexer.Main.main(Main.java:199) 在 com.android.dx.command.Main.main(Main.java:103) 2 错误;中止

第二个错误:

错误:Gradle:类 android.support.v7.widget.SearchView.OnSuggestionListener 已经 已添加到输出。请删除重复的副本。

第三次错误:

错误:Gradle:类 android.support.v4.util.TimeUtils 已经 添加到输出。请删除重复的副本。

在研究first stacktrace 之后,我发现了以下几行:

/home/alexander/projects/shopster-gradle/appcompat/libs/android-support-v7-appcompat.jar

/home/alexander/projects/shopster-gradle/appcompat/build/intermediates/bundles/debug/libs/android-support-v7-appcompat.jar

/home/alexander/projects/shopster-gradle/appcompat/libs/android-support-v4.jar /home/alexander/projects/shopster-gradle/appcompat/build/intermediates/bundles/debug/libs/android-support-v4.jar

如果我理解正确,gradle 将这个库添加到 build 目录中,然后尝试将其与原始库进行 dex 并引发异常。

我试图手动删除它,但它没有帮助......

另外,我不能从模块中删除这个库(jars),因为它是非常旧的项目,并且这个库已经指定了修订/版本。只有这个 jar 与这个 appcompat 模块兼容。当我删除它并添加为 gradledependecy 时,appcompat 模块中的一些资源消失了。换句话说,将此库添加为 gradle 依赖项是不可接受的决定。

我尝试使用 Intellij IDEA 14 运行测试。

有人知道如何解决这个问题吗?

已编辑

我的 support-v4 库的哈希7C2158F2ABA8503DF83F92C934508E2F

v7-appcompat 库的哈希75B6D02AA52729CA3F7B62DB1AF465EE

【问题讨论】:

    标签: android gradle android-gradle-plugin


    【解决方案1】:

    Robotium 是一个测试库,不应该这样包含

    compile 'com.jayway.android.robotium:robotium-solo:5.2.1'
    

    不如试试

    androidTestCompile 'com.jayway.android.robotium:robotium-solo:5.2.1'
    

    【讨论】:

    • 没有帮助。错误仍然出现
    猜你喜欢
    • 1970-01-01
    • 2015-02-12
    • 1970-01-01
    • 1970-01-01
    • 2015-10-04
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多