Zadržite testove determinističnima s eksplicitnim kontejnerima.

Većina testnih scenarija izravno se mapira na API-je ProviderContainera: read, invalidate, refresh, listen i overrideove po instanci providera.

Test Strategy

Podijelite testove na čiste container testove i integracijske testove widgeta.

Pure Dart

Koristite ProviderContainer izravno za read/invalidate/refresh tvrdnje

Overrides

Overrideajte po instanci providera s overrideWith / overrideWithValue

Widget tests

Ubacite vanjski kontejner i izričito ga oslobodite

Tip

ProviderContainer.listen ne emitira početnu vrijednost osim ako nije navedeno fireImmediately: true.

Naredba za testiranje i kontrolni popis

Pokrenite cijeli skup i provjerite da nema zaostalih curenja timera 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.

Primjer: override po argumentu

Provideri nalik obiteljima overrideaju se po instanci stvorenoj vašom tvornič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 repozitoriju miniriverpod.
Widget testovi trebaju odmontirati widgete prije oslobađanja vanjskih kontejnera.
Koristite fake_async za validaciju kašnjenja autoDispose i ponašanja keepAlive.

Sljedeći koraci

API Reference

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

Open API Reference

Back to Overview

Vratite se na potpunu dokumentacijsku mapu za miniriverpod.

Open Overview