Išlaikykite testus deterministiškus su aiškiais konteineriais.

Dauguma testavimo scenarijų tiesiogiai atitinka ProviderContainer API: read, invalidate, refresh, listen ir kiekvieno provider egzemplioriaus override’us.

Test Strategy

Padalinkite testus į grynuosius container testus ir widgetų integracijos testus.

Pure Dart

Naudokite ProviderContainer tiesiogiai read/invalidate/refresh teiginiams

Overrides

Perrašykite pagal provider egzempliorių su overrideWith / overrideWithValue

Widget tests

Įdiekite išorinį konteinerį ir aiškiai jį atlaisvinkite

Tip

ProviderContainer.listen neišleidžia pradinės reikšmės, nebent nurodyta fireImmediately: true.

Testo komanda ir kontrolinis sąrašas

Paleiskite visą rinkinį ir įsitikinkite, kad autoDispose scenarijuose nėra laukiančių timer nuotėkių.

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.

Pavyzdys: override pagal argumentą

Šeimos tipo provideriai perrašomi kiekvienam egzemplioriui, sukurtam jūsų fabriko funkcijos.

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();
Šis šablonas atitinka README ir upstream testus miniriverpod saugykloje.
Widgetų testai turėtų atjungti widgetus prieš atlaisvinant išorinius konteinerius.
Naudokite fake_async, kad patikrintumėte autoDispose vėlavimus ir keepAlive elgseną.

Kiti žingsniai

API Reference

Atverkite greitas ProviderContainer, Ref, AsyncValue ir mutation API specifikacijas.

Open API Reference

Back to Overview

Grįžkite į pilną miniriverpod dokumentacijos žemėlapį.

Open Overview