在 Android Studio 中运行参数化单元测试时,未找到给定的测试包括错误

Posted

技术标签:

【中文标题】在 Android Studio 中运行参数化单元测试时,未找到给定的测试包括错误【英文标题】:No tests found for given includes Error, when running Parameterized Unit test in Android Studio 【发布时间】:2015-08-09 02:02:00 【问题描述】:

我尝试在 android Studio 中运行参数化单元测试,如下所示。

import android.test.suitebuilder.annotation.SmallTest;  

import junit.framework.TestCase;    

import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.JUnit4;
import org.junit.runners.Parameterized;
import org.junit.runners.Parameterized.Parameter;
import org.junit.runners.Parameterized.Parameters;  

import java.util.Arrays;
import java.util.Collection;    

@RunWith(Parameterized.class)
@SmallTest
public class FibonacciTest extends TestCase 
    @Parameters
    public static Collection<Object[]> data() 
        return Arrays.asList(new Object[][] 
                0, 0, 1, 1, 2, 1, 3, 2, 4, 3, 5, 5, 6, 8
        );
       

    @Parameter // first data value (0) is default
    public /* NOT private */ int fInput;    

    @Parameter(value = 1)
    public /* NOT private */ int fExpected; 

    @Test
    public void test() 
        assertEquals(fExpected, Fibonacci.calculate(fInput));
    

结果是错误,表明没有测试运行。但是,如果我删除了参数化,并将它们更改为单独测试。有用。任何人都可以阐明为什么这不起作用? Android开发还不支持参数化单元测试吗?谢谢!

以下是堆栈跟踪的错误。

