diff --git a/.github/workflows/check.yml b/.github/workflows/check.yml index 17b6ad7..6726577 100644 --- a/.github/workflows/check.yml +++ b/.github/workflows/check.yml @@ -21,7 +21,7 @@ jobs: java-version: 17 - name: Setup Gradle - uses: gradle/gradle-build-action@v3 + uses: gradle/actions/setup-gradle@v3 - name: Setup Android SDK uses: android-actions/setup-android@v3 @@ -41,7 +41,10 @@ jobs: report_paths: './**/build/test-results/**/TEST-*.xml' uiTests: - runs-on: macos-latest + runs-on: ubuntu-latest + strategy: + matrix: + api-level: [30] steps: - uses: actions/checkout@v4 with: @@ -53,10 +56,44 @@ jobs: java-version: 17 - name: Setup Gradle - uses: gradle/gradle-build-action@v3 + uses: gradle/actions/setup-gradle@v3 - - name: Setup Android SDK - uses: android-actions/setup-android@v3 + - name: Enable KVM group perms + 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 - 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 diff --git a/app/build.gradle.kts b/app/build.gradle.kts index 362254d..36fecbd 100644 --- a/app/build.gradle.kts +++ b/app/build.gradle.kts @@ -1,6 +1,5 @@ @file:Suppress("UnstableApiUsage") -import com.android.build.api.dsl.ManagedVirtualDevice import java.io.FileInputStream import java.util.Properties @@ -62,17 +61,6 @@ android { execution = "ANDROIDX_TEST_ORCHESTRATOR" } - testOptions { - managedDevices { - devices { - maybeCreate("pixel2api30").apply { - device = "Pixel 2" - apiLevel = 30 - systemImageSource = "aosp-atd" - } - } - } - } buildFeatures { buildConfig = true } diff --git a/app/src/androidTest/kotlin/gq/kirmanak/mealient/FirstSetUpTest.kt b/app/src/androidTest/kotlin/gq/kirmanak/mealient/FirstSetUpTest.kt index 1821d16..e9eb09d 100644 --- a/app/src/androidTest/kotlin/gq/kirmanak/mealient/FirstSetUpTest.kt +++ b/app/src/androidTest/kotlin/gq/kirmanak/mealient/FirstSetUpTest.kt @@ -5,6 +5,7 @@ import gq.kirmanak.mealient.screen.AuthenticationScreen import gq.kirmanak.mealient.screen.BaseUrlScreen import gq.kirmanak.mealient.screen.DisclaimerScreen 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.kakao.common.utilities.getResourceString import org.junit.Before @@ -59,7 +60,13 @@ class FirstSetUpTest : BaseTestCase() { } 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 { diff --git a/app/src/main/java/gq/kirmanak/mealient/ui/disclaimer/DisclaimerViewModel.kt b/app/src/main/java/gq/kirmanak/mealient/ui/disclaimer/DisclaimerViewModel.kt index 53d407b..c6b4ddc 100644 --- a/app/src/main/java/gq/kirmanak/mealient/ui/disclaimer/DisclaimerViewModel.kt +++ b/app/src/main/java/gq/kirmanak/mealient/ui/disclaimer/DisclaimerViewModel.kt @@ -85,7 +85,7 @@ internal class DisclaimerViewModel @Inject constructor( } 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 } } \ No newline at end of file diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index 5e43620..334add9 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -58,7 +58,7 @@ kspPlugin = "1.9.22-1.0.17" # https://developer.android.com/jetpack/androidx/releases/sharetarget shareTarget = "1.2.0" # https://github.com/KasperskyLab/Kaspresso/releases -kaspresso = "1.5.5" +kaspresso = "1.5.4" # https://developer.android.com/jetpack/androidx/releases/test androidXTestCore = "1.5.0" androidXTestRules = "1.5.0"