Запазвайте тестовете детерминистични с явни контейнери.

Повечето сценарии за тестове се мапват директно към API-тата на ProviderContainer: read, invalidate, refresh, listen и overrides за всеки екземпляр на provider.

Test Strategy

Разделете тестовете на чисти контейнерни тестове и интеграционни тестове на widgets.

Pure Dart

Използвайте ProviderContainer директно за read/invalidate/refresh проверки

Overrides

Override-вайте по екземпляр на provider с overrideWith / overrideWithValue

Widget tests

Инжектирайте външния контейнер и го освобождавайте изрично

Tip

ProviderContainer.listen не излъчва началната стойност, освен ако fireImmediately: true не е зададено.

Тестова команда и контролен списък

Стартирайте целия набор и проверете, че няма висящи timer течове в сценарии autoDispose.

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.

Пример: override по аргумент

Провайдърите от семеен тип се override-ват за всеки екземпляр, създаден от вашата фабрична функция.

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();
Този модел следва README и upstream тестовете в хранилището miniriverpod.
Тестовете на widgets трябва да демонтират widget-ите преди да освободят външните контейнери.
Използвайте fake_async, за да валидирате забавянията на autoDispose и поведението keepAlive.

Следващи стъпки

API Reference

Отворете бързи сигнатури за ProviderContainer, Ref, AsyncValue и mutation API-тата.

Open API Reference

Back to Overview

Върнете се към пълната документационна карта на miniriverpod.

Open Overview