mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-05 10:29:23 +00:00
[skip ci] sync stuck watch dog
This commit is contained in:
parent
ac847d8b93
commit
c2e764f77b
1 changed files with 19 additions and 17 deletions
|
@ -253,7 +253,7 @@ Future<void> onStart(ServiceInstance service) async {
|
||||||
|
|
||||||
if (progress > 0.999 && shouldSync) {
|
if (progress > 0.999 && shouldSync) {
|
||||||
syncedTicks++;
|
syncedTicks++;
|
||||||
if (syncedTicks > 10) {
|
if (syncedTicks > 5) {
|
||||||
syncedTicks = 0;
|
syncedTicks = 0;
|
||||||
printV("WALLET $i SYNCED");
|
printV("WALLET $i SYNCED");
|
||||||
wallet.stopSync();
|
wallet.stopSync();
|
||||||
|
@ -374,25 +374,27 @@ Future<void> onStart(ServiceInstance service) async {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
// setup a watch dog to restart the sync process if it gets stuck:
|
// setup a watch dog to restart the wallet sync process if it appears to get stuck:
|
||||||
List<double> lastFewProgresses = [];
|
List<double> lastFewProgresses = [];
|
||||||
_stuckSyncTimer?.cancel();
|
_stuckSyncTimer?.cancel();
|
||||||
_stuckSyncTimer = Timer.periodic(const Duration(seconds: 10), (timer) async {
|
_stuckSyncTimer = Timer.periodic(const Duration(seconds: 10), (timer) async {
|
||||||
// TODO: finish this
|
if (syncingWallets.isEmpty) return;
|
||||||
// if (syncStatus is! SyncingSyncStatus) return;
|
final wallet = syncingWallets.first;
|
||||||
// if (syncStatus.progress() > 0.98) return; // don't check if we're close to synced
|
final syncStatus = wallet.syncStatus;
|
||||||
// lastFewProgresses.add(syncStatus.progress());
|
if (syncStatus is! SyncingSyncStatus) return;
|
||||||
// if (lastFewProgresses.length < 10) return;
|
if (syncStatus.progress() > SYNC_THRESHOLD) return; // don't bother checking if we're close to synced
|
||||||
// // limit list size to 10:
|
lastFewProgresses.add(syncStatus.progress());
|
||||||
// while (lastFewProgresses.length > 10) {
|
if (lastFewProgresses.length < 10) return;
|
||||||
// lastFewProgresses.removeAt(0);
|
// limit list size to 10:
|
||||||
// }
|
while (lastFewProgresses.length > 10) {
|
||||||
// // if the progress is the same over the last 100 seconds, restart the sync:
|
lastFewProgresses.removeAt(0);
|
||||||
// if (lastFewProgresses.every((p) => p == lastFewProgresses.first)) {
|
}
|
||||||
// printV("mweb syncing is stuck, restarting...");
|
// if the progress is the same over the last 100 seconds, restart the sync:
|
||||||
// syncStatus = LostConnectionSyncStatus();
|
if (lastFewProgresses.every((p) => p == lastFewProgresses.first)) {
|
||||||
// await stopSync();
|
printV("syncing appears to be stuck, restarting...");
|
||||||
// }
|
await wallet.stopSync();
|
||||||
|
await wallet.startSync();
|
||||||
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue