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

Unified Diff: google_apis/gcm/engine/account_mapping_unittest.cc

Issue 443573002: [GCM] Adding status to AccountMapping structure (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Renaming files from account_info to account_mapping Created 6 years, 4 months 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
Index: google_apis/gcm/engine/account_mapping_unittest.cc
diff --git a/google_apis/gcm/engine/account_mapping_unittest.cc b/google_apis/gcm/engine/account_mapping_unittest.cc
new file mode 100644
index 0000000000000000000000000000000000000000..9f485e37d49a8494582460c149307b5c65f53af4
--- /dev/null
+++ b/google_apis/gcm/engine/account_mapping_unittest.cc
@@ -0,0 +1,160 @@
+// Copyright 2014 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include <string>
+
+#include "google_apis/gcm/engine/account_mapping.h"
Nicolas Zea 2014/08/06 19:10:12 nit: this is typically the first include in the fi
fgorski 2014/08/06 20:44:43 Done.
+#include "testing/gtest/include/gtest/gtest.h"
+
+namespace gcm {
+
+namespace {
+
+TEST(AccountMappingTest, SerializeAccountMapping) {
+ AccountMapping account_mapping;
+ account_mapping.account_id = "acc_id";
+ account_mapping.email = "test@example.com";
+ account_mapping.access_token = "access_token";
+ account_mapping.status = AccountMapping::ADDING;
+ account_mapping.status_change_timestamp =
+ base::Time::FromInternalValue(1305797421259942LL);
+ account_mapping.last_message_id = "last_message_id_1";
+ account_mapping.last_message_type = AccountMapping::MSG_ADD;
+
+ EXPECT_EQ("test@example.com&adding&1305797421259942&add&last_message_id_1",
+ account_mapping.SerializeAsString());
+
+ account_mapping.account_id = "acc_id2";
+ account_mapping.email = "test@gmail.com";
+ account_mapping.access_token = "access_token"; // should be ignored.
+ account_mapping.status = AccountMapping::REMOVING;
+ account_mapping.status_change_timestamp =
+ base::Time::FromInternalValue(1305797421259977LL);
+ account_mapping.last_message_id = "last_message_id_2";
+ account_mapping.last_message_type = AccountMapping::MSG_REMOVE;
+
+ EXPECT_EQ("test@gmail.com&removing&1305797421259977&remove&last_message_id_2",
+ account_mapping.SerializeAsString());
+
+ account_mapping.status = AccountMapping::MAPPED;
+ account_mapping.last_message_type = AccountMapping::MSG_NONE;
+
+ EXPECT_EQ("test@gmail.com&mapped&1305797421259977&none",
+ account_mapping.SerializeAsString());
+
+ account_mapping.status = AccountMapping::REMOVED;
+
+ EXPECT_EQ("test@gmail.com&removed&1305797421259977&none",
+ account_mapping.SerializeAsString());
+
+ account_mapping.status = AccountMapping::NEW;
+ account_mapping.status_change_timestamp = base::Time();
+
+ EXPECT_EQ("test@gmail.com&new&0&none", account_mapping.SerializeAsString());
+}
+
+TEST(AccountMappingTest, DeserializeAccountMapping) {
+ AccountMapping account_mapping;
+ account_mapping.account_id = "acc_id";
+ EXPECT_TRUE(account_mapping.ParseFromString(
+ "test@example.com&adding&1305797421259942&add&last_message_id_1"));
+ EXPECT_EQ("acc_id", account_mapping.account_id);
+ EXPECT_EQ("test@example.com", account_mapping.email);
+ EXPECT_TRUE(account_mapping.access_token.empty());
+ EXPECT_EQ(AccountMapping::ADDING, account_mapping.status);
+ EXPECT_EQ(base::Time::FromInternalValue(1305797421259942LL),
+ account_mapping.status_change_timestamp);
+ EXPECT_EQ(AccountMapping::MSG_ADD, account_mapping.last_message_type);
+ EXPECT_EQ("last_message_id_1", account_mapping.last_message_id);
+
+ EXPECT_TRUE(account_mapping.ParseFromString(
+ "test@gmail.com&removing&1305797421259977&remove&last_message_id_2"));
+ EXPECT_EQ("acc_id", account_mapping.account_id);
+ EXPECT_EQ("test@gmail.com", account_mapping.email);
+ EXPECT_TRUE(account_mapping.access_token.empty());
+ EXPECT_EQ(AccountMapping::REMOVING, account_mapping.status);
+ EXPECT_EQ(base::Time::FromInternalValue(1305797421259977LL),
+ account_mapping.status_change_timestamp);
+ EXPECT_EQ(AccountMapping::MSG_REMOVE, account_mapping.last_message_type);
+ EXPECT_EQ("last_message_id_2", account_mapping.last_message_id);
+
+ EXPECT_TRUE(account_mapping.ParseFromString(
+ "test@gmail.com&mapped&1305797421259977&none"));
+ EXPECT_EQ("acc_id", account_mapping.account_id);
+ EXPECT_EQ("test@gmail.com", account_mapping.email);
+ EXPECT_TRUE(account_mapping.access_token.empty());
+ EXPECT_EQ(AccountMapping::MAPPED, account_mapping.status);
+ EXPECT_EQ(base::Time::FromInternalValue(1305797421259977LL),
+ account_mapping.status_change_timestamp);
+ EXPECT_EQ(AccountMapping::MSG_NONE, account_mapping.last_message_type);
+ EXPECT_EQ("", account_mapping.last_message_id);
+
+ EXPECT_TRUE(account_mapping.ParseFromString(
+ "test@gmail.com&removed&1305797421259977&none"));
+ EXPECT_EQ("acc_id", account_mapping.account_id);
+ EXPECT_EQ("test@gmail.com", account_mapping.email);
+ EXPECT_TRUE(account_mapping.access_token.empty());
+ EXPECT_EQ(AccountMapping::REMOVED, account_mapping.status);
+ EXPECT_EQ(base::Time::FromInternalValue(1305797421259977LL),
+ account_mapping.status_change_timestamp);
+ EXPECT_EQ(AccountMapping::MSG_NONE, account_mapping.last_message_type);
+ EXPECT_EQ("", account_mapping.last_message_id);
+
+ EXPECT_TRUE(account_mapping.ParseFromString("test@gmail.com&new&0&none"));
+ EXPECT_EQ("acc_id", account_mapping.account_id);
+ EXPECT_EQ("test@gmail.com", account_mapping.email);
+ EXPECT_TRUE(account_mapping.access_token.empty());
+ EXPECT_EQ(AccountMapping::NEW, account_mapping.status);
+ EXPECT_EQ(base::Time(), account_mapping.status_change_timestamp);
+ EXPECT_EQ(AccountMapping::MSG_NONE, account_mapping.last_message_type);
+ EXPECT_EQ("", account_mapping.last_message_id);
+}
+
+TEST(AccountMappingTest, DeserializeAccountMappingInvalidInput) {
+ AccountMapping account_mapping;
+ account_mapping.account_id = "acc_id";
+ // Too many agruments.
+ EXPECT_FALSE(account_mapping.ParseFromString(
+ "test@example.com&adding&1305797421259935"
+ "&add&last_message_id_1&stuff_here"));
+ // Too few arguments.
+ EXPECT_FALSE(account_mapping.ParseFromString(
+ "test@example.com&adding&1305797421259935&remove"));
+ // Too few arguments.
+ EXPECT_FALSE(account_mapping.ParseFromString(
+ "test@example.com&adding&1305797421259935"));
+ // Missing email.
+ EXPECT_FALSE(account_mapping.ParseFromString(
+ "&adding&1305797421259935&remove&last_message_id_2"));
+ // Missing mapping status.
+ EXPECT_FALSE(account_mapping.ParseFromString(
+ "test@gmail.com&&1305797421259935&remove&last_message_id_2"));
+ // Unknown mapping status.
+ EXPECT_FALSE(account_mapping.ParseFromString(
+ "test@gmail.com&random&1305797421259935&remove&last_message_id_2"));
+ // Missing mapping status change timestamp.
+ EXPECT_FALSE(account_mapping.ParseFromString(
+ "test@gmail.com&adding&&remove&last_message_id_2"));
+ // Last mapping status change timestamp not parseable.
+ EXPECT_FALSE(account_mapping.ParseFromString(
+ "test@gmail.com&removing&remove&asdfjkl&last_message_id_2"));
+ // Missing message type.
+ EXPECT_FALSE(account_mapping.ParseFromString(
+ "test@example.com&adding&1305797421259935&&last_message_id_2"));
+ // Unkown message type.
+ EXPECT_FALSE(account_mapping.ParseFromString(
+ "test@example.com&adding&1305797421259935&random&last_message_id_2"));
+ // Message type is none when message details specified.
+ EXPECT_FALSE(account_mapping.ParseFromString(
+ "test@example.com&adding&1305797421259935&none&last_message_id_2"));
+ // Message type is messed up.
+ EXPECT_FALSE(account_mapping.ParseFromString(
+ "test@example.com&adding&1305797421259935&random"));
+ // Missing last message ID.
+ EXPECT_FALSE(account_mapping.ParseFromString(
+ "test@example.com&adding&1305797421259935&remove&"));
+}
+
+} // namespace
+} // namespace gcm

Powered by Google App Engine
This is Rietveld 408576698