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();
Tento vzor odpovídá README a upstream testům v repozitáři miniriverpod.
Widget testy by měly widgety odpojit před uvolněním externích kontejnerů.
Použijte fake_async k ověření zpoždění autoDispose a chování keepAlive.

Další kroky

API Reference

Otevřete rychlé signatury pro ProviderContainer, Ref, AsyncValue a mutation API.

Open API Reference

Back to Overview

Vraťte se k plné mapě dokumentace miniriverpodu.

Open Overview