Udržte testy deterministické s explicitnými kontajnermi.

Väčšina testovacích scenárov sa priamo mapuje na API ProviderContainer: read, invalidate, refresh, listen a prepísania pre každú inštanciu providera.

Test Strategy

Rozdeľte testy na čisté container testy a widget integračné testy.

Pure Dart

Na tvrdenia read/invalidate/refresh používajte priamo ProviderContainer

Overrides

Pre každú inštanciu providera použite overrideWith / overrideWithValue

Widget tests

Vložte externý kontajner a explicitne ho disposeujte

Tip

ProviderContainer.listen neposiela počiatočnú hodnotu, pokiaľ nie je zadané fireImmediately: true.

Príkaz na testovanie a kontrolný zoznam

Spustite celý balík a overte, že v scenároch autoDispose nezostávajú žiadne úniky časovačov.

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.

Príklad: prepísanie podľa argumentu

Provídery typu family sa prepíšu pre každú inštanciu vytvorenú vašou factory funkciou.

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();
Tento vzor kopíruje README a upstream testy v repozitári miniriverpod.
Widget testy by mali widgety odmontovať pred zrušením externých kontajnerov.
Použite fake_async na overenie oneskorení autoDispose a správania keepAlive.

Ďalšie kroky

API Reference

Otvorte rýchle podpisy pre ProviderContainer, Ref, AsyncValue a API mutácií.

Open API Reference

Back to Overview

Vráťte sa na kompletnú mapu dokumentácie pre miniriverpod.

Open Overview