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

Unified Diff: chrome/browser/extensions/api/push_messaging/push_messaging_invalidation_handler_unittest.cc

Issue 56113003: Implement new invalidations ack tracking system (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Modify drive TODO comment + rebase Created 7 years, 1 month 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: chrome/browser/extensions/api/push_messaging/push_messaging_invalidation_handler_unittest.cc
diff --git a/chrome/browser/extensions/api/push_messaging/push_messaging_invalidation_handler_unittest.cc b/chrome/browser/extensions/api/push_messaging/push_messaging_invalidation_handler_unittest.cc
index 5c29b50a1f90e6bb5a2d17f3d3f8c8b8e5cacfe4..f868f9c680eec40d9ecf9998fc55e09fe9ca0485 100644
--- a/chrome/browser/extensions/api/push_messaging/push_messaging_invalidation_handler_unittest.cc
+++ b/chrome/browser/extensions/api/push_messaging/push_messaging_invalidation_handler_unittest.cc
@@ -9,7 +9,6 @@
#include "chrome/browser/extensions/api/push_messaging/push_messaging_invalidation_handler_delegate.h"
#include "chrome/browser/invalidation/invalidation_service.h"
#include "google/cacheinvalidation/types.pb.h"
-#include "sync/internal_api/public/base/invalidation_test_util.h"
#include "sync/notifier/object_id_invalidation_map.h"
#include "testing/gmock/include/gmock/gmock.h"
#include "testing/gtest/include/gtest/gtest.h"
@@ -18,7 +17,6 @@ using ::testing::_;
using ::testing::NotNull;
using ::testing::SaveArg;
using ::testing::StrictMock;
-using syncer::AckHandle;
namespace extensions {
@@ -34,8 +32,6 @@ class MockInvalidationService : public invalidation::InvalidationService {
void(syncer::InvalidationHandler*, const syncer::ObjectIdSet&));
MOCK_METHOD1(UnregisterInvalidationHandler,
void(syncer::InvalidationHandler*));
- MOCK_METHOD2(AcknowledgeInvalidation, void(const invalidation::ObjectId&,
- const syncer::AckHandle&));
MOCK_CONST_METHOD0(GetInvalidatorState, syncer::InvalidatorState());
MOCK_CONST_METHOD0(GetInvalidatorClientId, std::string());
@@ -126,14 +122,6 @@ TEST_F(PushMessagingInvalidationHandlerTest, Dispatch) {
OnMessage("dddddddddddddddddddddddddddddddd", 0, "payload"));
EXPECT_CALL(delegate_,
OnMessage("dddddddddddddddddddddddddddddddd", 3, ""));
-
- syncer::ObjectIdSet ids = invalidation_map.GetObjectIds();
- for (syncer::ObjectIdSet::const_iterator it = ids.begin(); it != ids.end();
- ++it) {
- const syncer::Invalidation& inv = invalidation_map.ForObject(*it).back();
- const syncer::AckHandle& ack_handle = inv.ack_handle();
- EXPECT_CALL(service_, AcknowledgeInvalidation(*it, ack_handle));
- }
handler_->OnIncomingInvalidation(invalidation_map);
}
@@ -170,15 +158,50 @@ TEST_F(PushMessagingInvalidationHandlerTest, DispatchInvalidObjectIds) {
invalidation::ObjectId(
ipc::invalidation::ObjectSource::CHROME_PUSH_MESSAGING,
"U/dddddddddddddddddddddddddddddddd/4")));
- // Invalid object IDs should still be acknowledged.
- syncer::ObjectIdSet ids = invalidation_map.GetObjectIds();
- for (syncer::ObjectIdSet::const_iterator it = ids.begin(); it != ids.end();
- ++it) {
- const syncer::Invalidation& inv = invalidation_map.ForObject(*it).back();
- const syncer::AckHandle& ack_handle = inv.ack_handle();
- EXPECT_CALL(service_, AcknowledgeInvalidation(*it, ack_handle));
- }
handler_->OnIncomingInvalidation(invalidation_map);
}
+// Test version filtering of incoming invalidations.
+TEST_F(PushMessagingInvalidationHandlerTest, InvalidationVersionsOutOfOrder) {
+ const invalidation::ObjectId id0(
+ ipc::invalidation::ObjectSource::CHROME_PUSH_MESSAGING,
+ "U/dddddddddddddddddddddddddddddddd/0");
+ const invalidation::ObjectId id3(
+ ipc::invalidation::ObjectSource::CHROME_PUSH_MESSAGING,
+ "U/dddddddddddddddddddddddddddddddd/3");
+
+ // The first received invalidation should get through.
+ syncer::ObjectIdInvalidationMap map1;
+ map1.Insert(syncer::Invalidation::Init(id0, 5, "5"));
+ EXPECT_CALL(delegate_, OnMessage("dddddddddddddddddddddddddddddddd", 0, "5"));
+ handler_->OnIncomingInvalidation(map1);
+ testing::Mock::VerifyAndClearExpectations(&delegate_);
+
+ // Invalid versions are always allowed through.
+ syncer::ObjectIdInvalidationMap map2;
+ map2.Insert(syncer::Invalidation::InitUnknownVersion(id0));
+ EXPECT_CALL(delegate_, OnMessage("dddddddddddddddddddddddddddddddd", 0, ""));
+ handler_->OnIncomingInvalidation(map2);
+ testing::Mock::VerifyAndClearExpectations(&delegate_);
+
+ // An older version should not make it through.
+ syncer::ObjectIdInvalidationMap map3;
+ map3.Insert(syncer::Invalidation::Init(id0, 4, "4"));
+ handler_->OnIncomingInvalidation(map3);
+
+ // A newer version will make it through.
+ syncer::ObjectIdInvalidationMap map4;
+ map4.Insert(syncer::Invalidation::Init(id0, 6, "6"));
+ EXPECT_CALL(delegate_, OnMessage("dddddddddddddddddddddddddddddddd", 0, "6"));
+ handler_->OnIncomingInvalidation(map4);
+ testing::Mock::VerifyAndClearExpectations(&delegate_);
+
+ // An unrelated object should be unaffected by all the above.
+ syncer::ObjectIdInvalidationMap map5;
+ map5.Insert(syncer::Invalidation::Init(id3, 1, "1"));
+ EXPECT_CALL(delegate_, OnMessage("dddddddddddddddddddddddddddddddd", 3, "1"));
+ handler_->OnIncomingInvalidation(map5);
+ testing::Mock::VerifyAndClearExpectations(&delegate_);
+}
+
} // namespace extensions

Powered by Google App Engine
This is Rietveld 408576698