Udržujte testy deterministické pomocí explicitních kontejnerů.
Většina testovacích scénářů se přímo mapuje na API ProviderContaineru: read, invalidate, refresh, listen a override pro každou instanci provideru.
Test Strategy
Rozdělte testy na čisté container testy a integrační testy widgetů.
Pure Dart
Používejte ProviderContainer přímo pro read/invalidate/refresh tvrzení
Overrides
Přepisujte podle instance provideru pomocí overrideWith / overrideWithValue
Widget tests
Vkládejte externí kontejner a explicitně jej uvolněte
Tip
ProviderContainer.listen nevysílá počáteční hodnotu, pokud není uvedeno fireImmediately: true.
Testovací příkaz a kontrolní seznam
Spusťte celou sadu a ověřte, že ve scénářích autoDispose nejsou žádné čekající úniky timerů.
Command
Checklist
- Dispose externally injected ProviderContainer in tearDown.
- Use fireImmediately: true when your listener assertions need initial state.
- For autoDispose tests, advance fake time beyond autoDisposeDelay.
Příklad: override podle argumentu
Providery rodinného typu se přepisují pro každou instanci vytvořenou vaší tovární funkcí.
class ProductById extends Provider<Product> {
ProductById(this.id) : super.args((id,));
final String id;
@override
Product build(ref) {
final repo = ref.watch(productRepoProvider);
return repo.fetch(id);
}
}
final container = ProviderContainer(
overrides: [
productByIdProvider('a').overrideWithValue(const Product(id: 'a', name: 'stub')),
],
);
// assert and cleanup
container.dispose();
Další kroky
API Reference
Otevřete rychlé signatury pro ProviderContainer, Ref, AsyncValue a mutation API.
Open API Reference