Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update uiauto library, extend framework to allow jank-testing and add new JetNews jank-testing workload #1268

Open
wants to merge 21 commits into
base: master
Choose a base branch
from

Conversation

luis-machado-arm
Copy link

No description provided.

…pport and into androidx

Currently the uiauto library is built on top of the deprecated android.support
libraries. Create an updated uiauto library (uiauto-androidx) using androidx
and keep it alongside the old one for compatibility reasons.

As we update workload-automation going forward, we should update the workloads
to use the androidx version of uiauto.

This has been tested with the latest gradle version available at the time
(8.8).
Jank testing involves using a different library (JankTestBase) that our
testing class needs to extend. Since we already make the base testing
class UiAutomation extend BaseUiAutomation, we cannot use the UiAutomation
class for our tests.

The uiauto_class property is hardcoded to "UiAutomation" though, so this
patch adds a uiauto_jank_class property for the Jank test class.

While at it, we also make the uiauto_runner configurable (currently hardcoded
to the old deprecated android.support version of it) so that our workloads
can pass whatever runner they need to use.

In terms of stages for testing, their current names are the following:

stages = ['setup', 'runWorkload', 'extractResults', 'teardown']

Those won't work for jank tests. For some reason the jank test library wants
to see the testing function name contain or start with a "test" string
pattern on it.

This behavior doesn't seem to be documented, but at least with the current
version of the JankTestBase library we have this restriction.

To make things work despite this restriction, I've added separate jank
test stages that can be provided by the workload. The generic workload
code will use these stages to generate the instrumentation invocation
command, and the provided jank test stages (essentially jank test
functions) will be invoked one by one.

Finally, we make the UiAutomatorGUI's _execute method return the output
of the execution so the workload can freely process and pattern-match
the results, like the UiBenchJankTests workload.
This patch adds the JetNews jank-testing workload. This is accomplished
through the uiauto helper library and the jank test classes.

This workload requires a JetNews app APK to be available. We plan to
make it available through the workload-automation-assets repo.

At the end of the run, users should end up with a json file containing all
the frame/jank metrics.

There are 3 parameters for this workload:

- tests: Specifies which of the 3 available tests to run (default is to run
         all of them)

- flingspeed: The speed of the fling interactions.

- repeat: How many times each of the selected tests is to be executed in a
          single measuring session.
@luis-machado-arm
Copy link
Author

@marcbonnici this PR replaces the previous patch to add a JetNews workload. This approach leverages the existing uiauto library and seems cleaner. Could you please take a look at it and let me know what you think?

Copy link
Contributor

@marcbonnici marcbonnici left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This seems good to me so far. I've left some high level thoughts/comments.
Plmk what you think. Thanks

wa/framework/uiauto/app/build.gradle Outdated Show resolved Hide resolved
wa/framework/workload.py Outdated Show resolved Hide resolved
wa/workloads/jetnews/__init__.py Outdated Show resolved Hide resolved
wa/workloads/jetnews/__init__.py Outdated Show resolved Hide resolved
wa/workloads/jetnews/__init__.py Outdated Show resolved Hide resolved
wa/workloads/jetnews/__init__.py Outdated Show resolved Hide resolved
We don't want to change the old uiauto library at the moment. We will
update uiauto along with each workload using it.
- Add JetNews workload description.
- Fixup copyright years.
- Adjust formatting.
- Add constraints to the workload's parameters.
- Fix comment typos.
- Remove unused commented-out code from app/build.gradle.
@luis-machado-arm
Copy link
Author

Updated the code based on the comments, pending the two comments above.

Update timestamp to match date the file was created.
Update the copyright years in the headers of files to match the
year they were created.
Restore UiAutomatorGUI back to what it was, as we don't want to
change the existing generic code for implementing the jank test
workloads.
Create two new classes to deal with workloads for which we want to
collect frame metrics/jank percentages.

ApkUiautoJankTestWorkload inherits from ApkUiautoWorkload and instantiates
a UiAutomatorJankTestGUI gui member.

UiAutomatorJankTestGUI (inherits from UiAutomatorGUI) handles most of the
new logic for jank tests, including using a regular expression to parse the
final output.
… in a simpler way

