Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(485)

Unified Diff: sync/engine/syncer_proto_util.cc

Issue 11490018: [Sync] Handle invalid specifics field numbers gracefully (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 8 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « sync/engine/store_timestamps_command.cc ('k') | sync/internal_api/public/base/model_type.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: sync/engine/syncer_proto_util.cc
diff --git a/sync/engine/syncer_proto_util.cc b/sync/engine/syncer_proto_util.cc
index 5ea54d439f0f071485c19e34437ae8b367673e25..6613c18b97775a40eaf43328c5c95b1e169e7b03 100644
--- a/sync/engine/syncer_proto_util.cc
+++ b/sync/engine/syncer_proto_util.cc
@@ -117,8 +117,13 @@ void SyncerProtoUtil::HandleMigrationDoneResponse(
<< "MIGRATION_DONE but no types specified.";
ModelTypeSet to_migrate;
for (int i = 0; i < response->migrated_data_type_id_size(); i++) {
- to_migrate.Put(GetModelTypeFromSpecificsFieldNumber(
- response->migrated_data_type_id(i)));
+ int field_number = response->migrated_data_type_id(i);
+ ModelType model_type = GetModelTypeFromSpecificsFieldNumber(field_number);
+ if (!IsRealDataType(model_type)) {
+ NOTREACHED() << "Unknown field number " << field_number;
+ continue;
+ }
+ to_migrate.Put(model_type);
}
// TODO(akalin): This should be a set union.
session->mutable_status_controller()->
@@ -322,9 +327,14 @@ SyncProtocolError ConvertErrorPBToLocalType(
// THROTTLED is currently the only error code that uses |error_data_types|.
DCHECK_EQ(error.error_type(), sync_pb::SyncEnums::THROTTLED);
for (int i = 0; i < error.error_data_type_ids_size(); ++i) {
- sync_protocol_error.error_data_types.Put(
- GetModelTypeFromSpecificsFieldNumber(
- error.error_data_type_ids(i)));
+ int field_number = error.error_data_type_ids(i);
+ ModelType model_type =
+ GetModelTypeFromSpecificsFieldNumber(field_number);
+ if (!IsRealDataType(model_type)) {
+ NOTREACHED() << "Unknown field number " << field_number;
tim (not reviewing) 2012/12/10 23:49:37 Is there any way to add a test for this?
akalin 2012/12/11 00:15:50 Yeah. Are you okay with doing it in another CL?
+ continue;
+ }
+ sync_protocol_error.error_data_types.Put(model_type);
}
}
« no previous file with comments | « sync/engine/store_timestamps_command.cc ('k') | sync/internal_api/public/base/model_type.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698