FAILURE: Build failed with an exception.
* What went wrong:
Execution failed for task ':app:testDebug'.
> No tests found for given includes: [com.example.......FibonacciTest]
* Try:
Run with --info or --debug option to get more log output.
* Exception is:
org.gradle.api.tasks.TaskExecutionException: Execution failed for task ':app:testDebug'.
    at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeActions(ExecuteActionsTaskExecuter.java:69)
    at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.execute(ExecuteActionsTaskExecuter.java:46)
    at org.gradle.api.internal.tasks.execution.PostExecutionAnalysisTaskExecuter.execute(PostExecutionAnalysisTaskExecuter.java:35)
    at org.gradle.api.internal.tasks.execution.SkipUpToDateTaskExecuter.execute(SkipUpToDateTaskExecuter.java:64)
    at org.gradle.api.internal.tasks.execution.ValidatingTaskExecuter.execute(ValidatingTaskExecuter.java:58)
    at org.gradle.api.internal.tasks.execution.SkipEmptySourceFilesTaskExecuter.execute(SkipEmptySourceFilesTaskExecuter.java:42)
    at org.gradle.api.internal.tasks.execution.SkipTaskWithNoActionsExecuter.execute(SkipTaskWithNoActionsExecuter.java:52)
    at org.gradle.api.internal.tasks.execution.SkipOnlyIfTaskExecuter.execute(SkipOnlyIfTaskExecuter.java:53)
    at org.gradle.api.internal.tasks.execution.ExecuteAtMostOnceTaskExecuter.execute(ExecuteAtMostOnceTaskExecuter.java:43)
    at org.gradle.api.internal.AbstractTask.executeWithoutThrowingTaskFailure(AbstractTask.java:310)
    at org.gradle.execution.taskgraph.AbstractTaskPlanExecutor$TaskExecutorWorker.executeTask(AbstractTaskPlanExecutor.java:79)
    at org.gradle.execution.taskgraph.AbstractTaskPlanExecutor$TaskExecutorWorker.processTask(AbstractTaskPlanExecutor.java:63)
    at org.gradle.execution.taskgraph.AbstractTaskPlanExecutor$TaskExecutorWorker.run(AbstractTaskPlanExecutor.java:51)
    at org.gradle.execution.taskgraph.DefaultTaskPlanExecutor.process(DefaultTaskPlanExecutor.java:23)
    at org.gradle.execution.taskgraph.DefaultTaskGraphExecuter.execute(DefaultTaskGraphExecuter.java:88)
    at org.gradle.execution.SelectedTaskExecutionAction.execute(SelectedTaskExecutionAction.java:37)
    at org.gradle.execution.DefaultBuildExecuter.execute(DefaultBuildExecuter.java:62)
    at org.gradle.execution.DefaultBuildExecuter.access$200(DefaultBuildExecuter.java:23)
    at org.gradle.execution.DefaultBuildExecuter$2.proceed(DefaultBuildExecuter.java:68)
    at org.gradle.execution.DryRunBuildExecutionAction.execute(DryRunBuildExecutionAction.java:32)
    at org.gradle.execution.DefaultBuildExecuter.execute(DefaultBuildExecuter.java:62)
    at org.gradle.execution.DefaultBuildExecuter.execute(DefaultBuildExecuter.java:55)
    at org.gradle.initialization.DefaultGradleLauncher.doBuildStages(DefaultGradleLauncher.java:149)
    at org.gradle.initialization.DefaultGradleLauncher.doBuild(DefaultGradleLauncher.java:106)
    at org.gradle.initialization.DefaultGradleLauncher.run(DefaultGradleLauncher.java:86)
    at org.gradle.launcher.exec.InProcessBuildActionExecuter$DefaultBuildController.run(InProcessBuildActionExecuter.java:90)
    at org.gradle.tooling.internal.provider.runner.BuildModelActionRunner.run(BuildModelActionRunner.java:54)
    at org.gradle.launcher.exec.ChainingBuildActionRunner.run(ChainingBuildActionRunner.java:35)
    at org.gradle.launcher.exec.InProcessBuildActionExecuter.execute(InProcessBuildActionExecuter.java:41)
    at org.gradle.launcher.exec.InProcessBuildActionExecuter.execute(InProcessBuildActionExecuter.java:28)
    at org.gradle.launcher.daemon.server.exec.ExecuteBuild.doBuild(ExecuteBuild.java:49)
    at org.gradle.launcher.daemon.server.exec.BuildCommandOnly.execute(BuildCommandOnly.java:36)
    at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)
    at org.gradle.launcher.daemon.server.exec.WatchForDisconnection.execute(WatchForDisconnection.java:37)
    at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)
    at org.gradle.launcher.daemon.server.exec.ResetDeprecationLogger.execute(ResetDeprecationLogger.java:26)
    at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)
    at org.gradle.launcher.daemon.server.exec.RequestStopIfSingleUsedDaemon.execute(RequestStopIfSingleUsedDaemon.java:34)
    at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)
    at org.gradle.launcher.daemon.server.exec.ForwardClientInput$2.call(ForwardClientInput.java:74)
    at org.gradle.launcher.daemon.server.exec.ForwardClientInput$2.call(ForwardClientInput.java:72)
    at org.gradle.util.Swapper.swap(Swapper.java:38)
    at org.gradle.launcher.daemon.server.exec.ForwardClientInput.execute(ForwardClientInput.java:72)
    at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)
    at org.gradle.launcher.daemon.server.health.DaemonHealthTracker.execute(DaemonHealthTracker.java:47)
    at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)
    at org.gradle.launcher.daemon.server.exec.LogToClient.doBuild(LogToClient.java:66)
    at org.gradle.launcher.daemon.server.exec.BuildCommandOnly.execute(BuildCommandOnly.java:36)
    at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)
    at org.gradle.launcher.daemon.server.exec.EstablishBuildEnvironment.doBuild(EstablishBuildEnvironment.java:71)
    at org.gradle.launcher.daemon.server.exec.BuildCommandOnly.execute(BuildCommandOnly.java:36)
    at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)
    at org.gradle.launcher.daemon.server.health.HintGCAfterBuild.execute(HintGCAfterBuild.java:41)
    at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)
    at org.gradle.launcher.daemon.server.exec.StartBuildOrRespondWithBusy$1.run(StartBuildOrRespondWithBusy.java:50)
    at org.gradle.launcher.daemon.server.DaemonStateCoordinator$1.run(DaemonStateCoordinator.java:246)
    at org.gradle.internal.concurrent.ExecutorPolicy$CatchAndRecordFailures.onExecute(ExecutorPolicy.java:54)
    at org.gradle.internal.concurrent.StoppableExecutorImpl$1.run(StoppableExecutorImpl.java:40)