Modify the JetNews workload to use the new jank testing classes. This allows
simplification of the code and also makes it more straightforward to implement
new workloads that also need to gather frame metrics.
@luis-machado-arm
Copy link
Author

luis-machado-arm commented Aug 29, 2024

These new 5 commits achieve the following:

  • Cleanup of timestamps / copyright years ([761cab1] and [94fa1be])
  • Rollback the changes to UiAutomatorGUI. [aa41d4d]
  • New classes that can be used to create workloads that gather frame metrics and use UiAutomator. [7b53b98]
  • Update the JetNews workload to use the new classes. [fefaa3c]

@luis-machado-arm
Copy link
Author

I'm not sure if the R0901 issue caught by linters/tests is of any concern. The workload classes seem to be split into a number of different layers already.

@luis-machado-arm
Copy link
Author

Ping @marcbonnici.

@marcbonnici
Copy link
Contributor

I'm not sure if the R0901 issue caught by linters/tests is of any concern. The workload classes seem to be split into a number of different layers already.

I'm not sure if the R0901 issue caught by linters/tests is of any concern. The workload classes seem to be split into a number of different layers already.

I agree this looks reasonable to me. Would it be possible to add a # pylint: disable... just to keep the linter happy?

Copy link
Contributor

@marcbonnici marcbonnici left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Apologies for the delayed response.

The workload code / structure looks good to me, although I ran into issues attempting to execute the workload on my emulator (error listed in the comments).

// Scroll to the first postcard in the list.
mDevice.wait(Until.findObject(By.res(MAIN_VIEW)), DEFAULT_TIMEOUT);
UiObject2 articles = mDevice.findObject(By.res(MAIN_VIEW));
ViewMatchers.assertThat(articles, CoreMatchers.notNullValue());
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Attempting to run this test on my emulator with the latest jetnews app results in the following crash.

