当前位置: 首页 > 知识库问答 >
问题:

在设备内部测试期间,“动画器只能在循环线程上运行”

燕富
2023-03-14

这是我的测试代码:

@RunWith(AndroidJUnit4.class)
@SmallTest
public class WelcomeActivityTests extends BaseTest {

    ApplicationController applicationController;

    @Rule
    public ActivityTestRule<WelcomeActivity> activityTestRule = new ActivityTestRule<>(WelcomeActivity.class);

    ArgumentCaptor<Callback> argumentCaptor;

    @Before
    @Override public void setUp() {
        applicationController = (ApplicationController) InstrumentationRegistry.getTargetContext().getApplicationContext();
        applicationController.setMockMode(true);
        argumentCaptor = ArgumentCaptor.forClass(Callback.class);
        super.setUp();
    }

    @Test
    public void testLogin() throws InterruptedException {

        onView(withId(R.id.btnLogInW)).perform(click());
        onView(withId(R.id.email)).perform(typeText("good.email@example.com"));
        onView(withId(R.id.passL)).perform(typeText("strong.password"));
        onView(withId(R.id.btnLogInL)).perform(click());

        User user = new User();
        user.first_name = "Fake name";
        user.last_name = "Fake name";
        user.id = 1;
        user.email = "fake.email@gmail.com";

        AuthResponse authResponse = new AuthResponse();
        authResponse.api_key = "fake_api_key";
        authResponse.status = "ok";
        authResponse.user = user;

        Mockito.verify(api).login(Mockito.anyString(), Mockito.anyString(), Mockito.anyString(), argumentCaptor.capture());
        argumentCaptor.getValue().success(authResponse, null);

        assert true;
    }

    @After
    public void release() {
        applicationController.setMockMode(false);
    }

}

我用浓缩咖啡点击的按钮是基于材质主题的,下面可能有一些动画。结果是,当我试图运行一些指令测试时,每次我点击一次,应用程序就会崩溃。我试着在系统开发者选项中关闭动画,但没用。

Androidutil。AndroidRuntimeException:动画师只能在android的活套线程上运行。动画我是动画师。在android上启动(ValueAnimator.java:1002)。动画我是动画师。在android上启动(ValueAnimator.java:1050)。动画物体动画师。在android上启动(ObjectAnimator.java:829)。动画动画师集。在android上启动(AnimatorSet.java:585)。动画国家动画师。在android上启动(StateListAnimator.java:187)。动画国家动画师。android上的setState(StateListAnimator.java:180)。看法看法drawableStateChanged(View.java:15988)在android上。小装置。文本视图。drawableStateChanged(TextView.java:3659)在android上。看法看法android上的refreshDrawableState(View.java:16032)。看法看法android上的setEnabled(View.java:6724)。小装置。文本视图。在我的网站上设置已启用(TextView.java:1446)。应用程序。用户界面。碎片。欢迎登录片段。解锁(LoginFragment.java:263)。应用程序。用户界面。碎片。欢迎登录碎片4美元。成功(LoginFragment.java:224)。应用程序。用户界面。碎片。欢迎登录碎片4美元。成功(LoginFragment.java:222)。应用程序。欢迎参加活动测试。java的testRate(WelcomeActivityTests.java:84)。朗,反思一下。方法在java上调用(本机方法)。朗,反思一下。方法在org上调用(Method.java:372)。朱尼特。跑步者。模型框架方法1美元。在org上运行ReflectVeCall(FrameworkMethod.java:45)。朱尼特。内部的跑步者。模型可反射的。在org上运行(reflectVeCallable.java:15)。朱尼特。跑步者。模型框架方法。在org上快速调用(FrameworkMethod.java:42)。朱尼特。内部的跑步者。声明。调用方法。在org上评估(InvokeMethod.java:20)。朱尼特。内部的跑步者。声明。RunBefores。在org上评估(RunBefores.java:28)。朱尼特。内部的跑步者。声明。Runafter。在android上评估(runafter.java:30)。支持测验内部的陈述这是我的声明。在android上评估(UiThreadStatement.java:55)。支持测验规则ActivityTestRule$ActivityStatement。在org上评估(ActivityTestRule.java:257)。朱尼特。规则。规则。在org上评估(RunRules.java:18)。朱尼特。跑步者。家长跑步者。runLeaf(ParentRunner.java:263)位于org。朱尼特。跑步者。BlockJunitClassRunner。org上的runChild(BlockJUnit4ClassRunner.java:68)。朱尼特。跑步者。BlockJunitClassRunner。org上的runChild(BlockJUnit4ClassRunner.java:47)。朱尼特。跑步者。ParentRunner 3美元。在org上运行(ParentRunner.java:231)。朱尼特。跑步者。ParentRunner 1美元。日程安排(ParentRunner.java:60)在org上。朱尼特。跑步者。家长跑步者。org上的runChildren(ParentRunner.java:229)。朱尼特。跑步者。家长跑步者。访问org上的$000(ParentRunner.java:50)。朱尼特。跑步者。ParentRunner 2美元。在org上评估(ParentRunner.java:222)。朱尼特。跑步者。家长跑步者。在org上运行(ParentRunner.java:300)。朱尼特。跑步者。一套org上的runChild(Suite.java:128)。朱尼特。跑步者。一套org上的runChild(Suite.java:24)。朱尼特。跑步者。ParentRunner 3美元。在org上运行(ParentRunner.java:231)。朱尼特。跑步者。ParentRunner 1美元。日程安排(ParentRunner.java:60)在org上。朱尼特。跑步者。家长跑步者。org上的runChildren(ParentRunner.java:229)。朱尼特。跑步者。家长跑步者。访问org上的$000(ParentRunner.java:50)。朱尼特。跑步者。ParentRunner 2美元。在org上评估(ParentRunner.java:222)。朱尼特。跑步者。家长跑步者。在org上运行(ParentRunner.java:300)。朱尼特。跑步者JUnitCore。在org上运行(JUnitCore.java:157)。朱尼特。跑步者JUnitCore。在android上运行(JUnitCore.java:136)。支持测验内部的跑步者测试员。在android上执行(TestExecutor.java:54)。支持测验跑步者安德洛德·朱尼特鲁纳。android上的onStart(AndroidJUnitRunner.java:228)。应用程序。Instrumentation$InstrumentationThread。run(Instrumentation.java:1853)

