A API de teste de unidade do Glance permite testar seu código do Glance sem inflar visualizações
ou precisar de um UI Automator. Por exemplo, a API de teste de unidade permite verificar
condições, como se os elementos estão em uma lista ou se as caixas foram
marcadas, usando comparadores como hasContentDescriptionEqualTo
ou isChecked
.
Essa API é leve e requer menos configuração. Assim, você pode realizar o desenvolvimento orientado por testes à medida que desenvolve partes individuais do widget e as organiza para melhorar a reutilização do código.
Configurar
As dependências necessárias para usar a biblioteca de testes de unidade são mostradas nos exemplos abaixo:
// 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.
Estrutura de teste
Organize funções combináveis fora da classe GlanceAppWidget
para permitir
a reutilização de código e testes de unidade. Reduza a complexidade das unidades em teste o máximo
possível.
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)
}
}
Definir o contexto e o tamanho do teste
Se a função combinável ler o contexto usando o método
LocalContext.current()
, será necessário definir um contexto usando o método LocalContext.current()
.
Caso contrário, esta etapa é opcional.
É possível usar qualquer framework de teste de unidade do Android baseado em JVM, como o Roboletric, para fornecer o contexto.
Se a função combinável acessar LocalSize
, defina o tamanho pretendido
para o teste antes de fornecer um elemento combinável no teste. O tamanho padrão é
349.dp x 455.dp, o que equivale a um widget de 5 x 4 mostrado em um dispositivo Pixel 4
no modo retrato.
- Se o AppWidget usar
sizeMode == Single
, defina-o comominWidth
eminHeight
no arquivoinfo.xml
do widget. - Se o AppWidget usar
sizeMode == Exact
, você poderá identificar os tamanhos a serem testados de maneira semelhante a como você determina um tamanho para o widget e identificar os tamanhos de paisagem e retrato em que o widget pode aparecer e testá-los. - Se o AppWidget usar
sizeMode == Responsive
, você poderá definir um dos tamanhos da lista que você fornece ao especificar osizeMode
.
A duração padrão de um tempo limite de teste é de um segundo, mas é possível transmitir uma duração
personalizada como argumento para o método runGlanceAppWidgetUnitTest
se a infraestrutura
de teste aplicar um tempo limite diferente.
Para mais informações e exemplos de código, consulte a documentação de referência de
runGlanceAppWidgetUnitTest
.