2024-09-12 17:29:36,628 ERROR        signal:         INSTRUMENTATION_STATUS: class=com.arm.wa.uiauto.jetnews.UiAutomationJankTests
2024-09-12 17:29:36,628 ERROR        signal:         INSTRUMENTATION_STATUS: current=1
2024-09-12 17:29:36,628 ERROR        signal:         INSTRUMENTATION_STATUS: id=AndroidJUnitRunner
2024-09-12 17:29:36,628 ERROR        signal:         INSTRUMENTATION_STATUS: numtests=1
2024-09-12 17:29:36,628 ERROR        signal:         INSTRUMENTATION_STATUS: stream=
2024-09-12 17:29:36,628 ERROR        signal:         com.arm.wa.uiauto.jetnews.UiAutomationJankTests:
2024-09-12 17:29:36,628 ERROR        signal:         INSTRUMENTATION_STATUS: test=test1
2024-09-12 17:29:36,628 ERROR        signal:         INSTRUMENTATION_STATUS_CODE: 1
2024-09-12 17:29:36,628 ERROR        signal:         INSTRUMENTATION_STATUS: class=com.arm.wa.uiauto.jetnews.UiAutomationJankTests
2024-09-12 17:29:36,628 ERROR        signal:         INSTRUMENTATION_STATUS: current=1
2024-09-12 17:29:36,628 ERROR        signal:         INSTRUMENTATION_STATUS: id=AndroidJUnitRunner
2024-09-12 17:29:36,628 ERROR        signal:         INSTRUMENTATION_STATUS: numtests=1
2024-09-12 17:29:36,628 ERROR        signal:         INSTRUMENTATION_STATUS: stack=java.lang.reflect.InvocationTargetException
2024-09-12 17:29:36,628 ERROR        signal:         	at java.lang.reflect.Method.invoke(Native Method)
2024-09-12 17:29:36,628 ERROR        signal:         	at androidx.test.jank.JankTestBase.runTest(JankTestBase.java:174)
2024-09-12 17:29:36,628 ERROR        signal:         	... 26 trimmed
2024-09-12 17:29:36,628 ERROR        signal:         Caused by: junit.framework.AssertionFailedError:
2024-09-12 17:29:36,628 ERROR        signal:         Expected: not null
2024-09-12 17:29:36,628 ERROR        signal:              Got: was null
2024-09-12 17:29:36,628 ERROR        signal:
2024-09-12 17:29:36,628 ERROR        signal:         	at androidx.test.espresso.matcher.ViewMatchers.assertThat(ViewMatchers.java:16)
2024-09-12 17:29:36,628 ERROR        signal:         	at androidx.test.espresso.matcher.ViewMatchers.assertThat(ViewMatchers.java:1)
2024-09-12 17:29:36,628 ERROR        signal:         	at com.arm.wa.uiauto.jetnews.UiAutomationJankTests.runPortraitVerticalTests(UiAutomationJankTests.java:116)
2024-09-12 17:29:36,628 ERROR        signal:         	at com.arm.wa.uiauto.jetnews.UiAutomationJankTests.test1(UiAutomationJankTests.java:88)
2024-09-12 17:29:36,628 ERROR        signal:         	... 29 more
2024-09-12 17:29:36,628 ERROR        signal:
2024-09-12 17:29:36,628 ERROR        signal:         INSTRUMENTATION_STATUS: stream=
2024-09-12 17:29:36,628 ERROR        signal:         Error in test1(com.arm.wa.uiauto.jetnews.UiAutomationJankTests):
2024-09-12 17:29:36,628 ERROR        signal:         java.lang.reflect.InvocationTargetException
2024-09-12 17:29:36,628 ERROR        signal:         	at java.lang.reflect.Method.invoke(Native Method)
2024-09-12 17:29:36,628 ERROR        signal:         	at androidx.test.jank.JankTestBase.runTest(JankTestBase.java:174)
2024-09-12 17:29:36,628 ERROR        signal:         	... 26 trimmed
2024-09-12 17:29:36,628 ERROR        signal:         Caused by: junit.framework.AssertionFailedError:
2024-09-12 17:29:36,628 ERROR        signal:         Expected: not null
2024-09-12 17:29:36,628 ERROR        signal:              Got: was null
2024-09-12 17:29:36,628 ERROR        signal:
2024-09-12 17:29:36,628 ERROR        signal:         	at androidx.test.espresso.matcher.ViewMatchers.assertThat(ViewMatchers.java:16)
2024-09-12 17:29:36,628 ERROR        signal:         	at androidx.test.espresso.matcher.ViewMatchers.assertThat(ViewMatchers.java:1)
2024-09-12 17:29:36,628 ERROR        signal:         	at com.arm.wa.uiauto.jetnews.UiAutomationJankTests.runPortraitVerticalTests(UiAutomationJankTests.java:116)
2024-09-12 17:29:36,628 ERROR        signal:         	at com.arm.wa.uiauto.jetnews.UiAutomationJankTests.test1(UiAutomationJankTests.java:88)
2024-09-12 17:29:36,628 ERROR        signal:         	... 29 more
2024-09-12 17:29:36,628 ERROR        signal:
2024-09-12 17:29:36,628 ERROR        signal:         INSTRUMENTATION_STATUS: test=test1
2024-09-12 17:29:36,628 ERROR        signal:         INSTRUMENTATION_STATUS_CODE: -2
2024-09-12 17:29:36,628 ERROR        signal:         INSTRUMENTATION_RESULT: stream=
2024-09-12 17:29:36,628 ERROR        signal:
2024-09-12 17:29:36,628 ERROR        signal:         Time: 1.761
2024-09-12 17:29:36,628 ERROR        signal:         There was 1 failure:
2024-09-12 17:29:36,628 ERROR        signal:         1) test1(com.arm.wa.uiauto.jetnews.UiAutomationJankTests)
2024-09-12 17:29:36,628 ERROR        signal:         java.lang.reflect.InvocationTargetException
2024-09-12 17:29:36,628 ERROR        signal:         	at java.lang.reflect.Method.invoke(Native Method)
2024-09-12 17:29:36,628 ERROR        signal:         	at androidx.test.jank.JankTestBase.runTest(JankTestBase.java:174)
2024-09-12 17:29:36,628 ERROR        signal:         	... 26 trimmed
2024-09-12 17:29:36,628 ERROR        signal:         Caused by: junit.framework.AssertionFailedError:
2024-09-12 17:29:36,628 ERROR        signal:         Expected: not null
2024-09-12 17:29:36,628 ERROR        signal:              Got: was null
2024-09-12 17:29:36,628 ERROR        signal:
2024-09-12 17:29:36,628 ERROR        signal:         	at androidx.test.espresso.matcher.ViewMatchers.assertThat(ViewMatchers.java:16)
2024-09-12 17:29:36,628 ERROR        signal:         	at androidx.test.espresso.matcher.ViewMatchers.assertThat(ViewMatchers.java:1)
2024-09-12 17:29:36,628 ERROR        signal:         	at com.arm.wa.uiauto.jetnews.UiAutomationJankTests.runPortraitVerticalTests(UiAutomationJankTests.java:116)
2024-09-12 17:29:36,628 ERROR        signal:         	at com.arm.wa.uiauto.jetnews.UiAutomationJankTests.test1(UiAutomationJankTests.java:88)
2024-09-12 17:29:36,628 ERROR        signal:         	... 29 more
2024-09-12 17:29:36,628 ERROR        signal:
2024-09-12 17:29:36,628 ERROR        signal:         FAILURES!!!
2024-09-12 17:29:36,628 ERROR        signal:         Tests run: 1,  Failures: 1
2024-09-12 17:29:36,628 ERROR        signal:
2024-09-12 17:29:36,628 ERROR        signal:
2024-09-12 17:29:36,628 ERROR        signal:         INSTRUMENTATION_CODE: -1

