debug_info_event_listener.cc revision 868fa2fe829687343ffae624259930155e16dbd8
15821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Copyright (c) 2012 The Chromium Authors. All rights reserved. 25821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Use of this source code is governed by a BSD-style license that can be 35821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// found in the LICENSE file. 45821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 55821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "sync/internal_api/debug_info_event_listener.h" 65821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 75821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "sync/util/cryptographer.h" 85821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 95821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)namespace syncer { 105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)using sessions::SyncSessionSnapshot; 125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)DebugInfoEventListener::DebugInfoEventListener() 145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) : events_dropped_(false), 155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) cryptographer_has_pending_keys_(false), 165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) cryptographer_ready_(false), 17c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) weak_ptr_factory_(this) { 185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)DebugInfoEventListener::~DebugInfoEventListener() { 215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnSyncCycleCompleted( 245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const SyncSessionSnapshot& snapshot) { 255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) sync_pb::DebugEventInfo event_info; 275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) sync_pb::SyncCycleCompletedEventInfo* sync_completed_event_info = 285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) event_info.mutable_sync_cycle_completed_event_info(); 295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) sync_completed_event_info->set_num_encryption_conflicts( 315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) snapshot.num_encryption_conflicts()); 325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) sync_completed_event_info->set_num_hierarchy_conflicts( 335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) snapshot.num_hierarchy_conflicts()); 345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) sync_completed_event_info->set_num_server_conflicts( 355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) snapshot.num_server_conflicts()); 365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) sync_completed_event_info->set_num_updates_downloaded( 385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) snapshot.model_neutral_state().num_updates_downloaded_total); 395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) sync_completed_event_info->set_num_reflected_updates_downloaded( 405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) snapshot.model_neutral_state().num_reflected_updates_downloaded_total); 415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) sync_completed_event_info->mutable_caller_info()->set_source( 425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) snapshot.source().updates_source); 435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) sync_completed_event_info->mutable_caller_info()->set_notifications_enabled( 445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) snapshot.notifications_enabled()); 455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) AddEventToQueue(event_info); 475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnInitializationComplete( 505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const WeakHandle<JsBackend>& js_backend, 515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const WeakHandle<DataTypeDebugInfoListener>& debug_listener, 525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) bool success, ModelTypeSet restored_types) { 535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CreateAndAddEvent(sync_pb::DebugEventInfo::INITIALIZATION_COMPLETE); 555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnConnectionStatusChange( 585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) ConnectionStatus status) { 595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CreateAndAddEvent(sync_pb::DebugEventInfo::CONNECTION_STATUS_CHANGE); 615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnPassphraseRequired( 645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) PassphraseRequiredReason reason, 655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const sync_pb::EncryptedData& pending_keys) { 665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CreateAndAddEvent(sync_pb::DebugEventInfo::PASSPHRASE_REQUIRED); 685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnPassphraseAccepted() { 715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CreateAndAddEvent(sync_pb::DebugEventInfo::PASSPHRASE_ACCEPTED); 735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnBootstrapTokenUpdated( 765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const std::string& bootstrap_token, BootstrapTokenType type) { 775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 785821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (type == PASSPHRASE_BOOTSTRAP_TOKEN) { 795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CreateAndAddEvent(sync_pb::DebugEventInfo::BOOTSTRAP_TOKEN_UPDATED); 805821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return; 815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK_EQ(type, KEYSTORE_BOOTSTRAP_TOKEN); 835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CreateAndAddEvent(sync_pb::DebugEventInfo::KEYSTORE_TOKEN_UPDATED); 845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnStopSyncingPermanently() { 875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CreateAndAddEvent(sync_pb::DebugEventInfo::STOP_SYNCING_PERMANENTLY); 895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnUpdatedToken(const std::string& token) { 925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CreateAndAddEvent(sync_pb::DebugEventInfo::UPDATED_TOKEN); 945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnEncryptedTypesChanged( 975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) ModelTypeSet encrypted_types, 985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) bool encrypt_everything) { 995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 1005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CreateAndAddEvent(sync_pb::DebugEventInfo::ENCRYPTED_TYPES_CHANGED); 1015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 1025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnEncryptionComplete() { 1045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 1055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CreateAndAddEvent(sync_pb::DebugEventInfo::ENCRYPTION_COMPLETE); 1065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 1075821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnCryptographerStateChanged( 1095821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) Cryptographer* cryptographer) { 1105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 1115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) cryptographer_has_pending_keys_ = cryptographer->has_pending_keys(); 1125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) cryptographer_ready_ = cryptographer->is_ready(); 1135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 1145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnPassphraseTypeChanged( 1165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) PassphraseType type, 1175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::Time explicit_passphrase_time) { 1185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 1195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CreateAndAddEvent(sync_pb::DebugEventInfo::PASSPHRASE_TYPE_CHANGED); 1205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 1215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnActionableError( 1235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const SyncProtocolError& sync_error) { 1245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 1255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CreateAndAddEvent(sync_pb::DebugEventInfo::ACTIONABLE_ERROR); 1265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 1275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnNudgeFromDatatype(ModelType datatype) { 1295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 1305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) sync_pb::DebugEventInfo event_info; 1315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) event_info.set_nudging_datatype( 1325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) GetSpecificsFieldNumberFromModelType(datatype)); 1335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) AddEventToQueue(event_info); 1345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 1355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnIncomingNotification( 1375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const ModelTypeInvalidationMap& invalidation_map) { 1385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 1395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) sync_pb::DebugEventInfo event_info; 1405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) ModelTypeSet types = ModelTypeInvalidationMapToSet(invalidation_map); 1415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) for (ModelTypeSet::Iterator it = types.First(); it.Good(); it.Inc()) { 1435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) event_info.add_datatypes_notified_from_server( 1445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) GetSpecificsFieldNumberFromModelType(it.Get())); 1455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 1465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) AddEventToQueue(event_info); 1485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 1495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::GetAndClearDebugInfo( 1515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) sync_pb::DebugInfo* debug_info) { 1525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 1535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK_LE(events_.size(), kMaxEntries); 1545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) while (!events_.empty()) { 1555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) sync_pb::DebugEventInfo* event_info = debug_info->add_events(); 1565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const sync_pb::DebugEventInfo& debug_event_info = events_.front(); 1575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) event_info->CopyFrom(debug_event_info); 1585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) events_.pop(); 1595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 1605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) debug_info->set_events_dropped(events_dropped_); 1625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) debug_info->set_cryptographer_ready(cryptographer_ready_); 1635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) debug_info->set_cryptographer_has_pending_keys( 1645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) cryptographer_has_pending_keys_); 1655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) events_dropped_ = false; 1675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 1685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)base::WeakPtr<DataTypeDebugInfoListener> DebugInfoEventListener::GetWeakPtr() { 1705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 1715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return weak_ptr_factory_.GetWeakPtr(); 1725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 1735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 174868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)void DebugInfoEventListener::OnSingleDataTypeConfigureComplete( 175868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) const DataTypeConfigurationStats& configuration_stats) { 1765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 177868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) DCHECK(ProtocolTypes().Has(configuration_stats.model_type)); 178868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) 179868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) const DataTypeAssociationStats& association_stats = 180868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) configuration_stats.association_stats; 181868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) 1825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) sync_pb::DebugEventInfo association_event; 1835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) sync_pb::DatatypeAssociationStats* datatype_stats = 1845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) association_event.mutable_datatype_association_stats(); 1855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) datatype_stats->set_data_type_id( 186868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) GetSpecificsFieldNumberFromModelType(configuration_stats.model_type)); 1875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) datatype_stats->set_num_local_items_before_association( 1885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) association_stats.num_local_items_before_association); 1895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) datatype_stats->set_num_sync_items_before_association( 1905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) association_stats.num_sync_items_before_association); 1915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) datatype_stats->set_num_local_items_after_association( 1925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) association_stats.num_local_items_after_association); 1935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) datatype_stats->set_num_sync_items_after_association( 1945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) association_stats.num_sync_items_after_association); 1955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) datatype_stats->set_num_local_items_added( 1965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) association_stats.num_local_items_added); 1975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) datatype_stats->set_num_local_items_deleted( 1985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) association_stats.num_local_items_deleted); 1995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) datatype_stats->set_num_local_items_modified( 2005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) association_stats.num_local_items_modified); 2015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) datatype_stats->set_num_sync_items_added( 2025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) association_stats.num_sync_items_added); 2035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) datatype_stats->set_num_sync_items_deleted( 2045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) association_stats.num_sync_items_deleted); 2055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) datatype_stats->set_num_sync_items_modified( 2065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) association_stats.num_sync_items_modified); 2075821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) datatype_stats->set_had_error(association_stats.had_error); 208868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) datatype_stats->set_association_wait_time_for_same_priority_us( 209b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) association_stats.association_wait_time.InMicroseconds()); 210b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) datatype_stats->set_association_time_us( 211b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) association_stats.association_time.InMicroseconds()); 212868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) datatype_stats->set_download_wait_time_us( 213868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) configuration_stats.download_wait_time.InMicroseconds()); 214868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) datatype_stats->set_download_time_us( 215868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) configuration_stats.download_time.InMicroseconds()); 216868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) datatype_stats->set_association_wait_time_for_high_priority_us( 217868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) configuration_stats.association_wait_time_for_high_priority 218868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) .InMicroseconds()); 219868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) 220868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) for (ModelTypeSet::Iterator it = 221868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) configuration_stats.high_priority_types_configured_before.First(); 222868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) it.Good(); it.Inc()) { 223868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) datatype_stats->add_high_priority_type_configured_before( 224868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) GetSpecificsFieldNumberFromModelType(it.Get())); 225868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) } 226868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) 227868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) for (ModelTypeSet::Iterator it = 228868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) configuration_stats.same_priority_types_configured_before.First(); 229868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) it.Good(); it.Inc()) { 230868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) datatype_stats->add_same_priority_type_configured_before( 231868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) GetSpecificsFieldNumberFromModelType(it.Get())); 232868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) } 2335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) AddEventToQueue(association_event); 2355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 2365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnConfigureComplete() { 2385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 2395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) CreateAndAddEvent(sync_pb::DebugEventInfo::CONFIGURE_COMPLETE); 2405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 2415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::CreateAndAddEvent( 2435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) sync_pb::DebugEventInfo::SingletonEventType type) { 2445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 2455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) sync_pb::DebugEventInfo event_info; 2465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) event_info.set_singleton_event(type); 2475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) AddEventToQueue(event_info); 2485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 2495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::AddEventToQueue( 2515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const sync_pb::DebugEventInfo& event_info) { 2525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(thread_checker_.CalledOnValidThread()); 2535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (events_.size() >= kMaxEntries) { 2545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DVLOG(1) << "DebugInfoEventListener::AddEventToQueue Dropping an old event " 2555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) << "because of full queue"; 2565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) events_.pop(); 2585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) events_dropped_ = true; 2595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 2605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) events_.push(event_info); 2615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 2625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} // namespace syncer 264