这是行,崩溃我的应用程序:

btnFacebook.setEnabled(false);

编辑:我找到了正确的解决方案,寻找接受的答案。

共有2个答案

吕胤
2023-03-14

尝试在模拟线程中调用该行:

new Handler().postDelayed(new Runnable() {
    @Override
    public void run() {
        btnFacebook.setEnabled(false);
    }
}, 100);
蒯宇定
2023-03-14

好的,我找到了一个合适的解决方案!在处理使用处理程序的库和API时,需要使用@UiThreadTest注释测试用例。此外,您正在存根的每个asynchronouos回调都应该使用runOnMainSync(Runnable r)插装方法调用。例子:

    @Test
    @UiThreadTest
    public void testLoginSuccess() {

        Instrumentation.ActivityMonitor monitor = InstrumentationRegistry.getInstrumentation().addMonitor(EventsListActivity.class.getName(), null, true);

        onView(withId(R.id.btnLogInW)).perform(click());
        onView(withId(R.id.email)).perform(typeText("good.email@example.com"));
        onView(withId(R.id.passL)).perform(typeText("strong.password"));
        onView(withId(R.id.btnLogInL)).perform(click());

        User user = new User();
        user.first_name = "Fake name";
        user.last_name = "Fake name";
        user.id = 1;
        user.email = "fake.email@gmail.com";

        final AuthResponse authResponse = new AuthResponse();
        authResponse.api_key = "fake_api_key";
        authResponse.status = "ok";
        authResponse.user = user;

        Mockito.verify(api).login(Mockito.anyString(), Mockito.anyString(), Mockito.anyString(), argumentCaptor.capture());
        InstrumentationRegistry.getInstrumentation().runOnMainSync(new Runnable() {
            @Override public void run() {
                argumentCaptor.getValue().success(authResponse, null);
            }
        });

        assertThat(1, equalTo(monitor.getHits()));
        InstrumentationRegistry.getInstrumentation().removeMonitor(monitor);
    }
 类似资料:
  • 如何在docker容器中运行基于的测试用例? 我有一个简单的Spring Boot应用程序,它具有集成测试(组件级),使用与容器交互。测试用例正在破坏来自外部容器(本地机器)的罚款。 我们正在容器中运行所有内容,并且build正在docker jenkins映像上运行。Docker文件正在创建jar,然后创建image。找不到安装的docker。下面是我的docker文件。 处理这个案子最好的办法

  • 我正在评估运行移动web测试的AWS设备场。以下是我预期的步骤: 创建样本测试(Java) 打包为zip文件 通过AWS设备场控制台,仅上传测试zip 手动选择配置和其他东西 手动执行测试并评估结果 我需要帮助的事情是: a)如果测试需要一些更改,我是否需要在每次运行中完成JAR包的创建?我可以从我的IDE运行测试,如果一切正常,然后只打包并上传到AWS设备场? b) 我注意到他们有API来模拟步

  • 我遵循了谷歌关于应用内购买服务的实施说明。 我被提供了访问Google Play开发者控制台的邀请用户。我从它的私钥,并添加我的谷歌帐户到输入字段与测试帐户。之后,我craetad APK文件,并签署了它与有效的证书。然后将应用程序上传到Google Play,但没有发布。之后,我创建了需要的应用内购买并发布它们。然后在我的设备上安装了相同的签名apk文件。 我的问题是:如何测试从不同设备和帐户购

  • 如何在迭代中更改python迭代器? 例如: 此打印: 我想打印: 编辑:抱歉,这个问题让人们感到困惑。我对为什么当我在for循环中尝试更改迭代器时,for循环在下一次迭代中忽略它很感兴趣。 其他人已经提交了一个答案来清除我的困惑。范围创建一个列表,然后for循环将迭代器分配给列表中的下一个变量。

  • 问题内容: 我正在React中尝试执行以下操作(其中ObjectRow是一个单独的组件): 我意识到并理解为什么这是无效的,因为它映射到函数调用。但是,由于来自模板领域并且是的新手,所以我不确定如何实现上述目标(多次添加组件)。 问题答案: 就像您只是在调用JavaScript函数一样。您不能使用循环来调用函数的参数: 查看如何将函数作为参数传递给循环-导致语法错误。 但是您可以创建一个数组,然后

  • TL;DR:我只能对某个设备运行一次测试,然后每隔一次尝试将我的应用程序连接到ADB会话,手动或通过Appium服务器调用,都会失败。如何解决这个问题,以便能够恢复自动化测试? 我的设备的Appium desired_capabilities包括。除设备标识符之外的所有其他desired_capabilities都在所有其他设备之间共享并适用于所有其他设备。 直到将添加到一个测试中,才观察到此错误