Do you see the same behaviour?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Did you use the stock jetnews app? If so, it doesn't have the required code, so I'd expect it to fail. You need a modified version of JetNews with test tags and additional articles.

I have shared a page that contains both the apk and the repository that can be used to build it from sources.

@@ -0,0 +1 @@
android.useAndroidX=true
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Apologies for the late comment on this, but IIUC it seems that this is currently the main meaningful difference between the uiauto and uiauto-androidx directory trees?

I.e. If I do a diff on these these directories, this is my output:

Common subdirectories: uiauto/app and uiauto-androidx/app
diff --color uiauto/build.gradle uiauto-androidx/build.gradle
5d4
<         jcenter()
6a6
>         mavenCentral()
9c9
<         classpath 'com.android.tools.build:gradle:7.2.1'
---
>         classpath 'com.android.tools.build:gradle:8.5.0'
11d10
<
13c12
<         // in the individual module build.gradle files
---
>     // in the individual module build.gradle files
19d17
<         jcenter()
20a19
>         mavenCentral()
diff --color uiauto/build.sh uiauto-androidx/build.sh
2c2
< #    Copyright 2013-2017 ARM Limited
---
> #    Copyright 2013-2024 ARM Limited
Common subdirectories: uiauto/gradle and uiauto-androidx/gradle
Only in uiauto-androidx: gradle.properties
Binary files uiauto/uiauto.aar and uiauto-androidx/uiauto.aar differ

Therefore I'm wondering if we really need the two trees here currently as I'm concerned about the duplication while we transition over to the new libraries.

Do you think it would be possible to instead just have 2 gradle.properties files and 2 build scripts in the same tree?
One that sets this property to True and one that sets it to False? That way we could maintain the same source tree but would still be able to build both versions of the library?

Plmk if I'm missing something that would make this a non-starter.

Copy link
Author

@luis-machado-arm luis-machado-arm Sep 13, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

On my end, the differences between wa/framework/uiauto and wa/framework/uiauto-androidx are a bit more significant:

