debug_info_event_listener.cc revision 58537e28ecd584eab876aee8be7156509866d23a
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)
758537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles)#include "sync/notifier/object_id_invalidation_map.h"
85821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "sync/util/cryptographer.h"
95821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)namespace syncer {
115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)using sessions::SyncSessionSnapshot;
135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)DebugInfoEventListener::DebugInfoEventListener()
155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    : events_dropped_(false),
165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      cryptographer_has_pending_keys_(false),
175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      cryptographer_ready_(false),
18c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)      weak_ptr_factory_(this) {
195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)DebugInfoEventListener::~DebugInfoEventListener() {
225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnSyncCycleCompleted(
255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const SyncSessionSnapshot& snapshot) {
265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_pb::DebugEventInfo event_info;
285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_pb::SyncCycleCompletedEventInfo* sync_completed_event_info =
295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      event_info.mutable_sync_cycle_completed_event_info();
305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_completed_event_info->set_num_encryption_conflicts(
325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      snapshot.num_encryption_conflicts());
335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_completed_event_info->set_num_hierarchy_conflicts(
345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      snapshot.num_hierarchy_conflicts());
355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_completed_event_info->set_num_server_conflicts(
365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      snapshot.num_server_conflicts());
375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_completed_event_info->set_num_updates_downloaded(
395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      snapshot.model_neutral_state().num_updates_downloaded_total);
405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_completed_event_info->set_num_reflected_updates_downloaded(
415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      snapshot.model_neutral_state().num_reflected_updates_downloaded_total);
425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_completed_event_info->mutable_caller_info()->set_source(
43a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles)      snapshot.legacy_updates_source());
445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_completed_event_info->mutable_caller_info()->set_notifications_enabled(
455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      snapshot.notifications_enabled());
465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  AddEventToQueue(event_info);
485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnInitializationComplete(
515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const WeakHandle<JsBackend>& js_backend,
525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const WeakHandle<DataTypeDebugInfoListener>& debug_listener,
535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    bool success, ModelTypeSet restored_types) {
545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::INITIALIZATION_COMPLETE);
565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnConnectionStatusChange(
595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    ConnectionStatus status) {
605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::CONNECTION_STATUS_CHANGE);
625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnPassphraseRequired(
655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    PassphraseRequiredReason reason,
665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const sync_pb::EncryptedData& pending_keys) {
675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::PASSPHRASE_REQUIRED);
695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnPassphraseAccepted() {
725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::PASSPHRASE_ACCEPTED);
745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnBootstrapTokenUpdated(
775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const std::string& bootstrap_token, BootstrapTokenType type) {
785821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  if (type == PASSPHRASE_BOOTSTRAP_TOKEN) {
805821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    CreateAndAddEvent(sync_pb::DebugEventInfo::BOOTSTRAP_TOKEN_UPDATED);
815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    return;
825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  }
835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK_EQ(type, KEYSTORE_BOOTSTRAP_TOKEN);
845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::KEYSTORE_TOKEN_UPDATED);
855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnStopSyncingPermanently() {
885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::STOP_SYNCING_PERMANENTLY);
905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnUpdatedToken(const std::string& token) {
935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::UPDATED_TOKEN);
955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnEncryptedTypesChanged(
985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    ModelTypeSet encrypted_types,
995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    bool encrypt_everything) {
1005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
1015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::ENCRYPTED_TYPES_CHANGED);
1025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
1035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnEncryptionComplete() {
1055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
1065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::ENCRYPTION_COMPLETE);
1075821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
1085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1095821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnCryptographerStateChanged(
1105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    Cryptographer* cryptographer) {
1115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
1125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  cryptographer_has_pending_keys_ = cryptographer->has_pending_keys();
1135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  cryptographer_ready_ = cryptographer->is_ready();
1145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
1155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnPassphraseTypeChanged(
1175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    PassphraseType type,
1185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    base::Time explicit_passphrase_time) {
1195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
1205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::PASSPHRASE_TYPE_CHANGED);
1215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
1225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnActionableError(
1245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const SyncProtocolError& sync_error) {
1255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
1265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::ACTIONABLE_ERROR);
1275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
1285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnNudgeFromDatatype(ModelType datatype) {
1305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
1315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_pb::DebugEventInfo event_info;
1325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  event_info.set_nudging_datatype(
1335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      GetSpecificsFieldNumberFromModelType(datatype));
1345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  AddEventToQueue(event_info);
1355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
1365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnIncomingNotification(
13858537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles)    const ObjectIdInvalidationMap& invalidations) {
1395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
1405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_pb::DebugEventInfo event_info;
14158537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles)  ModelTypeSet types = ObjectIdSetToModelTypeSet(ObjectIdInvalidationMapToSet(
14258537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles)          invalidations));
14358537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles)
14458537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles)  for (ObjectIdInvalidationMap::const_iterator it = invalidations.begin();
14558537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles)       it != invalidations.end(); ++it) {
14658537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles)    ModelType type = UNSPECIFIED;
14758537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles)    if (ObjectIdToRealModelType(it->first, &type)) {
14858537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles)      event_info.add_datatypes_notified_from_server(
14958537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles)          GetSpecificsFieldNumberFromModelType(type));
15058537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles)    }
1515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  }
1525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  AddEventToQueue(event_info);
1545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
1555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::GetAndClearDebugInfo(
1575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    sync_pb::DebugInfo* debug_info) {
1585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
1595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK_LE(events_.size(), kMaxEntries);
1605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  while (!events_.empty()) {
1615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    sync_pb::DebugEventInfo* event_info = debug_info->add_events();
1625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const sync_pb::DebugEventInfo& debug_event_info = events_.front();
1635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    event_info->CopyFrom(debug_event_info);
1645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    events_.pop();
1655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  }
1665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  debug_info->set_events_dropped(events_dropped_);
1685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  debug_info->set_cryptographer_ready(cryptographer_ready_);
1695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  debug_info->set_cryptographer_has_pending_keys(
1705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      cryptographer_has_pending_keys_);
1715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  events_dropped_ = false;
1735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
1745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)base::WeakPtr<DataTypeDebugInfoListener> DebugInfoEventListener::GetWeakPtr() {
1765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
1775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  return weak_ptr_factory_.GetWeakPtr();
1785821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
1795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
180868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)void DebugInfoEventListener::OnSingleDataTypeConfigureComplete(
181868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)    const DataTypeConfigurationStats& configuration_stats) {
1825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
183868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  DCHECK(ProtocolTypes().Has(configuration_stats.model_type));
184868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)
185868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  const DataTypeAssociationStats& association_stats =
186868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)      configuration_stats.association_stats;
187868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)
1885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_pb::DebugEventInfo association_event;
1895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_pb::DatatypeAssociationStats* datatype_stats =
1905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_event.mutable_datatype_association_stats();
1915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_data_type_id(
192868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)      GetSpecificsFieldNumberFromModelType(configuration_stats.model_type));
1935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_num_local_items_before_association(
1945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_stats.num_local_items_before_association);
1955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_num_sync_items_before_association(
1965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_stats.num_sync_items_before_association);
1975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_num_local_items_after_association(
1985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_stats.num_local_items_after_association);
1995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_num_sync_items_after_association(
2005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_stats.num_sync_items_after_association);
2015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_num_local_items_added(
2025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_stats.num_local_items_added);
2035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_num_local_items_deleted(
2045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_stats.num_local_items_deleted);
2055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_num_local_items_modified(
2065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_stats.num_local_items_modified);
2075821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_num_sync_items_added(
2085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_stats.num_sync_items_added);
2095821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_num_sync_items_deleted(
2105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_stats.num_sync_items_deleted);
2115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_num_sync_items_modified(
2125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      association_stats.num_sync_items_modified);
2137d4cd473f85ac64c3747c96c277f9e506a0d2246Torne (Richard Coles)  datatype_stats->set_local_version_pre_association(
2147d4cd473f85ac64c3747c96c277f9e506a0d2246Torne (Richard Coles)      association_stats.local_version_pre_association);
2157d4cd473f85ac64c3747c96c277f9e506a0d2246Torne (Richard Coles)  datatype_stats->set_sync_version_pre_association(
2167d4cd473f85ac64c3747c96c277f9e506a0d2246Torne (Richard Coles)      association_stats.sync_version_pre_association);
2175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  datatype_stats->set_had_error(association_stats.had_error);
218868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  datatype_stats->set_association_wait_time_for_same_priority_us(
219b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles)        association_stats.association_wait_time.InMicroseconds());
220b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles)  datatype_stats->set_association_time_us(
221b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles)      association_stats.association_time.InMicroseconds());
222868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  datatype_stats->set_download_wait_time_us(
223868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)      configuration_stats.download_wait_time.InMicroseconds());
224868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  datatype_stats->set_download_time_us(
225868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)      configuration_stats.download_time.InMicroseconds());
226868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  datatype_stats->set_association_wait_time_for_high_priority_us(
227868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)      configuration_stats.association_wait_time_for_high_priority
228868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)          .InMicroseconds());
229868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)
230868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  for (ModelTypeSet::Iterator it =
231868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)      configuration_stats.high_priority_types_configured_before.First();
232868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)      it.Good(); it.Inc()) {
233868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)    datatype_stats->add_high_priority_type_configured_before(
234868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)        GetSpecificsFieldNumberFromModelType(it.Get()));
235868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  }
236868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)
237868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  for (ModelTypeSet::Iterator it =
238868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)      configuration_stats.same_priority_types_configured_before.First();
239868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)      it.Good(); it.Inc()) {
240868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)    datatype_stats->add_same_priority_type_configured_before(
241868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)        GetSpecificsFieldNumberFromModelType(it.Get()));
242868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  }
2435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  AddEventToQueue(association_event);
2455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
2465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::OnConfigureComplete() {
2485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
2495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CreateAndAddEvent(sync_pb::DebugEventInfo::CONFIGURE_COMPLETE);
2505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
2515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::CreateAndAddEvent(
2535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    sync_pb::DebugEventInfo::SingletonEventType type) {
2545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
2555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  sync_pb::DebugEventInfo event_info;
2565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  event_info.set_singleton_event(type);
2575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  AddEventToQueue(event_info);
2585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
2595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DebugInfoEventListener::AddEventToQueue(
2615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  const sync_pb::DebugEventInfo& event_info) {
2625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(thread_checker_.CalledOnValidThread());
2635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  if (events_.size() >= kMaxEntries) {
2645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    DVLOG(1) << "DebugInfoEventListener::AddEventToQueue Dropping an old event "
2655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)             << "because of full queue";
2665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    events_.pop();
2685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    events_dropped_ = true;
2695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  }
2705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  events_.push(event_info);
2715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
2725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}  // namespace syncer
274