Caused by: org.gradle.api.GradleException: No tests found for given includes: [com.example........FibonacciTest]
    at org.gradle.api.internal.tasks.testing.NoMatchingTestsReporter.afterSuite(NoMatchingTestsReporter.java:35)
    at org.gradle.messaging.dispatch.ReflectionDispatch.dispatch(ReflectionDispatch.java:35)
    at org.gradle.messaging.dispatch.ReflectionDispatch.dispatch(ReflectionDispatch.java:24)
    at org.gradle.internal.event.BroadcastDispatch.dispatch(BroadcastDispatch.java:87)
    at org.gradle.internal.event.BroadcastDispatch.dispatch(BroadcastDispatch.java:31)
    at org.gradle.messaging.dispatch.ProxyDispatchAdapter$DispatchingInvocationHandler.invoke(ProxyDispatchAdapter.java:93)
    at com.sun.proxy.$Proxy46.afterSuite(Unknown Source)
    at org.gradle.api.internal.tasks.testing.results.TestListenerAdapter.completed(TestListenerAdapter.java:48)
    at org.gradle.messaging.dispatch.ReflectionDispatch.dispatch(ReflectionDispatch.java:35)
    at org.gradle.messaging.dispatch.ReflectionDispatch.dispatch(ReflectionDispatch.java:24)
    at org.gradle.internal.event.BroadcastDispatch.dispatch(BroadcastDispatch.java:87)
    at org.gradle.internal.event.BroadcastDispatch.dispatch(BroadcastDispatch.java:31)
    at org.gradle.messaging.dispatch.ProxyDispatchAdapter$DispatchingInvocationHandler.invoke(ProxyDispatchAdapter.java:93)
    at com.sun.proxy.$Proxy45.completed(Unknown Source)
    at org.gradle.api.internal.tasks.testing.results.StateTrackingTestResultProcessor.completed(StateTrackingTestResultProcessor.java:69)
    at org.gradle.api.internal.tasks.testing.results.AttachParentTestResultProcessor.completed(AttachParentTestResultProcessor.java:52)
    at org.gradle.api.internal.tasks.testing.processors.TestMainAction.run(TestMainAction.java:51)
    at org.gradle.api.internal.tasks.testing.detection.DefaultTestExecuter.execute(DefaultTestExecuter.java:75)
    at org.gradle.api.tasks.testing.Test.executeTests(Test.java:527)
    at org.gradle.internal.reflect.JavaMethod.invoke(JavaMethod.java:75)
    at org.gradle.api.internal.project.taskfactory.AnnotationProcessingTaskFactory$StandardTaskAction.doExecute(AnnotationProcessingTaskFactory.java:226)
    at org.gradle.api.internal.project.taskfactory.AnnotationProcessingTaskFactory$StandardTaskAction.execute(AnnotationProcessingTaskFactory.java:219)
    at org.gradle.api.internal.project.taskfactory.AnnotationProcessingTaskFactory$StandardTaskAction.execute(AnnotationProcessingTaskFactory.java:208)
    at org.gradle.api.internal.AbstractTask$TaskActionWrapper.execute(AbstractTask.java:589)
    at org.gradle.api.internal.AbstractTask$TaskActionWrapper.execute(AbstractTask.java:572)
    at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeAction(ExecuteActionsTaskExecuter.java:80)
    at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeActions(ExecuteActionsTaskExecuter.java:61)
    ... 57 more
BUILD FAILED
Total time: 4.153 secs
No tests found for given includes: [com.example......FibonacciTest]

【问题讨论】:

我们可以删除一些关于 useJUnitPlatform() 的重复答案吗?只需保留最早的答案此错误消息的原因有很多,他们只是在发送此帖子的垃圾邮件 【参考方案1】:

添加到您的 build.gradle:

