OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "sync/engine/sync_scheduler_impl.h" | 5 #include "sync/engine/sync_scheduler_impl.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <cstring> | 8 #include <cstring> |
9 | 9 |
10 #include "base/auto_reset.h" | 10 #include "base/auto_reset.h" |
(...skipping 14 matching lines...) Expand all Loading... |
25 using base::TimeTicks; | 25 using base::TimeTicks; |
26 | 26 |
27 namespace syncer { | 27 namespace syncer { |
28 | 28 |
29 using sessions::SyncSession; | 29 using sessions::SyncSession; |
30 using sessions::SyncSessionSnapshot; | 30 using sessions::SyncSessionSnapshot; |
31 using sync_pb::GetUpdatesCallerInfo; | 31 using sync_pb::GetUpdatesCallerInfo; |
32 | 32 |
33 namespace { | 33 namespace { |
34 | 34 |
| 35 bool IsConfigRelatedUpdateSourceValue( |
| 36 GetUpdatesCallerInfo::GetUpdatesSource source) { |
| 37 switch (source) { |
| 38 case GetUpdatesCallerInfo::RECONFIGURATION: |
| 39 case GetUpdatesCallerInfo::MIGRATION: |
| 40 case GetUpdatesCallerInfo::NEW_CLIENT: |
| 41 case GetUpdatesCallerInfo::NEWLY_SUPPORTED_DATATYPE: |
| 42 return true; |
| 43 default: |
| 44 return false; |
| 45 } |
| 46 } |
| 47 |
35 bool ShouldRequestEarlyExit(const SyncProtocolError& error) { | 48 bool ShouldRequestEarlyExit(const SyncProtocolError& error) { |
36 switch (error.error_type) { | 49 switch (error.error_type) { |
37 case SYNC_SUCCESS: | 50 case SYNC_SUCCESS: |
38 case MIGRATION_DONE: | 51 case MIGRATION_DONE: |
39 case THROTTLED: | 52 case THROTTLED: |
40 case TRANSIENT_ERROR: | 53 case TRANSIENT_ERROR: |
41 return false; | 54 return false; |
42 case NOT_MY_BIRTHDAY: | 55 case NOT_MY_BIRTHDAY: |
43 case CLEAR_PENDING: | 56 case CLEAR_PENDING: |
44 case DISABLED_BY_ADMIN: | 57 case DISABLED_BY_ADMIN: |
(...skipping 13 matching lines...) Expand all Loading... |
58 default: | 71 default: |
59 NOTREACHED(); | 72 NOTREACHED(); |
60 return false; | 73 return false; |
61 } | 74 } |
62 } | 75 } |
63 | 76 |
64 bool IsActionableError( | 77 bool IsActionableError( |
65 const SyncProtocolError& error) { | 78 const SyncProtocolError& error) { |
66 return (error.action != UNKNOWN_ACTION); | 79 return (error.action != UNKNOWN_ACTION); |
67 } | 80 } |
| 81 |
68 } // namespace | 82 } // namespace |
69 | 83 |
70 ConfigurationParams::ConfigurationParams() | 84 ConfigurationParams::ConfigurationParams() |
71 : source(GetUpdatesCallerInfo::UNKNOWN) {} | 85 : source(GetUpdatesCallerInfo::UNKNOWN) {} |
72 ConfigurationParams::ConfigurationParams( | 86 ConfigurationParams::ConfigurationParams( |
73 const sync_pb::GetUpdatesCallerInfo::GetUpdatesSource& source, | 87 const sync_pb::GetUpdatesCallerInfo::GetUpdatesSource& source, |
74 ModelTypeSet types_to_download, | 88 ModelTypeSet types_to_download, |
75 const ModelSafeRoutingInfo& routing_info, | 89 const ModelSafeRoutingInfo& routing_info, |
76 const base::Closure& ready_task, | 90 const base::Closure& ready_task, |
77 const base::Closure& retry_task) | 91 const base::Closure& retry_task) |
(...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
125 // Helper macros to log with the syncer thread name; useful when there | 139 // Helper macros to log with the syncer thread name; useful when there |
126 // are multiple syncer threads involved. | 140 // are multiple syncer threads involved. |
127 | 141 |
128 #define SLOG(severity) LOG(severity) << name_ << ": " | 142 #define SLOG(severity) LOG(severity) << name_ << ": " |
129 | 143 |
130 #define SDVLOG(verbose_level) DVLOG(verbose_level) << name_ << ": " | 144 #define SDVLOG(verbose_level) DVLOG(verbose_level) << name_ << ": " |
131 | 145 |
132 #define SDVLOG_LOC(from_here, verbose_level) \ | 146 #define SDVLOG_LOC(from_here, verbose_level) \ |
133 DVLOG_LOC(from_here, verbose_level) << name_ << ": " | 147 DVLOG_LOC(from_here, verbose_level) << name_ << ": " |
134 | 148 |
135 namespace { | |
136 | |
137 const int kDefaultSessionsCommitDelaySeconds = 10; | |
138 | |
139 bool IsConfigRelatedUpdateSourceValue( | |
140 GetUpdatesCallerInfo::GetUpdatesSource source) { | |
141 switch (source) { | |
142 case GetUpdatesCallerInfo::RECONFIGURATION: | |
143 case GetUpdatesCallerInfo::MIGRATION: | |
144 case GetUpdatesCallerInfo::NEW_CLIENT: | |
145 case GetUpdatesCallerInfo::NEWLY_SUPPORTED_DATATYPE: | |
146 return true; | |
147 default: | |
148 return false; | |
149 } | |
150 } | |
151 | |
152 } // namespace | |
153 | |
154 SyncSchedulerImpl::SyncSchedulerImpl(const std::string& name, | 149 SyncSchedulerImpl::SyncSchedulerImpl(const std::string& name, |
155 BackoffDelayProvider* delay_provider, | 150 BackoffDelayProvider* delay_provider, |
156 sessions::SyncSessionContext* context, | 151 sessions::SyncSessionContext* context, |
157 Syncer* syncer) | 152 Syncer* syncer) |
158 : name_(name), | 153 : name_(name), |
159 started_(false), | 154 started_(false), |
160 syncer_short_poll_interval_seconds_( | 155 syncer_short_poll_interval_seconds_( |
161 TimeDelta::FromSeconds(kDefaultShortPollIntervalSeconds)), | 156 TimeDelta::FromSeconds(kDefaultShortPollIntervalSeconds)), |
162 syncer_long_poll_interval_seconds_( | 157 syncer_long_poll_interval_seconds_( |
163 TimeDelta::FromSeconds(kDefaultLongPollIntervalSeconds)), | 158 TimeDelta::FromSeconds(kDefaultLongPollIntervalSeconds)), |
164 sessions_commit_delay_( | |
165 TimeDelta::FromSeconds(kDefaultSessionsCommitDelaySeconds)), | |
166 mode_(NORMAL_MODE), | 159 mode_(NORMAL_MODE), |
167 delay_provider_(delay_provider), | 160 delay_provider_(delay_provider), |
168 syncer_(syncer), | 161 syncer_(syncer), |
169 session_context_(context), | 162 session_context_(context), |
170 no_scheduling_allowed_(false), | 163 no_scheduling_allowed_(false), |
171 do_poll_after_credentials_updated_(false), | 164 do_poll_after_credentials_updated_(false), |
172 next_sync_session_job_priority_(NORMAL_PRIORITY), | 165 next_sync_session_job_priority_(NORMAL_PRIORITY), |
173 weak_ptr_factory_(this), | 166 weak_ptr_factory_(this), |
174 weak_ptr_factory_for_weak_handle_(this) { | 167 weak_ptr_factory_for_weak_handle_(this) { |
175 weak_handle_this_ = MakeWeakHandle( | 168 weak_handle_this_ = MakeWeakHandle( |
(...skipping 173 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
349 | 342 |
350 if (mode_ == CONFIGURATION_MODE) { | 343 if (mode_ == CONFIGURATION_MODE) { |
351 SDVLOG(1) << "Not running nudge because we're in configuration mode."; | 344 SDVLOG(1) << "Not running nudge because we're in configuration mode."; |
352 return false; | 345 return false; |
353 } | 346 } |
354 | 347 |
355 return true; | 348 return true; |
356 } | 349 } |
357 | 350 |
358 void SyncSchedulerImpl::ScheduleLocalNudge( | 351 void SyncSchedulerImpl::ScheduleLocalNudge( |
359 const TimeDelta& desired_delay, | |
360 ModelTypeSet types, | 352 ModelTypeSet types, |
361 const tracked_objects::Location& nudge_location) { | 353 const tracked_objects::Location& nudge_location) { |
362 DCHECK(CalledOnValidThread()); | 354 DCHECK(CalledOnValidThread()); |
363 DCHECK(!types.Empty()); | 355 DCHECK(!types.Empty()); |
364 | 356 |
365 SDVLOG_LOC(nudge_location, 2) | 357 SDVLOG_LOC(nudge_location, 2) |
366 << "Scheduling sync because of local change to " | 358 << "Scheduling sync because of local change to " |
367 << ModelTypeSetToString(types); | 359 << ModelTypeSetToString(types); |
368 UpdateNudgeTimeRecords(types); | 360 UpdateNudgeTimeRecords(types); |
369 nudge_tracker_.RecordLocalChange(types); | 361 base::TimeDelta nudge_delay = nudge_tracker_.RecordLocalChange(types); |
370 ScheduleNudgeImpl(desired_delay, nudge_location); | 362 ScheduleNudgeImpl(nudge_delay, nudge_location); |
371 } | 363 } |
372 | 364 |
373 void SyncSchedulerImpl::ScheduleLocalRefreshRequest( | 365 void SyncSchedulerImpl::ScheduleLocalRefreshRequest( |
374 const TimeDelta& desired_delay, | |
375 ModelTypeSet types, | 366 ModelTypeSet types, |
376 const tracked_objects::Location& nudge_location) { | 367 const tracked_objects::Location& nudge_location) { |
377 DCHECK(CalledOnValidThread()); | 368 DCHECK(CalledOnValidThread()); |
378 DCHECK(!types.Empty()); | 369 DCHECK(!types.Empty()); |
379 | 370 |
380 SDVLOG_LOC(nudge_location, 2) | 371 SDVLOG_LOC(nudge_location, 2) |
381 << "Scheduling sync because of local refresh request for " | 372 << "Scheduling sync because of local refresh request for " |
382 << ModelTypeSetToString(types); | 373 << ModelTypeSetToString(types); |
383 nudge_tracker_.RecordLocalRefreshRequest(types); | 374 base::TimeDelta nudge_delay = nudge_tracker_.RecordLocalRefreshRequest(types); |
384 ScheduleNudgeImpl(desired_delay, nudge_location); | 375 ScheduleNudgeImpl(nudge_delay, nudge_location); |
385 } | 376 } |
386 | 377 |
387 void SyncSchedulerImpl::ScheduleInvalidationNudge( | 378 void SyncSchedulerImpl::ScheduleInvalidationNudge( |
388 const TimeDelta& desired_delay, | |
389 syncer::ModelType model_type, | 379 syncer::ModelType model_type, |
390 scoped_ptr<InvalidationInterface> invalidation, | 380 scoped_ptr<InvalidationInterface> invalidation, |
391 const tracked_objects::Location& nudge_location) { | 381 const tracked_objects::Location& nudge_location) { |
392 DCHECK(CalledOnValidThread()); | 382 DCHECK(CalledOnValidThread()); |
393 | 383 |
394 SDVLOG_LOC(nudge_location, 2) | 384 SDVLOG_LOC(nudge_location, 2) |
395 << "Scheduling sync because we received invalidation for " | 385 << "Scheduling sync because we received invalidation for " |
396 << ModelTypeToString(model_type); | 386 << ModelTypeToString(model_type); |
397 nudge_tracker_.RecordRemoteInvalidation(model_type, invalidation.Pass()); | 387 base::TimeDelta nudge_delay = |
398 ScheduleNudgeImpl(desired_delay, nudge_location); | 388 nudge_tracker_.RecordRemoteInvalidation(model_type, invalidation.Pass()); |
| 389 ScheduleNudgeImpl(nudge_delay, nudge_location); |
399 } | 390 } |
400 | 391 |
401 void SyncSchedulerImpl::ScheduleInitialSyncNudge(syncer::ModelType model_type) { | 392 void SyncSchedulerImpl::ScheduleInitialSyncNudge(syncer::ModelType model_type) { |
402 DCHECK(CalledOnValidThread()); | 393 DCHECK(CalledOnValidThread()); |
403 | 394 |
404 SDVLOG(2) << "Scheduling non-blocking initial sync for " | 395 SDVLOG(2) << "Scheduling non-blocking initial sync for " |
405 << ModelTypeToString(model_type); | 396 << ModelTypeToString(model_type); |
406 nudge_tracker_.RecordInitialSyncRequired(model_type); | 397 nudge_tracker_.RecordInitialSyncRequired(model_type); |
407 ScheduleNudgeImpl(TimeDelta::FromSeconds(0), FROM_HERE); | 398 ScheduleNudgeImpl(TimeDelta::FromSeconds(0), FROM_HERE); |
408 } | 399 } |
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
454 } | 445 } |
455 | 446 |
456 const char* SyncSchedulerImpl::GetModeString(SyncScheduler::Mode mode) { | 447 const char* SyncSchedulerImpl::GetModeString(SyncScheduler::Mode mode) { |
457 switch (mode) { | 448 switch (mode) { |
458 ENUM_CASE(CONFIGURATION_MODE); | 449 ENUM_CASE(CONFIGURATION_MODE); |
459 ENUM_CASE(NORMAL_MODE); | 450 ENUM_CASE(NORMAL_MODE); |
460 } | 451 } |
461 return ""; | 452 return ""; |
462 } | 453 } |
463 | 454 |
| 455 void SyncSchedulerImpl::SetDefaultNudgeDelay(base::TimeDelta delay_ms) { |
| 456 DCHECK(CalledOnValidThread()); |
| 457 nudge_tracker_.SetDefaultNudgeDelay(delay_ms); |
| 458 } |
| 459 |
464 void SyncSchedulerImpl::DoNudgeSyncSessionJob(JobPriority priority) { | 460 void SyncSchedulerImpl::DoNudgeSyncSessionJob(JobPriority priority) { |
465 DCHECK(CalledOnValidThread()); | 461 DCHECK(CalledOnValidThread()); |
466 DCHECK(CanRunNudgeJobNow(priority)); | 462 DCHECK(CanRunNudgeJobNow(priority)); |
467 | 463 |
468 DVLOG(2) << "Will run normal mode sync cycle with types " | 464 DVLOG(2) << "Will run normal mode sync cycle with types " |
469 << ModelTypeSetToString(session_context_->GetEnabledTypes()); | 465 << ModelTypeSetToString(session_context_->GetEnabledTypes()); |
470 scoped_ptr<SyncSession> session(SyncSession::Build(session_context_, this)); | 466 scoped_ptr<SyncSession> session(SyncSession::Build(session_context_, this)); |
471 bool premature_exit = !syncer_->NormalSyncShare( | 467 bool premature_exit = !syncer_->NormalSyncShare( |
472 GetEnabledAndUnthrottledTypes(), | 468 GetEnabledAndUnthrottledTypes(), |
473 nudge_tracker_, | 469 nudge_tracker_, |
(...skipping 381 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
855 DCHECK(CalledOnValidThread()); | 851 DCHECK(CalledOnValidThread()); |
856 syncer_short_poll_interval_seconds_ = new_interval; | 852 syncer_short_poll_interval_seconds_ = new_interval; |
857 } | 853 } |
858 | 854 |
859 void SyncSchedulerImpl::OnReceivedLongPollIntervalUpdate( | 855 void SyncSchedulerImpl::OnReceivedLongPollIntervalUpdate( |
860 const base::TimeDelta& new_interval) { | 856 const base::TimeDelta& new_interval) { |
861 DCHECK(CalledOnValidThread()); | 857 DCHECK(CalledOnValidThread()); |
862 syncer_long_poll_interval_seconds_ = new_interval; | 858 syncer_long_poll_interval_seconds_ = new_interval; |
863 } | 859 } |
864 | 860 |
865 void SyncSchedulerImpl::OnReceivedSessionsCommitDelay( | 861 void SyncSchedulerImpl::OnReceivedCustomNudgeDelays( |
866 const base::TimeDelta& new_delay) { | 862 const std::map<ModelType, base::TimeDelta>& nudge_delays) { |
867 DCHECK(CalledOnValidThread()); | 863 DCHECK(CalledOnValidThread()); |
868 sessions_commit_delay_ = new_delay; | 864 nudge_tracker_.OnReceivedCustomNudgeDelays(nudge_delays); |
869 } | 865 } |
870 | 866 |
871 void SyncSchedulerImpl::OnReceivedClientInvalidationHintBufferSize(int size) { | 867 void SyncSchedulerImpl::OnReceivedClientInvalidationHintBufferSize(int size) { |
872 if (size > 0) | 868 if (size > 0) |
873 nudge_tracker_.SetHintBufferSize(size); | 869 nudge_tracker_.SetHintBufferSize(size); |
874 else | 870 else |
875 NOTREACHED() << "Hint buffer size should be > 0."; | 871 NOTREACHED() << "Hint buffer size should be > 0."; |
876 } | 872 } |
877 | 873 |
878 void SyncSchedulerImpl::OnSyncProtocolError( | 874 void SyncSchedulerImpl::OnSyncProtocolError( |
(...skipping 25 matching lines...) Expand all Loading... |
904 | 900 |
905 void SyncSchedulerImpl::SetNotificationsEnabled(bool notifications_enabled) { | 901 void SyncSchedulerImpl::SetNotificationsEnabled(bool notifications_enabled) { |
906 DCHECK(CalledOnValidThread()); | 902 DCHECK(CalledOnValidThread()); |
907 session_context_->set_notifications_enabled(notifications_enabled); | 903 session_context_->set_notifications_enabled(notifications_enabled); |
908 if (notifications_enabled) | 904 if (notifications_enabled) |
909 nudge_tracker_.OnInvalidationsEnabled(); | 905 nudge_tracker_.OnInvalidationsEnabled(); |
910 else | 906 else |
911 nudge_tracker_.OnInvalidationsDisabled(); | 907 nudge_tracker_.OnInvalidationsDisabled(); |
912 } | 908 } |
913 | 909 |
914 base::TimeDelta SyncSchedulerImpl::GetSessionsCommitDelay() const { | |
915 DCHECK(CalledOnValidThread()); | |
916 return sessions_commit_delay_; | |
917 } | |
918 | |
919 #undef SDVLOG_LOC | 910 #undef SDVLOG_LOC |
920 | 911 |
921 #undef SDVLOG | 912 #undef SDVLOG |
922 | 913 |
923 #undef SLOG | 914 #undef SLOG |
924 | 915 |
925 #undef ENUM_CASE | 916 #undef ENUM_CASE |
926 | 917 |
927 } // namespace syncer | 918 } // namespace syncer |
OLD | NEW |