--- uiauto/app/build.gradle	2024-07-26 15:42:00.889125106 +0100
+++ uiauto-androidx/app/build.gradle	2024-07-26 15:40:54.948614211 +0100
@@ -1,18 +1,18 @@
 apply plugin: 'com.android.library'
 
 android {
+    namespace "com.arm.wa.uiauto"
     compileSdkVersion 28
-    buildToolsVersion '28.0.3'
     defaultConfig {
         minSdkVersion 18
         targetSdkVersion 28
-        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
+        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
     }
 }
 
 dependencies {
     implementation fileTree(include: ['*.jar'], dir: 'libs')
-    implementation 'com.android.support.test:runner:0.5'
-    implementation 'com.android.support.test:rules:0.5'
-    implementation 'com.android.support.test.uiautomator:uiautomator-v18:2.1.2'
+    implementation 'androidx.test:runner:1.6.1'
+    implementation 'androidx.test:rules:1.6.1'
+    implementation 'androidx.test.uiautomator:uiautomator-v18:2.2.0-alpha1'
 }
diff -up -r uiauto/app/src/main/AndroidManifest.xml uiauto-androidx/app/src/main/AndroidManifest.xml
--- uiauto/app/src/main/AndroidManifest.xml	2024-07-26 15:40:54.948614211 +0100
+++ uiauto-androidx/app/src/main/AndroidManifest.xml	2024-07-26 15:40:54.948614211 +0100
@@ -1,5 +1,4 @@
-<manifest xmlns:android="http://schemas.android.com/apk/res/android"
-    package="com.arm.wa.uiauto">
+<manifest xmlns:android="http://schemas.android.com/apk/res/android">
 
     <uses-permission android:name="android.permission.READ_LOGS"/>
 
