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

Side by Side Diff: components/bookmarks/browser/managed_bookmarks_tracker_unittest.cc

Issue 305973004: BookmarkClient can add extra nodes to BookmarkModel. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase Created 6 years, 6 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
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
3 // found in the LICENSE file.
4
5 #include "components/bookmarks/browser/managed_bookmarks_tracker.h"
6
7 #include "base/files/file_path.h"
8 #include "base/memory/scoped_ptr.h"
9 #include "base/message_loop/message_loop.h"
10 #include "base/prefs/pref_registry_simple.h"
11 #include "base/prefs/testing_pref_service.h"
12 #include "base/strings/utf_string_conversions.h"
13 #include "components/bookmarks/browser/bookmark_model.h"
14 #include "components/bookmarks/browser/bookmark_model_observer.h"
15 #include "components/bookmarks/browser/bookmark_node.h"
16 #include "components/bookmarks/common/bookmark_pref_names.h"
17 #include "components/bookmarks/test/bookmark_test_helpers.h"
18 #include "components/bookmarks/test/test_bookmark_client.h"
19 #include "grit/components_strings.h"
20 #include "testing/gmock/include/gmock/gmock.h"
21 #include "testing/gtest/include/gtest/gtest.h"
22 #include "ui/base/l10n/l10n_util.h"
23 #include "url/gurl.h"
24
25 using testing::Mock;
26 using testing::_;
27
28 namespace {
29
30 class MockBookmarkModelObserver : public BookmarkModelObserver {
31 public:
32 MockBookmarkModelObserver() {}
33 virtual ~MockBookmarkModelObserver() {}
34
35 MOCK_METHOD2(BookmarkModelLoaded, void(BookmarkModel*, bool));
36
37 MOCK_METHOD5(BookmarkNodeMoved, void(BookmarkModel*,
38 const BookmarkNode*,
39 int,
40 const BookmarkNode*,
41 int));
42
43 MOCK_METHOD3(BookmarkNodeAdded, void(BookmarkModel*,
44 const BookmarkNode*,
45 int));
46
47 MOCK_METHOD5(BookmarkNodeRemoved, void(BookmarkModel*,
48 const BookmarkNode*,
49 int,
50 const BookmarkNode*,
51 const std::set<GURL>&));
52
53 MOCK_METHOD2(BookmarkNodeChanged, void(BookmarkModel*, const BookmarkNode*));
54
55 MOCK_METHOD2(BookmarkNodeFaviconChanged, void(BookmarkModel*,
56 const BookmarkNode*));
57
58 MOCK_METHOD2(BookmarkNodeChildrenReordered, void(BookmarkModel*,
59 const BookmarkNode*));
60
61 MOCK_METHOD2(BookmarkAllNodesRemoved, void(BookmarkModel*,
62 const std::set<GURL>&));
63 };
64
65 } // namespace
66
67 class ManagedBookmarksTrackerTest : public testing::Test {
68 public:
69 virtual void SetUp() OVERRIDE {
70 prefs_.registry()->RegisterListPref(prefs::kManagedBookmarks);
71 prefs_.registry()->RegisterListPref(prefs::kBookmarkEditorExpandedNodes);
72 }
73
74 virtual void TearDown() {
75 if (model_)
76 model_->RemoveObserver(&observer_);
77 }
78
79 void CreateModel() {
80 model_.reset(new BookmarkModel(&client_, false));
81 model_->AddObserver(&observer_);
82 EXPECT_CALL(observer_, BookmarkModelLoaded(model_.get(), _));
83 model_->Load(&prefs_,
84 std::string(),
85 base::FilePath(),
86 base::MessageLoopProxy::current(),
87 base::MessageLoopProxy::current());
88 test::WaitForBookmarkModelToLoad(model_.get());
89 Mock::VerifyAndClearExpectations(&observer_);
90 }
91
92 base::DictionaryValue* CreateBookmark(const std::string& title,
93 const std::string& url) {
94 EXPECT_TRUE(GURL(url).is_valid());
95 base::DictionaryValue* dict = new base::DictionaryValue();
96 dict->SetString("name", title);
97 dict->SetString("url", GURL(url).spec());
98 return dict;
99 }
100
101 base::DictionaryValue* CreateFolder(const std::string& title,
102 base::ListValue* children) {
103 base::DictionaryValue* dict = new base::DictionaryValue();
104 dict->SetString("name", title);
105 dict->Set("children", children);
106 return dict;
107 }
108
109 base::ListValue* CreateTestTree() {
110 base::ListValue* folder = new base::ListValue();
111 base::ListValue* empty = new base::ListValue();
112 folder->Append(CreateFolder("Empty", empty));
113 folder->Append(CreateBookmark("Youtube", "http://youtube.com/"));
114
115 base::ListValue* list = new base::ListValue();
116 list->Append(CreateBookmark("Google", "http://google.com/"));
117 list->Append(CreateFolder("Folder", folder));
118
119 return list;
120 }
121
122 std::string GetManagedFolderTitle() {
123 return l10n_util::GetStringUTF8(
124 IDS_BOOKMARK_BAR_MANAGED_FOLDER_DEFAULT_NAME);
125 }
126
127 base::DictionaryValue* CreateExpectedTree() {
128 return CreateFolder(GetManagedFolderTitle(), CreateTestTree());
129 }
130
131 bool NodeMatchesValue(const BookmarkNode* node,
132 const base::DictionaryValue* dict) {
133 base::string16 title;
134 if (!dict->GetString("name", &title) || node->GetTitle() != title)
135 return false;
136
137 if (node->is_folder()) {
138 const base::ListValue* children = NULL;
139 if (!dict->GetList("children", &children) ||
140 node->child_count() != static_cast<int>(children->GetSize())) {
141 return false;
142 }
143 for (int i = 0; i < node->child_count(); ++i) {
144 const base::DictionaryValue* child = NULL;
145 if (!children->GetDictionary(i, &child) ||
146 !NodeMatchesValue(node->GetChild(i), child)) {
147 return false;
148 }
149 }
150 } else if (node->is_url()) {
151 std::string url;
152 if (!dict->GetString("url", &url) || node->url() != GURL(url))
153 return false;
154 } else {
155 return false;
156 }
157 return true;
158 }
159
160 base::MessageLoop loop_;
161 TestingPrefServiceSimple prefs_;
162 test::TestBookmarkClient client_;
163 scoped_ptr<BookmarkModel> model_;
164 MockBookmarkModelObserver observer_;
165 };
166
167 TEST_F(ManagedBookmarksTrackerTest, Empty) {
168 CreateModel();
169 EXPECT_TRUE(model_->bookmark_bar_node()->empty());
170 EXPECT_TRUE(model_->other_node()->empty());
171 EXPECT_TRUE(model_->managed_node()->empty());
172 EXPECT_FALSE(model_->managed_node()->IsVisible());
173 }
174
175 TEST_F(ManagedBookmarksTrackerTest, LoadInitial) {
176 // Set a policy before loading the model.
177 prefs_.SetManagedPref(prefs::kManagedBookmarks, CreateTestTree());
178 CreateModel();
179 EXPECT_TRUE(model_->bookmark_bar_node()->empty());
180 EXPECT_TRUE(model_->other_node()->empty());
181 EXPECT_FALSE(model_->managed_node()->empty());
182 EXPECT_TRUE(model_->managed_node()->IsVisible());
183
184 scoped_ptr<base::DictionaryValue> expected(CreateExpectedTree());
185 EXPECT_TRUE(NodeMatchesValue(model_->managed_node(), expected.get()));
186 }
187
188 TEST_F(ManagedBookmarksTrackerTest, SwapNodes) {
189 prefs_.SetManagedPref(prefs::kManagedBookmarks, CreateTestTree());
190 CreateModel();
191
192 // Swap the Google bookmark with the Folder.
193 scoped_ptr<base::ListValue> updated(CreateTestTree());
194 scoped_ptr<base::Value> removed;
195 ASSERT_TRUE(updated->Remove(0, &removed));
196 updated->Append(removed.release());
197
198 // These two nodes should just be swapped.
199 const BookmarkNode* parent = model_->managed_node();
200 EXPECT_CALL(observer_, BookmarkNodeMoved(model_.get(), parent, 1, parent, 0));
201 prefs_.SetManagedPref(prefs::kManagedBookmarks, updated->DeepCopy());
202 Mock::VerifyAndClearExpectations(&observer_);
203
204 // Verify the final tree.
205 scoped_ptr<base::DictionaryValue> expected(
206 CreateFolder(GetManagedFolderTitle(), updated.release()));
207 EXPECT_TRUE(NodeMatchesValue(model_->managed_node(), expected.get()));
208 }
209
210 TEST_F(ManagedBookmarksTrackerTest, RemoveNode) {
211 prefs_.SetManagedPref(prefs::kManagedBookmarks, CreateTestTree());
212 CreateModel();
213
214 // Remove the Folder.
215 scoped_ptr<base::ListValue> updated(CreateTestTree());
216 ASSERT_TRUE(updated->Remove(1, NULL));
217
218 const BookmarkNode* parent = model_->managed_node();
219 EXPECT_CALL(observer_, BookmarkNodeRemoved(model_.get(), parent, 1, _, _));
220 prefs_.SetManagedPref(prefs::kManagedBookmarks, updated->DeepCopy());
221 Mock::VerifyAndClearExpectations(&observer_);
222
223 // Verify the final tree.
224 scoped_ptr<base::DictionaryValue> expected(
225 CreateFolder(GetManagedFolderTitle(), updated.release()));
226 EXPECT_TRUE(NodeMatchesValue(model_->managed_node(), expected.get()));
227 }
228
229 TEST_F(ManagedBookmarksTrackerTest, CreateNewNodes) {
230 prefs_.SetManagedPref(prefs::kManagedBookmarks, CreateTestTree());
231 CreateModel();
232
233 // Put all the nodes inside another folder.
234 scoped_ptr<base::ListValue> updated(new base::ListValue);
235 updated->Append(CreateFolder("Container", CreateTestTree()));
236
237 EXPECT_CALL(observer_, BookmarkNodeAdded(model_.get(), _, _)).Times(5);
238 // The remaining nodes have been pushed to positions 1 and 2; they'll both be
239 // removed when at position 1.
240 const BookmarkNode* parent = model_->managed_node();
241 EXPECT_CALL(observer_, BookmarkNodeRemoved(model_.get(), parent, 1, _, _))
242 .Times(2);
243 prefs_.SetManagedPref(prefs::kManagedBookmarks, updated->DeepCopy());
244 Mock::VerifyAndClearExpectations(&observer_);
245
246 // Verify the final tree.
247 scoped_ptr<base::DictionaryValue> expected(
248 CreateFolder(GetManagedFolderTitle(), updated.release()));
249 EXPECT_TRUE(NodeMatchesValue(model_->managed_node(), expected.get()));
250 }
251
252 TEST_F(ManagedBookmarksTrackerTest, RemoveAll) {
253 prefs_.SetManagedPref(prefs::kManagedBookmarks, CreateTestTree());
254 CreateModel();
255 EXPECT_TRUE(model_->managed_node()->IsVisible());
256
257 // Remove the policy.
258 const BookmarkNode* parent = model_->managed_node();
259 EXPECT_CALL(observer_, BookmarkNodeRemoved(model_.get(), parent, 0, _, _))
260 .Times(2);
261 prefs_.RemoveManagedPref(prefs::kManagedBookmarks);
262 Mock::VerifyAndClearExpectations(&observer_);
263
264 EXPECT_TRUE(model_->managed_node()->empty());
265 EXPECT_FALSE(model_->managed_node()->IsVisible());
266 }
267
268 TEST_F(ManagedBookmarksTrackerTest, IsManaged) {
269 prefs_.SetManagedPref(prefs::kManagedBookmarks, CreateTestTree());
270 CreateModel();
271
272 EXPECT_FALSE(model_->IsManaged(model_->root_node()));
273 EXPECT_FALSE(model_->IsManaged(model_->bookmark_bar_node()));
274 EXPECT_FALSE(model_->IsManaged(model_->other_node()));
275 EXPECT_FALSE(model_->IsManaged(model_->mobile_node()));
276 EXPECT_TRUE(model_->IsManaged(model_->managed_node()));
277
278 const BookmarkNode* parent = model_->managed_node();
279 ASSERT_EQ(2, parent->child_count());
280 EXPECT_TRUE(model_->IsManaged(parent->GetChild(0)));
281 EXPECT_TRUE(model_->IsManaged(parent->GetChild(1)));
282
283 parent = parent->GetChild(1);
284 ASSERT_EQ(2, parent->child_count());
285 EXPECT_TRUE(model_->IsManaged(parent->GetChild(0)));
286 EXPECT_TRUE(model_->IsManaged(parent->GetChild(1)));
287 }
288
289 TEST_F(ManagedBookmarksTrackerTest, RemoveAllDoesntRemoveManaged) {
290 prefs_.SetManagedPref(prefs::kManagedBookmarks, CreateTestTree());
291 CreateModel();
292 EXPECT_EQ(2, model_->managed_node()->child_count());
293
294 EXPECT_CALL(observer_,
295 BookmarkNodeAdded(model_.get(), model_->bookmark_bar_node(), 0));
296 EXPECT_CALL(observer_,
297 BookmarkNodeAdded(model_.get(), model_->bookmark_bar_node(), 1));
298 model_->AddURL(model_->bookmark_bar_node(),
299 0,
300 base::ASCIIToUTF16("Test"),
301 GURL("http://google.com/"));
302 model_->AddFolder(
303 model_->bookmark_bar_node(), 1, base::ASCIIToUTF16("Test Folder"));
304 EXPECT_EQ(2, model_->bookmark_bar_node()->child_count());
305 Mock::VerifyAndClearExpectations(&observer_);
306
307 EXPECT_CALL(observer_, BookmarkAllNodesRemoved(model_.get(), _));
308 model_->RemoveAll();
309 EXPECT_EQ(2, model_->managed_node()->child_count());
310 EXPECT_EQ(0, model_->bookmark_bar_node()->child_count());
311 Mock::VerifyAndClearExpectations(&observer_);
312 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698