dio_speed_tracker

A lightweight and extensible Dio interceptor that tracks real-world network download speeds in Mbps, using actual HTTP responses instead of ICMP pings.

This is a practical alternative to custom_ping, ideal for apps where ICMP (ping) is blocked or unreliable β€” or when you want real-world performance metrics rather than synthetic ones.


πŸ” Features

  • βœ… Dio interceptor that measures network speed from actual downloads
  • πŸ“‰ Emits NetworkStatus.poor when average speed drops below a threshold
  • πŸ”„ Rolling average for smoothing out results
  • βš™οΈ Configurable sample size, duration, and thresholds
  • 🧩 No platform channels or native code needed
  • πŸ‘Œ Suitable for Flutter & Dart web/server apps alike

πŸ“¦ Installation

Add this to your pubspec.yaml:

dependencies:
  dio: ^5.0.0
  collection: ^1.17.2
  dio_speed_tracker: ^0.0.3

πŸš€ Usage

1. Create and attach the interceptor

final speedController = NetworkSpeedController(
  maxSpeedSamples: 10,
  minResultsToCheck: 5,
  poorConnectionThreshold: 2.0, // Mbps
);

final dio = Dio();

dio.interceptors.add(
  SpeedInterceptor(
  speedController,
  minTrackableSize: 10 * 1024, // 10 KB
  minDuration: Duration(milliseconds: 20),
  ),
);

2. Listen for connection quality

speedController.stream.listen((status) {
  if (status == NetworkStatus.poor) {
    print("🚨 Poor connection detected!");
    // Optionally show a UI warning or fallback
  }
});

3. Clean up

Don't forget to dispose of the controller when no longer needed:

@override
void dispose() {
  speedController.dispose();
  super.dispose();
}

πŸ“Š How It Works

  • The interceptor uses Dio's onReceiveProgress to measure how long a real HTTP download takes.
  • It calculates Mbps based on size and duration.
  • Speeds are stored in a rolling buffer, and the average is continuously evaluated.
  • When the average falls below the defined threshold, it emits NetworkStatus.poor on the stream.

πŸ†š Why Not custom_ping?

Unlike custom_ping:

Feature dio_speed_tracker custom_ping
Real download-based speed βœ… ❌
Works without ICMP permissions βœ… ❌
Cross-platform compatible βœ… 🚫 (native)
Dio integration βœ… ❌
No extra request calls βœ… ❌
Single request evaluation ❌ (TBD) βœ…

πŸ§ͺ Testing

This package includes full unit test coverage for:

  • Speed sample tracking and averaging
  • Rolling window logic
  • Threshold stream emission
  • Basic interceptor setup

Run tests:

flutter test

You’ll find the test files in:

test/
β”œβ”€β”€ network_speed_controller_test.dart
└── speed_interceptor_test.dart

🧰 Requirements

  • Dart 2.17+
  • Dio 5+
  • collection package for calculating averages

πŸ“‚ License

MIT License β€” free for personal or commercial use.


πŸ™Œ Contributing

Contributions and issues welcome!
If you have improvements or new ideas, feel free to open a PR or start a discussion.