diff -up -r uiauto/app/src/main/java/com/arm/wa/uiauto/ActionLogger.java uiauto-androidx/app/src/main/java/com/arm/wa/uiauto/ActionLogger.java
--- uiauto/app/src/main/java/com/arm/wa/uiauto/ActionLogger.java	2024-07-26 15:40:54.948614211 +0100
+++ uiauto-androidx/app/src/main/java/com/arm/wa/uiauto/ActionLogger.java	2024-08-29 11:09:59.184231510 +0100
@@ -1,4 +1,4 @@
-/*    Copyright 2014-2018 ARM Limited
+/*    Copyright 2014-2024 ARM Limited
  *
  * Licensed under the Apache License, Version 2.0 (the "License");
  * you may not use this file except in compliance with the License.
diff -up -r uiauto/app/src/main/java/com/arm/wa/uiauto/ApplaunchInterface.java uiauto-androidx/app/src/main/java/com/arm/wa/uiauto/ApplaunchInterface.java
--- uiauto/app/src/main/java/com/arm/wa/uiauto/ApplaunchInterface.java	2024-07-26 15:40:54.948614211 +0100
+++ uiauto-androidx/app/src/main/java/com/arm/wa/uiauto/ApplaunchInterface.java	2024-08-29 11:09:59.184231510 +0100
@@ -1,4 +1,4 @@
-/*    Copyright 2013-2017 ARM Limited
+/*    Copyright 2013-2024 ARM Limited
  *
  * Licensed under the Apache License, Version 2.0 (the "License");
  * you may not use this file except in compliance with the License.
@@ -16,7 +16,7 @@
 package com.arm.wa.uiauto;
 
 import android.os.Bundle;
-import android.support.test.uiautomator.UiObject;
+import androidx.test.uiautomator.UiObject;
 
 /**
  * ApplaunchInterface.java
diff -up -r uiauto/app/src/main/java/com/arm/wa/uiauto/BaseUiAutomation.java uiauto-androidx/app/src/main/java/com/arm/wa/uiauto/BaseUiAutomation.java
--- uiauto/app/src/main/java/com/arm/wa/uiauto/BaseUiAutomation.java	2024-07-26 15:40:54.952614242 +0100
+++ uiauto-androidx/app/src/main/java/com/arm/wa/uiauto/BaseUiAutomation.java	2024-08-29 11:09:59.188231543 +0100
@@ -1,4 +1,4 @@
-/*    Copyright 2013-2018 ARM Limited
+/*    Copyright 2013-2024 ARM Limited
  *
  * Licensed under the Apache License, Version 2.0 (the "License");
  * you may not use this file except in compliance with the License.
@@ -22,13 +22,13 @@ import android.content.Context;
 import android.graphics.Point;
 import android.graphics.Rect;
 
-import android.support.test.InstrumentationRegistry;
-import android.support.test.uiautomator.UiDevice;
-import android.support.test.uiautomator.UiObject;
-import android.support.test.uiautomator.UiObjectNotFoundException;
-import android.support.test.uiautomator.UiSelector;
-import android.support.test.uiautomator.UiWatcher;
-import android.support.test.uiautomator.UiScrollable;
+import androidx.test.InstrumentationRegistry;
+import androidx.test.uiautomator.UiDevice;
+import androidx.test.uiautomator.UiObject;
+import androidx.test.uiautomator.UiObjectNotFoundException;
+import androidx.test.uiautomator.UiSelector;
+import androidx.test.uiautomator.UiWatcher;
+import androidx.test.uiautomator.UiScrollable;
 
 import org.junit.Before;
 import org.junit.Test;
@@ -39,7 +39,7 @@ import java.io.InputStreamReader;
 import java.util.concurrent.TimeUnit;
 import java.util.concurrent.TimeoutException;
 
-import static android.support.test.InstrumentationRegistry.getArguments;
+import static androidx.test.InstrumentationRegistry.getArguments;
 
 public class BaseUiAutomation {
 
diff -up -r uiauto/app/src/main/java/com/arm/wa/uiauto/UiAutoUtils.java uiauto-androidx/app/src/main/java/com/arm/wa/uiauto/UiAutoUtils.java
--- uiauto/app/src/main/java/com/arm/wa/uiauto/UiAutoUtils.java	2024-07-26 15:40:54.952614242 +0100
+++ uiauto-androidx/app/src/main/java/com/arm/wa/uiauto/UiAutoUtils.java	2024-08-29 11:09:59.188231543 +0100
@@ -1,4 +1,4 @@
-/*    Copyright 2013-2017 ARM Limited
+/*    Copyright 2013-2024 ARM Limited
  *
  * Licensed under the Apache License, Version 2.0 (the "License");
  * you may not use this file except in compliance with the License.
diff -up -r uiauto/app/src/main/java/com/arm/wa/uiauto/UxPerfUiAutomation.java uiauto-androidx/app/src/main/java/com/arm/wa/uiauto/UxPerfUiAutomation.java
--- uiauto/app/src/main/java/com/arm/wa/uiauto/UxPerfUiAutomation.java	2024-07-26 15:40:54.952614242 +0100
+++ uiauto-androidx/app/src/main/java/com/arm/wa/uiauto/UxPerfUiAutomation.java	2024-08-29 11:09:59.188231543 +0100
@@ -1,4 +1,4 @@
-/*    Copyright 2013-2017 ARM Limited
+/*    Copyright 2013-2024 ARM Limited
  *
  * Licensed under the Apache License, Version 2.0 (the "License");
  * you may not use this file except in compliance with the License.
diff -up -r uiauto/build.gradle uiauto-androidx/build.gradle
--- uiauto/build.gradle	2024-07-26 15:41:53.129065105 +0100
+++ uiauto-androidx/build.gradle	2024-07-26 15:40:54.948614211 +0100
@@ -2,22 +2,21 @@
 
 buildscript {
     repositories {
-        jcenter()
         google()
+        mavenCentral()
     }
     dependencies {
-        classpath 'com.android.tools.build:gradle:7.2.1'
-
+        classpath 'com.android.tools.build:gradle:8.5.0'
 
     // NOTE: Do not place your application dependencies here; they belong
-        // in the individual module build.gradle files
+    // in the individual module build.gradle files
     }
 }
 
 allprojects {
     repositories {
-        jcenter()
         google()
+        mavenCentral()
     }
 }
 
diff -up -r uiauto/build.sh uiauto-androidx/build.sh
--- uiauto/build.sh	2024-07-26 15:40:54.952614242 +0100
+++ uiauto-androidx/build.sh	2024-08-29 11:09:59.188231543 +0100
@@ -1,5 +1,5 @@
 #!/bin/bash
-#    Copyright 2013-2017 ARM Limited
+#    Copyright 2013-2024 ARM Limited
 #
 # Licensed under the Apache License, Version 2.0 (the "License");
 # you may not use this file except in compliance with the License.
diff -up -r uiauto/gradle/wrapper/gradle-wrapper.properties uiauto-androidx/gradle/wrapper/gradle-wrapper.properties
--- uiauto/gradle/wrapper/gradle-wrapper.properties	2024-07-26 15:40:54.952614242 +0100
+++ uiauto-androidx/gradle/wrapper/gradle-wrapper.properties	2024-08-29 11:09:59.188231543 +0100
@@ -1,6 +1,6 @@
-#Wed May 03 15:42:44 BST 2017
+#Tue 27 Aug 2024 12:28:27 PM BST
 distributionBase=GRADLE_USER_HOME
 distributionPath=wrapper/dists
 zipStoreBase=GRADLE_USER_HOME
 zipStorePath=wrapper/dists
-distributionUrl=https\://services.gradle.org/distributions/gradle-7.3.3-all.zip
+distributionUrl=https\://services.gradle.org/distributions/gradle-8.8-all.zip
Only in uiauto-androidx: gradle.properties```

For the androidx version there were version bumps for the libraries, removal of deprecated properties (buildToolsVersion IIRC), updates to the JUNIT runner (to use the androidx one), the gradle version, the repositories to fetch libraries from and changes to the uiauto app itself to use androidx libraries.

The way I see it, we want to update all the other apps to use the updated uiauto framework using androidx, because the older android support library is now deprecated. Unfortunately I was never able to chase the right versions of the apk's for some of the workloads. So it is a bit tricky to test and make sure they work. In the end, I considered keeping the original uiauto framework as-is for now, in the hopes it would still work for whoever still has those valid apk's.

I'm not sure I have the cycles to look into this at the moment, but we could probably coordinate internally to get this updated so we don't have to use deprecated libraries.

Drop the warning as we already have cases where it was disabled in geekbench
and gfxbench.
@luis-machado-arm
Copy link
Author

I'm not sure if the R0901 issue caught by linters/tests is of any concern. The workload classes seem to be split into a number of different layers already.

I'm not sure if the R0901 issue caught by linters/tests is of any concern. The workload classes seem to be split into a number of different layers already.

I agree this looks reasonable to me. Would it be possible to add a # pylint: disable... just to keep the linter happy?

Done now.

@luis-machado-arm
Copy link
Author

I think I managed to get all the checks happy now. :-)

@luis-machado-arm
Copy link
Author

@marcbonnici , the modified jewnews sources are now available publicly here: https://gitlab.arm.com/tooling/workload-automation-compose-samples.

You can build it by cloning, going into the JetNews subdir and...
./gradlew clean :app:assembleDebug

Make sure you have the AndroidSDK on the path. If within a LISA environment, you should have that set.

… phones

On tablets we have a landscape view by default, so we need to account for that
in our tests. On smaller phones, the landscape mode doesn't show the article
preview.

On both tablets and small screen phones, we need to be mindful of scrolling
too fast and missing an element we're looking for, either because a bigger
screen means we scroll faster or because a smaller screen means only a few
items are shown at one time.
I noticed we were sometimes getting stale object exceptions. To help prevent
that situation from happening, pass around resource id's for the objects and
only fetch an instance of the objects whenever we need to click/scroll.

This means the time between fetching the object and using it is short, and
hopefully the object won't go stale or get recycled in that brief moment,
preventing the stale exceptions.
… to 34

API level 27 (Android 8.1/Oreo) doesn't report a frame metric called
"deadline missed", but the JankTest library expects to be able to find
data for that metric. If it is not found, an assertion is reported and
the run fails.

Given Android Oreo is reasonably old at this point, set the minimum SDK
version to 28 so we can gather all the metrics we need.

Also bump the targetSdkVersion to make it clear what version was used
for putting this code together.
@luis-machado-arm
Copy link
Author

After looking into the latest reported assertion (regarding not finding deadline missed metrics), the last two commits bump the minimum API level to 28, as that is the minimum version that includes the deadline missed metrics. Unfortunately supporting older API levels, though possible, would make things more complicated for little benefit.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants