summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--sync/engine/sync_scheduler_impl.cc66
-rw-r--r--sync/engine/sync_scheduler_impl.h10
2 files changed, 48 insertions, 28 deletions
diff --git a/sync/engine/sync_scheduler_impl.cc b/sync/engine/sync_scheduler_impl.cc
index f93a35b9..66460d3 100644
--- a/sync/engine/sync_scheduler_impl.cc
+++ b/sync/engine/sync_scheduler_impl.cc
@@ -237,7 +237,7 @@ void SyncSchedulerImpl::Start(Mode mode) {
CanRunNudgeJobNow(NORMAL_PRIORITY)) {
// We just got back to normal mode. Let's try to run the work that was
// queued up while we were configuring.
- DoNudgeSyncSessionJob(NORMAL_PRIORITY);
+ TrySyncSessionJob(NORMAL_PRIORITY);
}
}
@@ -299,7 +299,7 @@ void SyncSchedulerImpl::ScheduleConfiguration(
// Only reconfigure if we have types to download.
if (!params.types_to_download.Empty()) {
pending_configure_params_.reset(new ConfigurationParams(params));
- DoConfigurationSyncSessionJob(NORMAL_PRIORITY);
+ TrySyncSessionJob(NORMAL_PRIORITY);
} else {
SDVLOG(2) << "No change in routing info, calling ready task directly.";
params.ready_task.Run();
@@ -572,7 +572,7 @@ void SyncSchedulerImpl::DoPollSyncSessionJob() {
GetEnabledAndUnthrottledTypes(),
session.get());
- AdjustPolling(UPDATE_INTERVAL);
+ AdjustPolling(FORCE_RESET);
if (IsCurrentlyThrottled()) {
SDVLOG(2) << "Poll request got us throttled.";
@@ -599,18 +599,25 @@ void SyncSchedulerImpl::UpdateNudgeTimeRecords(ModelTypeSet types) {
}
}
+TimeDelta SyncSchedulerImpl::GetPollInterval() {
+ return (!session_context_->notifications_enabled() ||
+ !session_context_->ShouldFetchUpdatesBeforeCommit()) ?
+ syncer_short_poll_interval_seconds_ :
+ syncer_long_poll_interval_seconds_;
+}
+
void SyncSchedulerImpl::AdjustPolling(PollAdjustType type) {
DCHECK(CalledOnValidThread());
- TimeDelta poll = (!session_context_->notifications_enabled() ||
- !session_context_->ShouldFetchUpdatesBeforeCommit()) ?
- syncer_short_poll_interval_seconds_ :
- syncer_long_poll_interval_seconds_;
+ TimeDelta poll = GetPollInterval();
bool rate_changed = !poll_timer_.IsRunning() ||
poll != poll_timer_.GetCurrentDelay();
- if (type == FORCE_RESET && !rate_changed)
- poll_timer_.Reset();
+ if (type == FORCE_RESET) {
+ last_poll_reset_ = base::TimeTicks::Now();
+ if (!rate_changed)
+ poll_timer_.Reset();
+ }
if (!rate_changed)
return;
@@ -660,25 +667,28 @@ void SyncSchedulerImpl::Stop() {
// This is the only place where we invoke DoSyncSessionJob with canary
// privileges. Everyone else should use NORMAL_PRIORITY.
void SyncSchedulerImpl::TryCanaryJob() {
- DCHECK(CalledOnValidThread());
+ TrySyncSessionJob(CANARY_PRIORITY);
+ // Don't run poll job till the next time poll timer fires.
+ do_poll_after_credentials_updated_ = false;
+}
- if (mode_ == CONFIGURATION_MODE && pending_configure_params_) {
- SDVLOG(2) << "Found pending configure job; will run as canary";
- DoConfigurationSyncSessionJob(CANARY_PRIORITY);
- } else if (mode_ == NORMAL_MODE && nudge_tracker_.IsSyncRequired() &&
- CanRunNudgeJobNow(CANARY_PRIORITY)) {
- SDVLOG(2) << "Found pending nudge job; will run as canary";
- DoNudgeSyncSessionJob(CANARY_PRIORITY);
- } else if (mode_ == NORMAL_MODE && CanRunJobNow(CANARY_PRIORITY) &&
- do_poll_after_credentials_updated_) {
- // Retry poll if poll timer recently fired and ProfileSyncService received
- // fresh access token.
- DoPollSyncSessionJob();
+void SyncSchedulerImpl::TrySyncSessionJob(JobPriority priority) {
+ DCHECK(CalledOnValidThread());
+ if (mode_ == CONFIGURATION_MODE) {
+ if (pending_configure_params_) {
+ SDVLOG(2) << "Found pending configure job";
+ DoConfigurationSyncSessionJob(priority);
+ }
} else {
- SDVLOG(2) << "Found no work to do; will not run a canary";
+ DCHECK(mode_ == NORMAL_MODE);
+ if (nudge_tracker_.IsSyncRequired() && CanRunNudgeJobNow(priority)) {
+ SDVLOG(2) << "Found pending nudge job";
+ DoNudgeSyncSessionJob(priority);
+ } else if (do_poll_after_credentials_updated_ ||
+ ((base::TimeTicks::Now() - last_poll_reset_) >= GetPollInterval())) {
+ DoPollSyncSessionJob();
+ }
}
- // Don't run poll job till the next time poll timer fires.
- do_poll_after_credentials_updated_ = false;
}
void SyncSchedulerImpl::PollTimerCallback() {
@@ -694,7 +704,7 @@ void SyncSchedulerImpl::PollTimerCallback() {
return;
}
- DoPollSyncSessionJob();
+ TrySyncSessionJob(NORMAL_PRIORITY);
// Poll timer fires infrequently. Usually by this time access token is already
// expired and poll job will fail with auth error. Set flag to retry poll once
// ProfileSyncService gets new access token, TryCanaryJob will be called in
@@ -739,14 +749,14 @@ void SyncSchedulerImpl::TypeUnthrottle(base::TimeTicks unthrottle_time) {
// Maybe this is a good time to run a nudge job. Let's try it.
if (nudge_tracker_.IsSyncRequired() && CanRunNudgeJobNow(NORMAL_PRIORITY))
- DoNudgeSyncSessionJob(NORMAL_PRIORITY);
+ TrySyncSessionJob(NORMAL_PRIORITY);
}
void SyncSchedulerImpl::PerformDelayedNudge() {
// Circumstances may have changed since we scheduled this delayed nudge.
// We must check to see if it's OK to run the job before we do so.
if (CanRunNudgeJobNow(NORMAL_PRIORITY))
- DoNudgeSyncSessionJob(NORMAL_PRIORITY);
+ TrySyncSessionJob(NORMAL_PRIORITY);
// We're not responsible for setting up any retries here. The functions that
// first put us into a state that prevents successful sync cycles (eg. global
diff --git a/sync/engine/sync_scheduler_impl.h b/sync/engine/sync_scheduler_impl.h
index 60d1c38..4ffbf6f 100644
--- a/sync/engine/sync_scheduler_impl.h
+++ b/sync/engine/sync_scheduler_impl.h
@@ -167,6 +167,9 @@ class SYNC_EXPORT_PRIVATE SyncSchedulerImpl
// Invoke the Syncer to perform a poll job.
void DoPollSyncSessionJob();
+ // Helper function to calculate poll interval.
+ base::TimeDelta GetPollInterval();
+
// Adjusts the poll timer to account for new poll interval, and possibly
// resets the poll interval, depedning on the flag's value.
void AdjustPolling(PollAdjustType type);
@@ -204,6 +207,8 @@ class SYNC_EXPORT_PRIVATE SyncSchedulerImpl
// priority.
void TryCanaryJob();
+ void TrySyncSessionJob(JobPriority priority);
+
// Transitions out of the THROTTLED WaitInterval then calls TryCanaryJob().
void Unthrottle();
@@ -309,6 +314,11 @@ class SYNC_EXPORT_PRIVATE SyncSchedulerImpl
// after credentials are updated.
bool do_poll_after_credentials_updated_;
+ // TryJob might get called for multiple reasons. It should only call
+ // DoPollSyncSessionJob after some time since the last attempt.
+ // last_poll_reset_ keeps track of when was last attempt.
+ base::TimeTicks last_poll_reset_;
+
base::WeakPtrFactory<SyncSchedulerImpl> weak_ptr_factory_;
// A second factory specially for weak_handle_this_, to allow the handle