Dengan Glance unit test API, Anda dapat menguji kode Glance tanpa mem-inflate tampilan atau memerlukan UI Automator. Misalnya, API pengujian unit memungkinkan Anda memverifikasi
kondisi, seperti apakah elemen ada dalam daftar atau apakah kotak telah
dicentang, menggunakan pencocok seperti hasContentDescriptionEqualTo
atau isChecked
.
API ini ringan dan memerlukan lebih sedikit penyiapan, sehingga Anda dapat melakukan pengembangan berbasis pengujian saat mengembangkan setiap bagian widget dan menyusunnya untuk meningkatkan penggunaan kembali kode.
Penyiapan
Dependensi yang diperlukan untuk menggunakan library pengujian unit ditampilkan dalam contoh berikut:
// Other Glance and Compose runtime dependencies.
...
testImplementation 'androidx.glance:glance-testing:1.1.1'
testImplementation 'androidx.glance:glance-appwidget-testing:1.1.1'
testImplementation 'org.robolectric:robolectric:4.11.1'
...
// You may include additional dependencies, such as Robolectric, if your test
// needs to set a LocalContext.
Struktur pengujian
Atur fungsi composable di luar class GlanceAppWidget
untuk memungkinkan
penggunaan kembali kode dan pengujian unit. Kurangi kompleksitas unit yang diuji sebanyak mungkin.
class MyGlanceComposableTest {
@Test
fun myNewsItemComposable_largeSize_hasAuthorAsSubtitle() = runGlanceAppWidgetUnitTest {
// Prepare inputs and state
setAppWidgetSize(100.dp, 100.dp)
// Set the composable under test
provideComposable {
MyNewsItemComposable(TEST_NEWS_ITEM)
}
// Perform assertions
onNode(hasTestTag("subTitle"))
.assertHasText(TEST_NEWS_ITEM.authorName)
}
}
Menetapkan konteks dan ukuran untuk pengujian
Jika fungsi composable Anda membaca konteks menggunakan metode LocalContext.current()
, Anda harus menyetel konteks menggunakan setContext()
. Jika tidak, langkah ini bersifat opsional.
Anda dapat menggunakan framework pengujian unit Android berbasis JVM apa pun, seperti Robolectric, untuk memberikan konteks.
Jika fungsi composable Anda mengakses LocalSize
, tetapkan ukuran yang diinginkan untuk pengujian sebelum memberikan composable dalam pengujian. Ukuran defaultnya adalah
349.dp x 455.dp, yang setara dengan widget 5x4 yang ditampilkan di perangkat Pixel 4
dalam mode potret.
- Jika AppWidget Anda menggunakan
sizeMode == Single
, Anda dapat menyetelnya keminWidth
danminHeight
dalam fileinfo.xml
widget Anda. - Jika AppWidget Anda menggunakan
sizeMode == Exact
, Anda dapat mengidentifikasi ukuran yang akan diuji dengan cara yang serupa dengan cara Anda menentukan ukuran untuk widget dan mengidentifikasi ukuran lanskap dan potret yang mungkin ditampilkan widget Anda dan mengujinya. - Jika AppWidget Anda menggunakan
sizeMode == Responsive
, Anda dapat menyetelnya ke salah satu ukuran dari daftar yang Anda berikan saat menentukansizeMode
.
Durasi default untuk waktu tunggu pengujian adalah 1 detik, tetapi Anda dapat meneruskan durasi kustom sebagai argumen ke metode runGlanceAppWidgetUnitTest
jika infrastruktur pengujian Anda menerapkan waktu tunggu yang berbeda.
Untuk mengetahui informasi dan contoh kode selengkapnya, lihat dokumentasi referensi untuk
runGlanceAppWidgetUnitTest
.