Držite testove determinističnim uz eksplicitne kontejnere.

Većina test scenarija direktno se mapira na ProviderContainer API-je: read, invalidate, refresh, listen i overrides po instanci provider-a.

Test Strategy

Podelite testove na čiste container testove i integracione testove widget-a.

Pure Dart

Koristite ProviderContainer direktno za read/invalidate/refresh provere

Overrides

Override-ujte po instanci provider-a sa overrideWith / overrideWithValue

Widget tests

Ubacite eksterni kontejner i eksplicitno ga oslobodite

Tip

ProviderContainer.listen ne emituje početnu vrednost osim ako fireImmediately: true nije navedeno.

Test komanda i kontrolna lista

Pokrenite ceo set i proverite da nema preostalih timer curenja u autoDispose scenarijima.

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.

Primer: override po argumentu

Provider-i porodičnog tipa se override-uju po instanci kreiranoj vašom fabričkom funkcijom.

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();
Ovaj obrazac prati README i upstream testove u miniriverpod repozitorijumu.
Widget testovi treba da uklone widget-e pre nego što oslobode spoljne kontejnere.
Koristite fake_async da biste validirali kašnjenja autoDispose i ponašanje keepAlive.

Sledeći koraci

API Reference

Otvorite brze potpise za ProviderContainer, Ref, AsyncValue i mutation API-je.

Open API Reference

Back to Overview

Vratite se na kompletnu mapu dokumentacije za miniriverpod.

Open Overview