API pengujian unit Glance memungkinkan Anda menguji kode Glance tanpa meng-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 yang didorong pengujian saat mengembangkan setiap bagian widget dan mengaturnya 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.0'
testImplementation 'androidx.glance:glance-AppWidget-testing:1.1.0'
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 mengaktifkan
penggunaan kembali kode dan pengujian unit. Kurangi kompleksitas unit yang sedang 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 membaca konteks menggunakan metode
LocalContext.current()
, Anda harus menetapkan konteks menggunakan metode LocalContext.current()
.
Jika tidak, langkah ini bersifat opsional.
Anda dapat menggunakan framework pengujian unit Android berbasis JVM, seperti Roboletric, untuk menyediakan 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 menggunakan
sizeMode == Single
, Anda dapat menetapkannya keminWidth
danminHeight
dalam fileinfo.xml
widget. - Jika AppWidget Anda menggunakan
sizeMode == Exact
, Anda dapat mengidentifikasi ukuran yang akan diuji dengan cara yang mirip dengan cara Anda menentukan ukuran untuk widget dan mengidentifikasi ukuran lanskap dan potret tempat widget Anda mungkin muncul dan mengujinya. - Jika AppWidget menggunakan
sizeMode == Responsive
, Anda dapat menetapkannya 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 informasi selengkapnya dan contoh kode, lihat dokumentasi referensi untuk
runGlanceAppWidgetUnitTest
.