| OLD | NEW |
| (Empty) |
| 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 | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "sync/api/sync_error.h" | |
| 6 | |
| 7 #include <string> | |
| 8 | |
| 9 #include "base/location.h" | |
| 10 #include "testing/gtest/include/gtest/gtest.h" | |
| 11 | |
| 12 namespace syncer { | |
| 13 | |
| 14 namespace { | |
| 15 | |
| 16 using std::string; | |
| 17 | |
| 18 typedef testing::Test SyncErrorTest; | |
| 19 | |
| 20 TEST_F(SyncErrorTest, Unset) { | |
| 21 SyncError error; | |
| 22 EXPECT_FALSE(error.IsSet()); | |
| 23 } | |
| 24 | |
| 25 TEST_F(SyncErrorTest, Default) { | |
| 26 tracked_objects::Location location = FROM_HERE; | |
| 27 std::string msg = "test"; | |
| 28 ModelType type = PREFERENCES; | |
| 29 SyncError error(location, SyncError::DATATYPE_ERROR, msg, type); | |
| 30 ASSERT_TRUE(error.IsSet()); | |
| 31 EXPECT_EQ(location.line_number(), error.location().line_number()); | |
| 32 EXPECT_EQ("datatype error was encountered: ", error.GetMessagePrefix()); | |
| 33 EXPECT_EQ(msg, error.message()); | |
| 34 EXPECT_EQ(type, error.model_type()); | |
| 35 EXPECT_EQ(SyncError::SYNC_ERROR_SEVERITY_ERROR, error.GetSeverity()); | |
| 36 } | |
| 37 | |
| 38 TEST_F(SyncErrorTest, LowSeverity) { | |
| 39 tracked_objects::Location location = FROM_HERE; | |
| 40 std::string msg = "test"; | |
| 41 ModelType type = PREFERENCES; | |
| 42 SyncError error(location, SyncError::DATATYPE_POLICY_ERROR, msg, type); | |
| 43 ASSERT_TRUE(error.IsSet()); | |
| 44 EXPECT_EQ(location.line_number(), error.location().line_number()); | |
| 45 EXPECT_EQ("disabled due to configuration constraints: ", | |
| 46 error.GetMessagePrefix()); | |
| 47 EXPECT_EQ(msg, error.message()); | |
| 48 EXPECT_EQ(type, error.model_type()); | |
| 49 EXPECT_EQ(SyncError::SYNC_ERROR_SEVERITY_INFO, error.GetSeverity()); | |
| 50 } | |
| 51 | |
| 52 TEST_F(SyncErrorTest, Reset) { | |
| 53 tracked_objects::Location location = FROM_HERE; | |
| 54 std::string msg = "test"; | |
| 55 ModelType type = PREFERENCES; | |
| 56 | |
| 57 SyncError error; | |
| 58 EXPECT_FALSE(error.IsSet()); | |
| 59 | |
| 60 error.Reset(location, msg, type); | |
| 61 ASSERT_TRUE(error.IsSet()); | |
| 62 EXPECT_EQ(location.line_number(), error.location().line_number()); | |
| 63 EXPECT_EQ(msg, error.message()); | |
| 64 EXPECT_EQ(type, error.model_type()); | |
| 65 | |
| 66 tracked_objects::Location location2 = FROM_HERE; | |
| 67 std::string msg2 = "test"; | |
| 68 ModelType type2 = PREFERENCES; | |
| 69 error.Reset(location2, msg2, type2); | |
| 70 ASSERT_TRUE(error.IsSet()); | |
| 71 EXPECT_EQ(location2.line_number(), error.location().line_number()); | |
| 72 EXPECT_EQ(msg2, error.message()); | |
| 73 EXPECT_EQ(type2, error.model_type()); | |
| 74 } | |
| 75 | |
| 76 TEST_F(SyncErrorTest, Copy) { | |
| 77 tracked_objects::Location location = FROM_HERE; | |
| 78 std::string msg = "test"; | |
| 79 ModelType type = PREFERENCES; | |
| 80 | |
| 81 SyncError error1; | |
| 82 EXPECT_FALSE(error1.IsSet()); | |
| 83 SyncError error2(error1); | |
| 84 EXPECT_FALSE(error2.IsSet()); | |
| 85 | |
| 86 error1.Reset(location, msg, type); | |
| 87 ASSERT_TRUE(error1.IsSet()); | |
| 88 EXPECT_EQ(location.line_number(), error1.location().line_number()); | |
| 89 EXPECT_EQ(msg, error1.message()); | |
| 90 EXPECT_EQ(type, error1.model_type()); | |
| 91 | |
| 92 SyncError error3(error1); | |
| 93 ASSERT_TRUE(error3.IsSet()); | |
| 94 EXPECT_EQ(error1.location().line_number(), error3.location().line_number()); | |
| 95 EXPECT_EQ(error1.message(), error3.message()); | |
| 96 EXPECT_EQ(error1.model_type(), error3.model_type()); | |
| 97 | |
| 98 SyncError error4; | |
| 99 EXPECT_FALSE(error4.IsSet()); | |
| 100 SyncError error5(error4); | |
| 101 EXPECT_FALSE(error5.IsSet()); | |
| 102 } | |
| 103 | |
| 104 TEST_F(SyncErrorTest, Assign) { | |
| 105 tracked_objects::Location location = FROM_HERE; | |
| 106 std::string msg = "test"; | |
| 107 ModelType type = PREFERENCES; | |
| 108 | |
| 109 SyncError error1; | |
| 110 EXPECT_FALSE(error1.IsSet()); | |
| 111 SyncError error2; | |
| 112 error2 = error1; | |
| 113 EXPECT_FALSE(error2.IsSet()); | |
| 114 | |
| 115 error1.Reset(location, msg, type); | |
| 116 ASSERT_TRUE(error1.IsSet()); | |
| 117 EXPECT_EQ(location.line_number(), error1.location().line_number()); | |
| 118 EXPECT_EQ(msg, error1.message()); | |
| 119 EXPECT_EQ(type, error1.model_type()); | |
| 120 | |
| 121 error2 = error1; | |
| 122 ASSERT_TRUE(error2.IsSet()); | |
| 123 EXPECT_EQ(error1.location().line_number(), error2.location().line_number()); | |
| 124 EXPECT_EQ(error1.message(), error2.message()); | |
| 125 EXPECT_EQ(error1.model_type(), error2.model_type()); | |
| 126 | |
| 127 error2 = SyncError(); | |
| 128 EXPECT_FALSE(error2.IsSet()); | |
| 129 } | |
| 130 | |
| 131 TEST_F(SyncErrorTest, ToString) { | |
| 132 tracked_objects::Location location = FROM_HERE; | |
| 133 std::string msg = "test"; | |
| 134 ModelType type = PREFERENCES; | |
| 135 std::string expected = std::string(ModelTypeToString(type)) + | |
| 136 " datatype error was encountered: " + msg; | |
| 137 LOG(INFO) << "Expect " << expected; | |
| 138 SyncError error(location, SyncError::DATATYPE_ERROR, msg, type); | |
| 139 EXPECT_TRUE(error.IsSet()); | |
| 140 EXPECT_NE(string::npos, error.ToString().find(expected)); | |
| 141 | |
| 142 SyncError error2; | |
| 143 EXPECT_FALSE(error2.IsSet()); | |
| 144 EXPECT_EQ(std::string(), error2.ToString()); | |
| 145 | |
| 146 error2 = error; | |
| 147 EXPECT_TRUE(error2.IsSet()); | |
| 148 EXPECT_NE(string::npos, error.ToString().find(expected)); | |
| 149 } | |
| 150 | |
| 151 } // namespace | |
| 152 | |
| 153 } // namespace syncer | |
| OLD | NEW |