Fix flaky UI test (#253)
* Update Kotlin and KSP * Downgrade Kaspresso to last released * Update Compose compiler extension * Fix flaky UI test * Update AGP version * Fix flakySafely scope * Fix missing system image for UI tests * Use Intel MacOS to run UI tests * Revert "Fix missing system image for UI tests" This reverts commit 9003c37315f253835f3788ab2fecd402fa5522be. * Update test device API level to 34 * Use google-atd system image source * Update managed devices declaration syntax * Use device and syntax from now in android app * Try ubuntu agent for UI tests * Use an actual emulator instead of GMD * Use only one API level 30 * Remove Android SDK setup action * Setup Gradle before AVD * Use x86_64 architecture * Replace deprecated gradle setup action * Downgrade all dependencies again * Run only app android tests * Remove managed devices
This commit is contained in:
49
.github/workflows/check.yml
vendored
49
.github/workflows/check.yml
vendored
@@ -21,7 +21,7 @@ jobs:
|
|||||||
java-version: 17
|
java-version: 17
|
||||||
|
|
||||||
- name: Setup Gradle
|
- name: Setup Gradle
|
||||||
uses: gradle/gradle-build-action@v3
|
uses: gradle/actions/setup-gradle@v3
|
||||||
|
|
||||||
- name: Setup Android SDK
|
- name: Setup Android SDK
|
||||||
uses: android-actions/setup-android@v3
|
uses: android-actions/setup-android@v3
|
||||||
@@ -41,7 +41,10 @@ jobs:
|
|||||||
report_paths: './**/build/test-results/**/TEST-*.xml'
|
report_paths: './**/build/test-results/**/TEST-*.xml'
|
||||||
|
|
||||||
uiTests:
|
uiTests:
|
||||||
runs-on: macos-latest
|
runs-on: ubuntu-latest
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
api-level: [30]
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v4
|
- uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
@@ -53,10 +56,44 @@ jobs:
|
|||||||
java-version: 17
|
java-version: 17
|
||||||
|
|
||||||
- name: Setup Gradle
|
- name: Setup Gradle
|
||||||
uses: gradle/gradle-build-action@v3
|
uses: gradle/actions/setup-gradle@v3
|
||||||
|
|
||||||
- name: Setup Android SDK
|
- name: Enable KVM group perms
|
||||||
uses: android-actions/setup-android@v3
|
run: |
|
||||||
|
echo 'KERNEL=="kvm", GROUP="kvm", MODE="0666", OPTIONS+="static_node=kvm"' | sudo tee /etc/udev/rules.d/99-kvm4all.rules
|
||||||
|
sudo udevadm control --reload-rules
|
||||||
|
sudo udevadm trigger --name-match=kvm
|
||||||
|
|
||||||
|
- name: AVD cache
|
||||||
|
uses: actions/cache@v4
|
||||||
|
id: avd-cache
|
||||||
|
with:
|
||||||
|
path: |
|
||||||
|
~/.android/avd/*
|
||||||
|
~/.android/adb*
|
||||||
|
key: avd-${{ matrix.api-level }}
|
||||||
|
|
||||||
|
- name: create AVD and generate snapshot for caching
|
||||||
|
if: steps.avd-cache.outputs.cache-hit != 'true'
|
||||||
|
uses: reactivecircus/android-emulator-runner@v2
|
||||||
|
with:
|
||||||
|
api-level: ${{ matrix.api-level }}
|
||||||
|
force-avd-creation: false
|
||||||
|
emulator-options: -no-window -gpu swiftshader_indirect -noaudio -no-boot-anim -camera-back none
|
||||||
|
arch: x86_64
|
||||||
|
disable-animations: true
|
||||||
|
disk-size: 6000M
|
||||||
|
heap-size: 600M
|
||||||
|
script: echo "Generated AVD snapshot for caching."
|
||||||
|
|
||||||
- name: Run tests
|
- name: Run tests
|
||||||
run: ./gradlew allDevicesCheck -Pandroid.testoptions.manageddevices.emulator.gpu=swiftshader_indirect
|
uses: reactivecircus/android-emulator-runner@v2
|
||||||
|
with:
|
||||||
|
api-level: ${{ matrix.api-level }}
|
||||||
|
force-avd-creation: false
|
||||||
|
emulator-options: -no-snapshot-save -no-window -gpu swiftshader_indirect -noaudio -no-boot-anim -camera-back none
|
||||||
|
arch: x86_64
|
||||||
|
disable-animations: true
|
||||||
|
disk-size: 6000M
|
||||||
|
heap-size: 600M
|
||||||
|
script: ./gradlew :app:connectedCheck
|
||||||
|
|||||||
@@ -1,6 +1,5 @@
|
|||||||
@file:Suppress("UnstableApiUsage")
|
@file:Suppress("UnstableApiUsage")
|
||||||
|
|
||||||
import com.android.build.api.dsl.ManagedVirtualDevice
|
|
||||||
import java.io.FileInputStream
|
import java.io.FileInputStream
|
||||||
import java.util.Properties
|
import java.util.Properties
|
||||||
|
|
||||||
@@ -62,17 +61,6 @@ android {
|
|||||||
execution = "ANDROIDX_TEST_ORCHESTRATOR"
|
execution = "ANDROIDX_TEST_ORCHESTRATOR"
|
||||||
}
|
}
|
||||||
|
|
||||||
testOptions {
|
|
||||||
managedDevices {
|
|
||||||
devices {
|
|
||||||
maybeCreate<ManagedVirtualDevice>("pixel2api30").apply {
|
|
||||||
device = "Pixel 2"
|
|
||||||
apiLevel = 30
|
|
||||||
systemImageSource = "aosp-atd"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
buildFeatures {
|
buildFeatures {
|
||||||
buildConfig = true
|
buildConfig = true
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,6 +5,7 @@ import gq.kirmanak.mealient.screen.AuthenticationScreen
|
|||||||
import gq.kirmanak.mealient.screen.BaseUrlScreen
|
import gq.kirmanak.mealient.screen.BaseUrlScreen
|
||||||
import gq.kirmanak.mealient.screen.DisclaimerScreen
|
import gq.kirmanak.mealient.screen.DisclaimerScreen
|
||||||
import gq.kirmanak.mealient.screen.RecipesListScreen
|
import gq.kirmanak.mealient.screen.RecipesListScreen
|
||||||
|
import gq.kirmanak.mealient.ui.disclaimer.DisclaimerViewModel
|
||||||
import io.github.kakaocup.compose.node.element.ComposeScreen.Companion.onComposeScreen
|
import io.github.kakaocup.compose.node.element.ComposeScreen.Companion.onComposeScreen
|
||||||
import io.github.kakaocup.kakao.common.utilities.getResourceString
|
import io.github.kakaocup.kakao.common.utilities.getResourceString
|
||||||
import org.junit.Before
|
import org.junit.Before
|
||||||
@@ -59,7 +60,13 @@ class FirstSetUpTest : BaseTestCase() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
okayButtonText {
|
okayButtonText {
|
||||||
assertTextContains(getResourceString(R.string.fragment_disclaimer_button_okay))
|
flakySafely(DisclaimerViewModel.FULL_COUNT_DOWN_SEC * 1_000L) {
|
||||||
|
assertTextContains(getResourceString(R.string.fragment_disclaimer_button_okay))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
okayButton {
|
||||||
|
assertIsEnabled()
|
||||||
}
|
}
|
||||||
|
|
||||||
disclaimerText {
|
disclaimerText {
|
||||||
|
|||||||
@@ -85,7 +85,7 @@ internal class DisclaimerViewModel @Inject constructor(
|
|||||||
}
|
}
|
||||||
|
|
||||||
companion object {
|
companion object {
|
||||||
private const val FULL_COUNT_DOWN_SEC = 5
|
const val FULL_COUNT_DOWN_SEC = 5
|
||||||
private const val COUNT_DOWN_TICK_PERIOD_SEC = 1
|
private const val COUNT_DOWN_TICK_PERIOD_SEC = 1
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -58,7 +58,7 @@ kspPlugin = "1.9.22-1.0.17"
|
|||||||
# https://developer.android.com/jetpack/androidx/releases/sharetarget
|
# https://developer.android.com/jetpack/androidx/releases/sharetarget
|
||||||
shareTarget = "1.2.0"
|
shareTarget = "1.2.0"
|
||||||
# https://github.com/KasperskyLab/Kaspresso/releases
|
# https://github.com/KasperskyLab/Kaspresso/releases
|
||||||
kaspresso = "1.5.5"
|
kaspresso = "1.5.4"
|
||||||
# https://developer.android.com/jetpack/androidx/releases/test
|
# https://developer.android.com/jetpack/androidx/releases/test
|
||||||
androidXTestCore = "1.5.0"
|
androidXTestCore = "1.5.0"
|
||||||
androidXTestRules = "1.5.0"
|
androidXTestRules = "1.5.0"
|
||||||
|
|||||||
Reference in New Issue
Block a user