स्पष्ट containers सँग tests लाई deterministic राख्नुहोस्।

धेरैजसो test scenarios सिधै ProviderContainer APIs मा map हुन्छन्: read, invalidate, refresh, listen, र provider instance अनुसार overrides।

Test Strategy

tests लाई pure container tests र widget integration tests मा विभाजित गर्नुहोस्।

Pure Dart

read/invalidate/refresh assertions का लागि सिधै ProviderContainer प्रयोग गर्नुहोस्

Overrides

overrideWith / overrideWithValue सँग provider instance अनुसार override गर्नुहोस्

Widget tests

external container inject गर्नुहोस् र यसलाई स्पष्ट रूपमा dispose गर्नुहोस्

Tip

fireImmediately: true निर्दिष्ट नगरिएसम्म ProviderContainer.listen ले प्रारम्भिक value emit गर्दैन।

Test command र checklist

पूरा suite चलाउनुहोस् र autoDispose scenarios मा कुनै pending timer leak छैन भनेर verify गर्नुहोस्।

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.

उदाहरण: argument अनुसार override

family-like providers तपाईंको factory function ले बनाएको प्रत्येक instance का लागि 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();
यो ढाँचाले miniriverpod repository का README र upstream tests लाई पछ्याउँछ।
widget tests ले external containers dispose गर्नु अघि widgets unmount गर्नुपर्छ।
autoDispose delays र keepAlive behavior प्रमाणित गर्न fake_async प्रयोग गर्नुहोस्।

अर्को कदम

API Reference

ProviderContainer, Ref, AsyncValue, र mutation APIs का quick signatures खोल्नुहोस्।

Open API Reference

Back to Overview

miniriverpod को पूर्ण documentation map मा फर्कनुहोस्।

Open Overview