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

Unified Diff: sync/notifier/object_id_state_map_test_util.cc

Issue 10837214: Refactor ModelTypePayloadMap and ObjectIdPayloadMap to StateMaps. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix unit test Created 8 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
« no previous file with comments | « sync/notifier/object_id_state_map_test_util.h ('k') | sync/notifier/p2p_notifier.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: sync/notifier/object_id_state_map_test_util.cc
diff --git a/sync/notifier/object_id_state_map_test_util.cc b/sync/notifier/object_id_state_map_test_util.cc
new file mode 100644
index 0000000000000000000000000000000000000000..58659af0357454ab050fe5675be4707a284c0295
--- /dev/null
+++ b/sync/notifier/object_id_state_map_test_util.cc
@@ -0,0 +1,110 @@
+// Copyright (c) 2012 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 "sync/notifier/object_id_state_map_test_util.h"
+
+#include <algorithm>
+
+#include "base/basictypes.h"
+
+namespace syncer {
+
+using ::testing::MakeMatcher;
+using ::testing::MatchResultListener;
+using ::testing::Matcher;
+using ::testing::MatcherInterface;
+using ::testing::PrintToString;
+
+namespace {
+
+class ObjectIdStateMapEqMatcher
+ : public MatcherInterface<const ObjectIdStateMap&> {
+ public:
+ explicit ObjectIdStateMapEqMatcher(const ObjectIdStateMap& expected);
+
+ virtual bool MatchAndExplain(const ObjectIdStateMap& actual,
+ MatchResultListener* listener) const;
+ virtual void DescribeTo(::std::ostream* os) const;
+ virtual void DescribeNegationTo(::std::ostream* os) const;
+
+ private:
+ const ObjectIdStateMap expected_;
+
+ DISALLOW_COPY_AND_ASSIGN(ObjectIdStateMapEqMatcher);
+};
+
+ObjectIdStateMapEqMatcher::ObjectIdStateMapEqMatcher(
+ const ObjectIdStateMap& expected) : expected_(expected) {
+}
+
+bool ObjectIdStateMapEqMatcher::MatchAndExplain(
+ const ObjectIdStateMap& actual, MatchResultListener* listener) const {
+ ObjectIdStateMap expected_only;
+ ObjectIdStateMap actual_only;
+ typedef std::pair<invalidation::ObjectId,
+ std::pair<InvalidationState, InvalidationState> >
+ ValueDifference;
+ std::vector<ValueDifference> value_differences;
+
+ std::set_difference(expected_.begin(), expected_.end(),
+ actual.begin(), actual.end(),
+ std::inserter(expected_only, expected_only.begin()),
+ expected_.value_comp());
+ std::set_difference(actual.begin(), actual.end(),
+ expected_.begin(), expected_.end(),
+ std::inserter(actual_only, actual_only.begin()),
+ actual.value_comp());
+
+ for (ObjectIdStateMap::const_iterator it = expected_.begin();
+ it != expected_.end(); ++it) {
+ ObjectIdStateMap::const_iterator find_it =
+ actual.find(it->first);
+ if (find_it != actual.end() &&
+ !Matches(Eq(it->second))(find_it->second)) {
+ value_differences.push_back(std::make_pair(
+ it->first, std::make_pair(it->second, find_it->second)));
+ }
+ }
+
+ if (expected_only.empty() && actual_only.empty() && value_differences.empty())
+ return true;
+
+ bool printed_header = false;
+ if (!actual_only.empty()) {
+ *listener << " which has these unexpected elements: "
+ << PrintToString(actual_only);
+ printed_header = true;
+ }
+
+ if (!expected_only.empty()) {
+ *listener << (printed_header ? ",\nand" : "which")
+ << " doesn't have these expected elements: "
+ << PrintToString(expected_only);
+ printed_header = true;
+ }
+
+ if (!value_differences.empty()) {
+ *listener << (printed_header ? ",\nand" : "which")
+ << " differ in the following values: "
+ << PrintToString(value_differences);
+ }
+
+ return false;
+}
+
+void ObjectIdStateMapEqMatcher::DescribeTo(::std::ostream* os) const {
+ *os << " is equal to " << PrintToString(expected_);
+}
+
+void ObjectIdStateMapEqMatcher::DescribeNegationTo(::std::ostream* os) const {
+ *os << " isn't equal to " << PrintToString(expected_);
+}
+
+} // namespace
+
+Matcher<const ObjectIdStateMap&> Eq(const ObjectIdStateMap& expected) {
+ return MakeMatcher(new ObjectIdStateMapEqMatcher(expected));
+}
+
+} // namespace syncer
« no previous file with comments | « sync/notifier/object_id_state_map_test_util.h ('k') | sync/notifier/p2p_notifier.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698