Hold tester deterministiske med eksplisitte containere.

De fleste testsituasjoner kan mappes direkte til ProviderContainer-APIer: read, invalidate, refresh, listen og overrides per providerinstans.

Test Strategy

Del opp tester i rene container-tester og widget-integrasjonstester.

Pure Dart

Bruk ProviderContainer direkte for read/invalidate/refresh-assertjoner

Overrides

Overstyr per providerinstans med overrideWith / overrideWithValue

Widget tests

Injiser den eksterne containeren og avhend den eksplisitt

Tip

ProviderContainer.listen sender ikke ut den innledende verdien med mindre fireImmediately: true er angitt.

Testkommando og sjekkliste

Kjør hele testsettet og verifiser at det ikke finnes ventende timerlekkasjer i autoDispose-scenarier.

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.

Eksempel: override per argument

Familielignende providers overstyres per instans opprettet av fabrikkfunksjonen din.

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();
Dette mønsteret speiler README og upstream-testene i miniriverpod-repositoriet.
Widgettester bør avmontere widgets før eksterne containere avhendes.
Bruk fake_async for å validere autoDispose-forsinkelser og keepAlive-oppførsel.

Neste steg

API Reference

Åpne hurtige signaturer for ProviderContainer, Ref, AsyncValue og mutation-APIer.

Open API Reference

Back to Overview

Tilbake til det fullstendige dokumentasjonskartet for miniriverpod.

Open Overview