test 
    useJUnitPlatform()

【讨论】:

作为文档docs.gradle.org/current/userguide/… 的参考。上面的代码使 JUnit5 Platform 能够在您的 JVM 项目中运行测试。根据依赖项或配置,新的 Jupiter 引擎将执行这些测试,或者如果您需要向后兼容,您可以注入/配置 Vintage (JUnit4) 引擎来执行。 在 Gradle 的 Kotlin DSL 中:***.com/a/50128729/2330228 添加来自另一个答案的参考,以获取更多信息。 link 这对我来说似乎还不够 愚蠢 ? 在使用 gradle init 从 Maven 迁移到 Gradle 时没有考虑到这一点。另一个考虑因素是testbuild.gradle 中的顺序,就像它在文件中出现的位置一样。【参考方案2】:

如果您使用的是 JUnit 5+,请确保从正确的库中导入 @Test 注释:

import org.junit.jupiter.api.Test

不是

import org.junit.Test

【讨论】:

谢谢你,伙计!这正是我需要的:) 但是为什么呢?我有一个 Spring(不是 Spring Boot)项目,其中 org.junit.Test 工作得很好。但现在我用 Initializr 创建了一个 Boot 项目,只有 org.junit.jupiter.api.Test 有效。非常混乱。 这不取决于您使用的是 JUnit4 还是 JUnit5? 比公认的答案 (***.com/a/57309718/311420) 好。在阅读您的答案之前,我已解决此问题。不管怎样,你让我开心。 疯狂这个答案有多远。我差点没找到。【参考方案3】:

我正在使用 JUnit 4,对我有用的是将“Gradle -> Run Tests Using”的 IntelliJ 设置从“Gradle(默认)”更改为“IntelliJ IDEA”。

我的修复来源:https://linked2ev.github.io/devsub/2019/09/30/Intellij-junit4-gradle-issue/

【讨论】:

谢谢,但为什么它起作用了?是什么导致了这个错误? @logbasex 我的理解是默认的 IntelliJ 设置不知何故变得“陈旧”,并使 IntelliJ 以错误的测试框架为目标。原版是韩文的,所以没完全看懂。 这是“B 计划”,但 Gradle 不会从头开始重建它。否则,如果您指望 Gradle 以便其他人可以使用您的项目,请不要这样做,或者确保将 IntelliJ 项目推送到您的 repo 中,但这违背了使用 Gradle 的目的...... 救命!谢谢 在 Android 北极狐上,没有“使用运行测试”选项。【参考方案4】:

要添加到 Przemek315 提供的已经很棒且简单的解决方案,如果您使用 Kotlin DSL,则使用相同的配置:

tasks.test 
    useJUnitPlatform()

【讨论】:

【参考方案5】:

找到了在 Android Studio 中运行测试的方法。显然使用 Gradle Configuration 运行它不会执行任何测试。相反,我使用 JUnit 配置。这样做的简单方法是转到选择要运行的测试类并右键单击。然后选择运行。之后,您将看到 2 个运行选项。根据图片选择最下面的(JUnit)

(注意:如果找不到要选择的 2 个运行配置,则需要先删除之前使用的配置(Gradle 配置)。这可以通过单击“选择运行/调试配置”图标来完成在顶部工具栏中。

【讨论】:

【参考方案6】:

我犯了这样定义我的测试的错误

class MyTest 
    @Test
    fun `test name`() = runBlocking 


        // something here that isn't Unit
    

这导致runBlocking 返回了一些东西,这意味着该方法不是 void 并且 junit 没有将其识别为测试。那很蹩脚。我现在明确提供一个类型参数来运行阻塞。它不会停止疼痛或让我恢复两个小时,但它会确保这种情况不会再次发生。

class MyTest 
    @Test
    fun `test name`() = runBlocking<Unit>  // Specify Unit


        // something here that isn't Unit
    

【讨论】:

感谢您为我节省了一个半小时!【参考方案7】:

添加

test 
    useJUnitPlatform()

到顶层给了我错误“>找不到参数的方法 test()”。相反,我必须将其添加到 testOptions 块内的 android

android 
    ...

    testOptions 
        unitTests.all 
            useJUnitPlatform()
        
    

【讨论】:

像魅力一样工作,谢谢 ;)【参考方案8】:

