Skip to content

Commit

Permalink
Add UI and ViewModel tests
Browse files Browse the repository at this point in the history
  • Loading branch information
sdsantos committed Jul 30, 2024
1 parent 8cf60e6 commit 6a6a3f5
Show file tree
Hide file tree
Showing 5 changed files with 98 additions and 0 deletions.
21 changes: 21 additions & 0 deletions .github/workflows/validate.yml
Original file line number Diff line number Diff line change
Expand Up @@ -67,3 +67,24 @@ jobs:
with:
name: android-lint-report
path: composeApp/build/reports/ktlint/

common-tests:
name: Common Tests
runs-on: macos-latest
needs: [ build ]

steps:
- uses: actions/checkout@v4

- name: Setup
uses: ./.github/actions/setup

- name: Run common tests
run: ./gradlew :composeApp:iosSimulatorArm64Test

- name: Uploads test reports
uses: actions/upload-artifact@v4
if: failure()
with:
name: android-lint-report
path: composeApp/build/reports/tests/iosSimulatorArm64Test/
7 changes: 7 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -40,3 +40,10 @@ besides platform-specific code that we can’t avoid, such as the loading our pr
* `shared` classes and methods shared across the whole app
* `data` data layer code (database, preferences, network...)
* `ui` UI layer code, organized into features/screens

## Testing

Common tests (tests inside `commonTest`) only run on the iOS Simulator.
Choosing the option `android (local)` won't work. This is a current
[issue](https://www.jetbrains.com/help/kotlin-multiplatform-dev/compose-test.html#f03e048) with
the official testing library.
7 changes: 7 additions & 0 deletions composeApp/build.gradle.kts
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import org.jetbrains.compose.ExperimentalComposeLibrary
import org.jetbrains.kotlin.gradle.ExperimentalKotlinGradlePluginApi
import org.jetbrains.kotlin.gradle.dsl.JvmTarget

Expand Down Expand Up @@ -83,10 +84,16 @@ kotlin {
kotlin.srcDir(config.srcRoot)
}
}
commonTest.dependencies {
implementation(kotlin("test"))
@OptIn(ExperimentalComposeLibrary::class)
implementation(compose.uiTest)
}
all {
languageSettings {
optIn("kotlinx.coroutines.ExperimentalCoroutinesApi")
optIn("androidx.compose.material3.ExperimentalMaterial3Api")
optIn("androidx.compose.ui.test.ExperimentalTestApi")
}
}
}
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
package org.ooni.probe.ui.result

import androidx.compose.ui.test.onNodeWithContentDescription
import androidx.compose.ui.test.onNodeWithText
import androidx.compose.ui.test.performClick
import androidx.compose.ui.test.runComposeUiTest
import org.ooni.probe.data.models.TestResult
import kotlin.test.Test
import kotlin.test.assertEquals

class ResultScreenTest {
@Test
fun showResult() =
runComposeUiTest {
val result = TestResult(TestResult.Id("ABCDEF"))
setContent {
ResultScreen(
state = ResultViewModel.State(result),
onEvent = {},
)
}

onNodeWithText(result.id.value).assertExists()
}

@Test
fun pressBack() =
runComposeUiTest {
val events = mutableListOf<ResultViewModel.Event>()
val result = TestResult(TestResult.Id("ABCDEF"))
setContent {
ResultScreen(
state = ResultViewModel.State(result),
onEvent = events::add,
)
}

onNodeWithContentDescription("Back").performClick()
assertEquals(1, events.size)
assertEquals(ResultViewModel.Event.BackClicked, events.first())
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
package org.ooni.probe.ui.result

import org.ooni.probe.data.models.TestResult
import kotlin.test.Test
import kotlin.test.assertTrue

class ResultViewModelTest {
@Test
fun backClicked() {
var backPressed = false

val viewModel =
ResultViewModel(
resultId = TestResult.Id("1234"),
onBack = { backPressed = true },
)

viewModel.onEvent(ResultViewModel.Event.BackClicked)
assertTrue(backPressed)
}
}

0 comments on commit 6a6a3f5

Please sign in to comment.