Quero executar PeriodicWork com injeções de dependência Dagger Hilt. No entanto, isso não funciona periodicamente. Eu verifiquei meu código muitas vezes. Há no máximo apenas uma mensagem de conclusão bem-sucedida do trabalho, embora eu espere receber uma mensagem a cada segundo.
Aqui está o código para MainActivity:
@AndroidEntryPoint
class MainActivity : ComponentActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContent {
RunARepeatableWorkUsingWorkManagerTheme {
val lifecycleOwner = LocalLifecycleOwner.current
LaunchedEffect(key1 = Unit ){
val workRequest = PeriodicWorkRequestBuilder<CustomWorker>(
repeatInterval = 1,
repeatIntervalTimeUnit = TimeUnit.SECONDS,)
.setBackoffCriteria(
backoffPolicy = BackoffPolicy.LINEAR,
duration = Duration.ofSeconds(5))
.build()
val workManager = WorkManager.getInstance(applicationContext)
workManager.enqueueUniquePeriodicWork("myWork", ExistingPeriodicWorkPolicy.KEEP, workRequest)
workManager.getWorkInfosForUniqueWorkLiveData("myWork")
.observe(lifecycleOwner){ it ->
it.forEach {workInfo ->
Log.d("MyWorker: MainActivity", "${workInfo.state}")
}
}
}
}
}
}
}
Meu trabalhador fica assim:
@HiltWorker
class CustomWorker @AssistedInject constructor(
@Assisted context: Context,
@Assisted workerParameters: WorkerParameters
) : CoroutineWorker(context, workerParameters){
override suspend fun doWork(): Result {
try {
println("MyWorker : The result or the worker is Success")
return Result.success()
} catch (e: Exception) {
Log.e("MyWorker: CustomWorker", "Worker failed: ${e.message}", e)
return Result.failure()
}
}
}
HiltAndroidAppIs:
@HiltAndroidApp
class AppInstance : Application(), Configuration.Provider{
@Inject lateinit var workerFactory: HiltWorkerFactory
override fun getWorkManagerConfiguration() =
Configuration.Builder()
.setWorkerFactory(workerFactory)
.build()
}
Também no arquivo de manifesto adicionei:
<provider
android:name="androidx.startup.InitializationProvider"
android:authorities="${applicationId}.androidx-startup"
android:exported="false"
tools:node="merge"
>
<meta-data
android:name="androidx.work.impl.WorkManagerInitializer"
android:value="androidx.startup"
tools:node="remove" />
</provider>
O Logcat mostra apenas:
2023-09-24 18:16:46.712 4819-4819 MyWorker: MainActivity com...epeatableworkusingworkmanager D ENQUEUED
2023-09-24 18:17:47.375 4819-4854 System.out com...epeatableworkusingworkmanager I MyWorker : The result or the worker is Success
2023-09-24 18:17:47.429 4819-4819 MyWorker: MainActivity com...epeatableworkusingworkmanager D RUNNING
2023-09-24 18:17:47.437 4819-4819 MyWorker: MainActivity com...epeatableworkusingworkmanager D ENQUEUED
E isso é tudo. A questão é: por que não vejo uma mensagem do trabalho sendo realizado a cada segundo? Eu apreciaria qualquer ajuda!
Provavelmente porque de acordo com a documentação
Você não pode ter uma solicitação de trabalho periódica a cada 1 segundo, então seu código provavelmente está funcionando, mas você não está esperando os 15 minutos para que ele seja acionado.