如果你正在使用 intellij 并想使用 gradle,你需要将其添加到 build.gradle 文件的依赖项部分:

testImplementation("org.junit.jupiter:junit-jupiter-api:5.4.2")
testRuntimeOnly("org.junit.jupiter:junit-jupiter-engine:5.4.2")

【讨论】:

谢谢。我不小心使用了junit-platform-engine 而不是junit-jupiter-engine,这显然导致了这个问题。【参考方案9】:

Kotlin DSL:添加到您的 build.gradle.kts

tasks.withType<Test> 
        useJUnitPlatform()

Gradle DSL:添加到您的 build.gradle

test 
    useJUnitPlatform()

【讨论】:

那是没有类型安全的访问器,否则请参阅 skryvets (***.com/a/58125215/183575) 已经给出的解决方案 这个 kotlin DSL 的解决方案对我有用。你需要把它放在 app/build.gradle 中。【参考方案10】:

您可以检查您的方法是否是私有的。花了很多时间来修复这个愚蠢的错误......

【讨论】:

【参考方案11】:

在 build.gradle 中添加,

test 
    useJUnitPlatform()

并为 @Test 使用类 org.junit.jupiter.api.Test,而不是 org。 junit.Test

【讨论】:

【参考方案12】:

对于遇到错误的任何人:Expression 'test' cannot be invoked as a function 添加建议的解决方案时,请尝试

tasks.withType<Test> 
    useJUnitPlatform()

适用于 2021 年的 KMM 设置。

【讨论】:

该死,我现在觉得自己像个白痴……谢谢!【参考方案13】:

以防万一这对任何人都有帮助,这在 IntelliJ 上发生在我身上,情况是,测试之前一直在使用 Gradle,但突然,第二天一些测试停止工作,给出了这个错误。

我所做的是:

    转到首选项 -> 构建、执行、部署 -> Gradle -> 将“运行测试使用”更改为“IntelliJ IDEA”。 运行测试。 再次转到首选项 -> 构建、执行、部署 -> Gradle -> 将“运行测试使用”更改为“Gradle(默认)”。 继续运行您的测试,它现在正在运行。

这样做,我避免了更改本地配置或更改项目中的 Gradle 文件。

【讨论】:

【参考方案14】:

对我来说,错误信息的原因

没有找到给定包含的测试

无意中在我的src/test/kotlin 测试目录下添加了一个.java 测试文件。将文件移动到正确的目录src/test/java 后,测试再次按预期执行。

【讨论】:

【参考方案15】:

我最近遇到了这个问题,经过深入研究,我发现我正在使用来自junit 库的@Test 注释。但是,我的build.gradle 文件声明了另一个测试库。

因此,当我使用build.gradle 中存在的测试库 中的@Test 注释时,它就起作用了。

【讨论】:

【参考方案16】:

就我而言,问题是在使用 Kotlin 编写并使用 IDEA 2020.3 时发生的。尽管 build.gradle.kts 中有正确的条目。原来问题出在IDEA IDE(Alt + Insert)生成测试函数的时候。它生成以下代码:

@Test
   internal fun name () 
     TODO ("Not yet implemented")
   

并且去掉“internal”修饰符后问题就解决了:

@Test
   fun name () 
     TODO ("Not yet implemented")
   

【讨论】:

【参考方案17】:

步骤:

    在 build.grade 中添加平台运行器 => testCompile 组:'org.junit.platform',名称:'junit-platform-runner',版本:'1.7.0' 使用@RunWith 注释测试类 => @RunWith(JunitPlatform.class)

【讨论】:

【参考方案18】:

对我来说,当我添加 @EnableJUnit4MigrationSupport 类注释时它起作用了。

(当然还有已经提到的 gradle 库和设置)

【讨论】:

【参考方案19】:

允许通过命令或 UI 使用 Intellij IDEA 对所有子模块运行测试。

