| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/browser/invalidation/invalidation_logger.h" | 5 #include "chrome/browser/invalidation/invalidation_logger.h" |
| 6 #include "chrome/browser/invalidation/invalidation_logger_observer.h" | 6 #include "chrome/browser/invalidation/invalidation_logger_observer.h" |
| 7 | 7 |
| 8 #include "testing/gtest/include/gtest/gtest.h" | 8 #include "testing/gtest/include/gtest/gtest.h" |
| 9 | 9 |
| 10 namespace invalidation { | 10 namespace invalidation { |
| 11 | 11 |
| 12 class InvalidationLoggerTest : public testing::Test { | 12 class InvalidationLoggerTest : public testing::Test { |
| 13 public: | 13 public: |
| 14 InvalidationLoggerTest() {} | 14 InvalidationLoggerTest() {} |
| 15 }; | 15 }; |
| 16 | 16 |
| 17 class InvalidationLoggerObserverTest : public InvalidationLoggerObserver { | 17 class InvalidationLoggerObserverTest : public InvalidationLoggerObserver { |
| 18 public: | 18 public: |
| 19 InvalidationLoggerObserverTest() { resetStates(); } | 19 InvalidationLoggerObserverTest() { ResetStates(); } |
| 20 | 20 |
| 21 void resetStates() { | 21 void ResetStates() { |
| 22 registrationReceived = false; | 22 registration_received = false; |
| 23 unregistrationReceived = false; | 23 unregistration_received = false; |
| 24 stateReceived = false; | 24 state_received = false; |
| 25 updateIdReceived = false; | 25 update_id_received = false; |
| 26 debugMessageReceived = false; | 26 debug_message_received = false; |
| 27 invalidationReceived = false; | 27 invalidation_received = false; |
| 28 update_id_replicated = std::map<std::string, syncer::ObjectIdSet>(); |
| 28 } | 29 } |
| 29 | 30 |
| 30 virtual void OnRegistration(const base::DictionaryValue& details) OVERRIDE { | 31 virtual void OnRegistration(const base::DictionaryValue& details) OVERRIDE { |
| 31 registrationReceived = true; | 32 registration_received = true; |
| 32 } | 33 } |
| 33 | 34 |
| 34 virtual void OnUnregistration(const base::DictionaryValue& details) OVERRIDE { | 35 virtual void OnUnregistration(const base::DictionaryValue& details) OVERRIDE { |
| 35 unregistrationReceived = true; | 36 unregistration_received = true; |
| 36 } | 37 } |
| 37 | 38 |
| 38 virtual void OnStateChange(const syncer::InvalidatorState& newState) | 39 virtual void OnStateChange(const syncer::InvalidatorState& newState) |
| 39 OVERRIDE { | 40 OVERRIDE { |
| 40 stateReceived = true; | 41 state_received = true; |
| 41 } | 42 } |
| 42 | 43 |
| 43 virtual void OnUpdateIds(const base::DictionaryValue& details) OVERRIDE { | 44 virtual void OnUpdateIds(const std::string& handler, |
| 44 updateIdReceived = true; | 45 const syncer::ObjectIdSet& details) OVERRIDE { |
| 46 update_id_received = true; |
| 47 update_id_replicated[handler] = details; |
| 45 } | 48 } |
| 46 | 49 |
| 47 virtual void OnDebugMessage(const base::DictionaryValue& details) OVERRIDE { | 50 virtual void OnDebugMessage(const base::DictionaryValue& details) OVERRIDE { |
| 48 debugMessageReceived = true; | 51 debug_message_received = true; |
| 49 } | 52 } |
| 50 | 53 |
| 51 virtual void OnInvalidation( | 54 virtual void OnInvalidation( |
| 52 const syncer::ObjectIdInvalidationMap& newInvalidations) OVERRIDE { | 55 const syncer::ObjectIdInvalidationMap& newInvalidations) OVERRIDE { |
| 53 invalidationReceived = true; | 56 invalidation_received = true; |
| 54 } | 57 } |
| 55 | 58 |
| 56 bool registrationReceived; | 59 bool registration_received; |
| 57 bool unregistrationReceived; | 60 bool unregistration_received; |
| 58 bool stateReceived; | 61 bool state_received; |
| 59 bool updateIdReceived; | 62 bool update_id_received; |
| 60 bool debugMessageReceived; | 63 bool debug_message_received; |
| 61 bool invalidationReceived; | 64 bool invalidation_received; |
| 65 std::map<std::string, syncer::ObjectIdSet> update_id_replicated; |
| 62 }; | 66 }; |
| 63 | 67 |
| 64 // Test that the callbacks are actually being called when observers are | 68 // Test that the callbacks are actually being called when observers are |
| 65 // registered and don't produce any other callback in the meantime. | 69 // registered and don't produce any other callback in the meantime. |
| 66 TEST_F(InvalidationLoggerTest, TestCallbacks) { | 70 TEST_F(InvalidationLoggerTest, TestCallbacks) { |
| 67 InvalidationLogger log; | 71 InvalidationLogger log; |
| 68 InvalidationLoggerObserverTest observerTest; | 72 InvalidationLoggerObserverTest observer_test; |
| 69 | 73 |
| 70 log.RegisterForDebug(&observerTest); | 74 log.RegisterObserver(&observer_test); |
| 71 log.OnStateChange(syncer::INVALIDATIONS_ENABLED); | 75 log.OnStateChange(syncer::INVALIDATIONS_ENABLED); |
| 72 EXPECT_TRUE(observerTest.stateReceived); | 76 EXPECT_TRUE(observer_test.state_received); |
| 73 EXPECT_FALSE(observerTest.updateIdReceived); | 77 EXPECT_FALSE(observer_test.update_id_received); |
| 74 EXPECT_FALSE(observerTest.registrationReceived); | 78 EXPECT_FALSE(observer_test.registration_received); |
| 75 EXPECT_FALSE(observerTest.invalidationReceived); | 79 EXPECT_FALSE(observer_test.invalidation_received); |
| 76 EXPECT_FALSE(observerTest.unregistrationReceived); | 80 EXPECT_FALSE(observer_test.unregistration_received); |
| 77 EXPECT_FALSE(observerTest.debugMessageReceived); | 81 EXPECT_FALSE(observer_test.debug_message_received); |
| 78 | 82 |
| 79 observerTest.resetStates(); | 83 observer_test.ResetStates(); |
| 80 | 84 |
| 81 log.OnInvalidation(syncer::ObjectIdInvalidationMap()); | 85 log.OnInvalidation(syncer::ObjectIdInvalidationMap()); |
| 82 EXPECT_TRUE(observerTest.invalidationReceived); | 86 EXPECT_TRUE(observer_test.invalidation_received); |
| 83 EXPECT_FALSE(observerTest.stateReceived); | 87 EXPECT_FALSE(observer_test.state_received); |
| 84 EXPECT_FALSE(observerTest.updateIdReceived); | 88 EXPECT_FALSE(observer_test.update_id_received); |
| 85 EXPECT_FALSE(observerTest.registrationReceived); | 89 EXPECT_FALSE(observer_test.registration_received); |
| 86 EXPECT_FALSE(observerTest.unregistrationReceived); | 90 EXPECT_FALSE(observer_test.unregistration_received); |
| 87 EXPECT_FALSE(observerTest.debugMessageReceived); | 91 EXPECT_FALSE(observer_test.debug_message_received); |
| 88 | 92 |
| 89 log.UnregisterForDebug(&observerTest); | 93 log.UnregisterObserver(&observer_test); |
| 90 } | 94 } |
| 91 | 95 |
| 92 // Test that after registering an observer and then unregistering it | 96 // Test that after registering an observer and then unregistering it |
| 93 // no callbacks regarding that observer are called. | 97 // no callbacks regarding that observer are called. |
| 94 // (i.e. the observer is cleanly removed) | 98 // (i.e. the observer is cleanly removed) |
| 95 TEST_F(InvalidationLoggerTest, TestReleaseOfObserver) { | 99 TEST_F(InvalidationLoggerTest, TestReleaseOfObserver) { |
| 96 InvalidationLogger log; | 100 InvalidationLogger log; |
| 97 InvalidationLoggerObserverTest observerTest; | 101 InvalidationLoggerObserverTest observer_test; |
| 98 | 102 |
| 99 log.RegisterForDebug(&observerTest); | 103 log.RegisterObserver(&observer_test); |
| 100 log.UnregisterForDebug(&observerTest); | 104 log.UnregisterObserver(&observer_test); |
| 101 | 105 |
| 102 log.OnInvalidation(syncer::ObjectIdInvalidationMap()); | 106 log.OnInvalidation(syncer::ObjectIdInvalidationMap()); |
| 103 log.OnStateChange(syncer::INVALIDATIONS_ENABLED); | 107 log.OnStateChange(syncer::INVALIDATIONS_ENABLED); |
| 104 log.OnRegistration(base::DictionaryValue()); | 108 log.OnRegistration(base::DictionaryValue()); |
| 105 log.OnUnregistration(base::DictionaryValue()); | 109 log.OnUnregistration(base::DictionaryValue()); |
| 106 log.OnDebugMessage(base::DictionaryValue()); | 110 log.OnDebugMessage(base::DictionaryValue()); |
| 107 log.OnUpdateIds(base::DictionaryValue()); | 111 log.OnUpdateIds(std::map<std::string, syncer::ObjectIdSet>()); |
| 108 EXPECT_FALSE(observerTest.registrationReceived); | 112 EXPECT_FALSE(observer_test.registration_received); |
| 109 EXPECT_FALSE(observerTest.unregistrationReceived); | 113 EXPECT_FALSE(observer_test.unregistration_received); |
| 110 EXPECT_FALSE(observerTest.updateIdReceived); | 114 EXPECT_FALSE(observer_test.update_id_received); |
| 111 EXPECT_FALSE(observerTest.invalidationReceived); | 115 EXPECT_FALSE(observer_test.invalidation_received); |
| 112 EXPECT_FALSE(observerTest.stateReceived); | 116 EXPECT_FALSE(observer_test.state_received); |
| 113 EXPECT_FALSE(observerTest.debugMessageReceived); | 117 EXPECT_FALSE(observer_test.debug_message_received); |
| 114 } | 118 } |
| 115 | 119 |
| 116 // Test the EmitContet in InvalidationLogger is actually | 120 // Test the EmitContet in InvalidationLogger is actually |
| 117 // sending (only) state notifications. | 121 // sending state and updateIds notifications. |
| 118 TEST_F(InvalidationLoggerTest, TestEmitContent) { | 122 TEST_F(InvalidationLoggerTest, TestEmitContent) { |
| 119 InvalidationLogger log; | 123 InvalidationLogger log; |
| 120 InvalidationLoggerObserverTest observerTest; | 124 InvalidationLoggerObserverTest observer_test; |
| 121 | 125 |
| 122 log.RegisterForDebug(&observerTest); | 126 log.RegisterObserver(&observer_test); |
| 123 EXPECT_FALSE(observerTest.stateReceived); | 127 EXPECT_FALSE(observer_test.state_received); |
| 128 EXPECT_FALSE(observer_test.update_id_received); |
| 124 log.EmitContent(); | 129 log.EmitContent(); |
| 130 // Only expect state because no Ids were registered. |
| 131 EXPECT_TRUE(observer_test.state_received); |
| 132 EXPECT_FALSE(observer_test.registration_received); |
| 133 EXPECT_FALSE(observer_test.unregistration_received); |
| 134 EXPECT_FALSE(observer_test.update_id_received); |
| 135 EXPECT_FALSE(observer_test.invalidation_received); |
| 136 EXPECT_FALSE(observer_test.debug_message_received); |
| 125 | 137 |
| 126 EXPECT_TRUE(observerTest.stateReceived); | 138 observer_test.ResetStates(); |
| 127 EXPECT_FALSE(observerTest.registrationReceived); | 139 std::map<std::string, syncer::ObjectIdSet> test_map; |
| 128 EXPECT_FALSE(observerTest.unregistrationReceived); | 140 test_map["Test"] = syncer::ObjectIdSet(); |
| 129 EXPECT_FALSE(observerTest.updateIdReceived); | 141 log.OnUpdateIds(test_map); |
| 130 EXPECT_FALSE(observerTest.invalidationReceived); | 142 EXPECT_TRUE(observer_test.update_id_received); |
| 131 EXPECT_FALSE(observerTest.debugMessageReceived); | 143 observer_test.ResetStates(); |
| 132 log.UnregisterForDebug(&observerTest); | 144 |
| 145 log.EmitContent(); |
| 146 // Expect now state and ids change. |
| 147 EXPECT_TRUE(observer_test.state_received); |
| 148 EXPECT_TRUE(observer_test.update_id_received); |
| 149 EXPECT_FALSE(observer_test.registration_received); |
| 150 EXPECT_FALSE(observer_test.unregistration_received); |
| 151 EXPECT_FALSE(observer_test.invalidation_received); |
| 152 EXPECT_FALSE(observer_test.debug_message_received); |
| 153 log.UnregisterObserver(&observer_test); |
| 154 } |
| 155 |
| 156 // Test that the updateId notification actually sends |
| 157 // what was sent to the Observer. |
| 158 // The ObserverTest rebuilds the map that was sent in pieces by the logger. |
| 159 TEST_F(InvalidationLoggerTest, TestUpdateIdsMap) { |
| 160 InvalidationLogger log; |
| 161 InvalidationLoggerObserverTest observer_test; |
| 162 std::map<std::string, syncer::ObjectIdSet> test_map; |
| 163 log.RegisterObserver(&observer_test); |
| 164 |
| 165 syncer::ObjectIdSet sync_set_A; |
| 166 sync_set_A.insert(ObjectId(1000, "DataType1")); |
| 167 sync_set_A.insert(ObjectId(1000, "DataType2")); |
| 168 syncer::ObjectIdSet sync_set_B; |
| 169 sync_set_B.insert(ObjectId(1020, "DataTypeA")); |
| 170 test_map["TestA"] = sync_set_A; |
| 171 test_map["TestB"] = sync_set_B; |
| 172 |
| 173 log.OnUpdateIds(test_map); |
| 174 EXPECT_EQ(test_map, observer_test.update_id_replicated); |
| 175 |
| 176 syncer::ObjectIdSet sync_set_B2; |
| 177 sync_set_B2.insert(ObjectId(1020, "DataTypeF")); |
| 178 sync_set_B2.insert(ObjectId(1020, "DataTypeG")); |
| 179 test_map["TestB"] = sync_set_B2; |
| 180 |
| 181 log.OnUpdateIds(test_map); |
| 182 EXPECT_EQ(test_map, observer_test.update_id_replicated); |
| 183 |
| 184 // The emit content should return the same map too. |
| 185 observer_test.ResetStates(); |
| 186 log.EmitContent(); |
| 187 EXPECT_EQ(test_map, observer_test.update_id_replicated); |
| 188 |
| 189 log.UnregisterObserver(&observer_test); |
| 133 } | 190 } |
| 134 } // namespace invalidation | 191 } // namespace invalidation |
| OLD | NEW |