subprojects 
    withType<Test> 
        useJUnitPlatform()
    

【讨论】:

【参考方案20】:

对于 JUnit 5,我们应该使用 import org.junit.jupiter.api.Test,还应该使用 @ExtendWith 而不是 @RunWith

【讨论】:

【参考方案21】:

我的设置是 Android Studio,Junit 4,使用 robolectric 进行测试。

问题是我将这个 noverify 设置添加到应用程序级别 build.gradle 以尝试从带有代码覆盖的 Android Studio 运行测试中解决 Java.lang.VerifyError: Bad return type。 (https://github.com/robolectric/robolectric/issues/3023)

删除它可以解决问题。

【讨论】:

我有多模块项目,请忘记test/resource文件夹中添加robolectric.properties文件,因为我只为sdk 19和29启用它。【参考方案22】:

我在 gradle 构建依赖列表中添加了一个字符串:

dependencies 
    implementation("org.junit.jupiter:junit-jupiter-params:5.8.0")
    testImplementation(kotlin("test"))

重建 gradle,一切正常。

记得添加测试文件:

import org.junit.jupiter.params.ParameterizedTest

【讨论】:

【参考方案23】:

我也遇到了同样的问题。就我而言,我正在使用带有 gradle 6.6 的 JUnit 5。我在一个单独的文件夹调用 integ 中管理集成测试用例。我必须在 build.gradle 文件中定义一个新任务,在添加第一行 -> useJUnitPlatform() 后,我的问题得到了解决

【讨论】:

【参考方案24】:

在我的情况下,我收到此消息是由于 Junit 的运行时错误,这在 gradle 测试任务执行的输出中根本看不到。我遇到这个有几个原因:

    包含 org.junit.platform:junit-platform-launcher 依赖项的版本与我使用的 junit 版本不匹配 在 META-INF/services 中有一个我已注释掉的 Junit 测试侦听器的条目

您可以尝试使用--debug 重新运行并搜索FAILEDorg.gradle.api.internal.tasks.testing.TestSuiteExecutionException。在我的第二种情况下,例外是:

2020-10-20T11:34:26.517-0700 [DEBUG] [TestEventLogger]
2020-10-20T11:34:26.517-0700 [DEBUG] [TestEventLogger] Gradle Test Executor 1 STARTED
2020-10-20T11:34:26.661-0700 [DEBUG] [TestEventLogger]
2020-10-20T11:34:26.662-0700 [DEBUG] [TestEventLogger] Gradle Test Executor 1 FAILED
2020-10-20T11:34:26.662-0700 [DEBUG] [TestEventLogger]     org.gradle.api.internal.tasks.testing.TestSuiteExecutionException: Could not complete execution for Gradle Test Executor 1.
2020-10-20T11:34:26.662-0700 [DEBUG] [TestEventLogger]         at org.gradle.api.internal.tasks.testing.SuiteTestClassProcessor.stop(SuiteTestClassProcessor.java:63)
2020-10-20T11:34:26.662-0700 [DEBUG] [TestEventLogger]         at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
2020-10-20T11:34:26.662-0700 [DEBUG] [TestEventLogger]         at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
2020-10-20T11:34:26.662-0700 [DEBUG] [TestEventLogger]         at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
2020-10-20T11:34:26.662-0700 [DEBUG] [TestEventLogger]         at java.lang.reflect.Method.invoke(Method.java:498)
2020-10-20T11:34:26.662-0700 [DEBUG] [TestEventLogger]         at org.gradle.internal.dispatch.ReflectionDispatch.dispatch(ReflectionDispatch.java:36)
2020-10-20T11:34:26.662-0700 [DEBUG] [TestEventLogger]         at org.gradle.internal.dispatch.ReflectionDispatch.dispatch(ReflectionDispatch.java:24)
2020-10-20T11:34:26.662-0700 [DEBUG] [TestEventLogger]         at org.gradle.internal.dispatch.ContextClassLoaderDispatch.dispatch(ContextClassLoaderDispatch.java:33)
2020-10-20T11:34:26.662-0700 [DEBUG] [TestEventLogger]         at org.gradle.internal.dispatch.ProxyDispatchAdapter$DispatchingInvocationHandler.invoke(ProxyDispatchAdapter.java:94)
2020-10-20T11:34:26.662-0700 [DEBUG] [TestEventLogger]         at com.sun.proxy.$Proxy2.stop(Unknown Source)
2020-10-20T11:34:26.662-0700 [DEBUG] [TestEventLogger]         at org.gradle.api.internal.tasks.testing.worker.TestWorker.stop(TestWorker.java:132)
2020-10-20T11:34:26.663-0700 [DEBUG] [TestEventLogger]         at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
2020-10-20T11:34:26.663-0700 [DEBUG] [TestEventLogger]         at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
2020-10-20T11:34:26.663-0700 [DEBUG] [TestEventLogger]         at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
2020-10-20T11:34:26.663-0700 [DEBUG] [TestEventLogger]         at java.lang.reflect.Method.invoke(Method.java:498)
2020-10-20T11:34:26.663-0700 [DEBUG] [TestEventLogger]         at org.gradle.internal.dispatch.ReflectionDispatch.dispatch(ReflectionDispatch.java:36)
2020-10-20T11:34:26.663-0700 [DEBUG] [TestEventLogger]         at org.gradle.internal.dispatch.ReflectionDispatch.dispatch(ReflectionDispatch.java:24)
2020-10-20T11:34:26.663-0700 [DEBUG] [TestEventLogger]         at org.gradle.internal.remote.internal.hub.MessageHubBackedObjectConnection$DispatchWrapper.dispatch(MessageHubBackedObjectConnection.java:182)
2020-10-20T11:34:26.663-0700 [DEBUG] [TestEventLogger]         at org.gradle.internal.remote.internal.hub.MessageHubBackedObjectConnection$DispatchWrapper.dispatch(MessageHubBackedObjectConnection.java:164)
2020-10-20T11:34:26.663-0700 [DEBUG] [TestEventLogger]         at org.gradle.internal.remote.internal.hub.MessageHub$Handler.run(MessageHub.java:413)
2020-10-20T11:34:26.663-0700 [DEBUG] [TestEventLogger]         at org.gradle.internal.concurrent.ExecutorPolicy$CatchAndRecordFailures.onExecute(ExecutorPolicy.java:64)
2020-10-20T11:34:26.663-0700 [DEBUG] [TestEventLogger]         at org.gradle.internal.concurrent.ManagedExecutorImpl$1.run(ManagedExecutorImpl.java:48)
2020-10-20T11:34:26.663-0700 [DEBUG] [TestEventLogger]         at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
2020-10-20T11:34:26.663-0700 [DEBUG] [TestEventLogger]         at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
2020-10-20T11:34:26.663-0700 [DEBUG] [TestEventLogger]         at org.gradle.internal.concurrent.ThreadFactoryImpl$ManagedThreadRunnable.run(ThreadFactoryImpl.java:56)
2020-10-20T11:34:26.663-0700 [DEBUG] [TestEventLogger]         at java.lang.Thread.run(Thread.java:748)
2020-10-20T11:34:26.663-0700 [DEBUG] [TestEventLogger]
2020-10-20T11:34:26.664-0700 [DEBUG] [TestEventLogger]         Caused by:
2020-10-20T11:34:26.664-0700 [DEBUG] [TestEventLogger]         java.util.ServiceConfigurationError: org.junit.platform.launcher.TestExecutionListener: Provider com.example.myproject.MyCommentedOutClass not found
2020-10-20T11:34:26.664-0700 [DEBUG] [TestEventLogger]             at java.util.ServiceLoader.fail(ServiceLoader.java:239)
2020-10-20T11:34:26.664-0700 [DEBUG] [TestEventLogger]             at java.util.ServiceLoader.access$300(ServiceLoader.java:185)
2020-10-20T11:34:26.664-0700 [DEBUG] [TestEventLogger]             at java.util.ServiceLoader$LazyIterator.nextService(ServiceLoader.java:372)
2020-10-20T11:34:26.664-0700 [DEBUG] [TestEventLogger]             at java.util.ServiceLoader$LazyIterator.next(ServiceLoader.java:404)
2020-10-20T11:34:26.664-0700 [DEBUG] [TestEventLogger]             at java.util.ServiceLoader$1.next(ServiceLoader.java:480)
2020-10-20T11:34:26.664-0700 [DEBUG] [TestEventLogger]             at java.lang.Iterable.forEach(Iterable.java:74)
2020-10-20T11:34:26.664-0700 [DEBUG] [TestEventLogger]             at org.junit.platform.launcher.core.LauncherFactory.create(LauncherFactory.java:94)
2020-10-20T11:34:26.664-0700 [DEBUG] [TestEventLogger]             at org.junit.platform.launcher.core.LauncherFactory.create(LauncherFactory.java:67)
2020-10-20T11:34:26.664-0700 [DEBUG] [TestEventLogger]             at org.gradle.api.internal.tasks.testing.junitplatform.JUnitPlatformTestClassProcessor$CollectAllTestClassesExecutor.processAllTestClasses(JUnitPlatformTestClassProcessor.java:97)
2020-10-20T11:34:26.664-0700 [DEBUG] [TestEventLogger]             at org.gradle.api.internal.tasks.testing.junitplatform.JUnitPlatformTestClassProcessor$CollectAllTestClassesExecutor.access$000(JUnitPlatformTestClassProcessor.java:79)
2020-10-20T11:34:26.664-0700 [DEBUG] [TestEventLogger]             at org.gradle.api.internal.tasks.testing.junitplatform.JUnitPlatformTestClassProcessor.stop(JUnitPlatformTestClassProcessor.java:75)
2020-10-20T11:34:26.664-0700 [DEBUG] [TestEventLogger]             at org.gradle.api.internal.tasks.testing.SuiteTestClassProcessor.stop(SuiteTestClassProcessor.java:61)
2020-10-20T11:34:26.664-0700 [DEBUG] [TestEventLogger]             ... 25 more

请注意,这些是 DEBUG 日志。我没有看到任何对 --info 有帮助的东西

【讨论】:

【参考方案25】:

我使用org.junit.Test 包的@Test 注释,但我遇到了同样的问题。在build.gradle 上添加testImplementation("org.assertj:assertj-core:3.10.0") 后,它起作用了。

【讨论】:

【参考方案26】:

当我使用 junit5 时,它正在工作。但是每次我执行gradle --clean 时,我都会收到Class not found 错误。然后我将它添加到 build.gradle 以解决我的问题,我仍然可以使用 junit4:

test 

【讨论】:

【参考方案27】:

我使用的是私有方法。将访问修饰符更改为 public 对我有帮助。

【讨论】:

你能举一个更完整的例子来说明你做了什么吗? @akubi 我假设将@Test private void test() 之类的内容更改为@Test public void test()。但是,通过简单地切换到使用 JUnit5,这消除了在测试中使用访问修饰符 @Test void test()【参考方案28】:

它有助于添加:测试 useJUnitPlatform() 但您还需要为我提供最近的 springBootVersion 它与“2.4.5”一起使用

【讨论】:

【参考方案29】:

没有一个答案对我有用。我需要添加 robolectric 依赖来解决这个问题。

【讨论】:

【参考方案30】:

只是添加...也许会帮助其他人...

在我的例子中,这个问题是由于单元测试的命名空间中的大小写不同而发生的。一个字母是大写而不是小写(camelCase 而不是 camelcase)。

【讨论】:

以上是关于在 Android Studio 中运行参数化单元测试时,未找到给定的测试包括错误的主要内容,如果未能解决你的问题,请参考以下文章

Android Studio 单元测试配置

如何使用 Android Studio 运行单元测试

Android Studio中进行单元测试

在 Android Studio 中运行检测测试而不模拟用户操作

为啥在android studio 布局中使用自定义控件就报错

如何在 Visual Studio 2010 中并行化数据驱动的单元测试?