| 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/bookmarks/chrome_bookmark_client.h" | |
| 6 | |
| 7 #include "base/macros.h" | 5 #include "base/macros.h" |
| 8 #include "base/memory/scoped_ptr.h" | 6 #include "base/memory/scoped_ptr.h" |
| 9 #include "base/strings/utf_string_conversions.h" | 7 #include "base/strings/utf_string_conversions.h" |
| 10 #include "base/values.h" | 8 #include "base/values.h" |
| 11 #include "chrome/browser/bookmarks/bookmark_model_factory.h" | 9 #include "chrome/browser/bookmarks/bookmark_model_factory.h" |
| 12 #include "chrome/browser/bookmarks/chrome_bookmark_client.h" | 10 #include "chrome/browser/bookmarks/chrome_bookmark_client.h" |
| 13 #include "chrome/browser/bookmarks/chrome_bookmark_client_factory.h" | 11 #include "chrome/browser/bookmarks/managed_bookmark_service_factory.h" |
| 14 #include "chrome/test/base/testing_pref_service_syncable.h" | 12 #include "chrome/test/base/testing_pref_service_syncable.h" |
| 15 #include "chrome/test/base/testing_profile.h" | 13 #include "chrome/test/base/testing_profile.h" |
| 16 #include "components/bookmarks/browser/bookmark_model.h" | 14 #include "components/bookmarks/browser/bookmark_model.h" |
| 17 #include "components/bookmarks/browser/bookmark_node.h" | 15 #include "components/bookmarks/browser/bookmark_node.h" |
| 18 #include "components/bookmarks/browser/bookmark_utils.h" | 16 #include "components/bookmarks/browser/bookmark_utils.h" |
| 19 #include "components/bookmarks/common/bookmark_pref_names.h" | 17 #include "components/bookmarks/common/bookmark_pref_names.h" |
| 18 #include "components/bookmarks/managed/managed_bookmark_service.h" |
| 20 #include "components/bookmarks/test/bookmark_test_helpers.h" | 19 #include "components/bookmarks/test/bookmark_test_helpers.h" |
| 21 #include "components/bookmarks/test/mock_bookmark_model_observer.h" | 20 #include "components/bookmarks/test/mock_bookmark_model_observer.h" |
| 22 #include "content/public/test/test_browser_thread_bundle.h" | 21 #include "content/public/test/test_browser_thread_bundle.h" |
| 23 #include "grit/components_strings.h" | 22 #include "grit/components_strings.h" |
| 24 #include "testing/gmock/include/gmock/gmock.h" | 23 #include "testing/gmock/include/gmock/gmock.h" |
| 25 #include "testing/gtest/include/gtest/gtest.h" | 24 #include "testing/gtest/include/gtest/gtest.h" |
| 26 #include "ui/base/l10n/l10n_util.h" | 25 #include "ui/base/l10n/l10n_util.h" |
| 27 | 26 |
| 28 using bookmarks::BookmarkModel; | 27 using bookmarks::BookmarkModel; |
| 29 using bookmarks::BookmarkNode; | 28 using bookmarks::BookmarkNode; |
| 29 using bookmarks::ManagedBookmarkService; |
| 30 using testing::Mock; | 30 using testing::Mock; |
| 31 using testing::_; | 31 using testing::_; |
| 32 | 32 |
| 33 class ChromeBookmarkClientTest : public testing::Test { | 33 class ManagedBookmarkServiceTest : public testing::Test { |
| 34 public: | 34 public: |
| 35 ChromeBookmarkClientTest() : client_(NULL), model_(NULL) {} | 35 ManagedBookmarkServiceTest() : managed_(NULL), model_(NULL) {} |
| 36 ~ChromeBookmarkClientTest() override {} | 36 ~ManagedBookmarkServiceTest() override {} |
| 37 | 37 |
| 38 void SetUp() override { | 38 void SetUp() override { |
| 39 prefs_ = profile_.GetTestingPrefService(); | 39 prefs_ = profile_.GetTestingPrefService(); |
| 40 ASSERT_FALSE(prefs_->HasPrefPath(bookmarks::prefs::kManagedBookmarks)); | 40 ASSERT_FALSE(prefs_->HasPrefPath(bookmarks::prefs::kManagedBookmarks)); |
| 41 | 41 |
| 42 prefs_->SetManagedPref(bookmarks::prefs::kManagedBookmarks, | 42 prefs_->SetManagedPref(bookmarks::prefs::kManagedBookmarks, |
| 43 CreateTestTree()); | 43 CreateTestTree()); |
| 44 ResetModel(); | 44 ResetModel(); |
| 45 | 45 |
| 46 // The managed node always exists. | 46 // The managed node always exists. |
| 47 ASSERT_TRUE(client_->managed_node()); | 47 ASSERT_TRUE(managed_->managed_node()); |
| 48 ASSERT_TRUE(client_->managed_node()->parent() == model_->root_node()); | 48 ASSERT_TRUE(managed_->managed_node()->parent() == model_->root_node()); |
| 49 EXPECT_NE(-1, model_->root_node()->GetIndexOf(client_->managed_node())); | 49 EXPECT_NE(-1, model_->root_node()->GetIndexOf(managed_->managed_node())); |
| 50 } | 50 } |
| 51 | 51 |
| 52 void TearDown() override { model_->RemoveObserver(&observer_); } | 52 void TearDown() override { model_->RemoveObserver(&observer_); } |
| 53 | 53 |
| 54 void ResetModel() { | 54 void ResetModel() { |
| 55 profile_.CreateBookmarkModel(false); | 55 profile_.CreateBookmarkModel(false); |
| 56 model_ = BookmarkModelFactory::GetForProfile(&profile_); | 56 model_ = BookmarkModelFactory::GetForProfile(&profile_); |
| 57 bookmarks::test::WaitForBookmarkModelToLoad(model_); | 57 bookmarks::test::WaitForBookmarkModelToLoad(model_); |
| 58 model_->AddObserver(&observer_); | 58 model_->AddObserver(&observer_); |
| 59 client_ = ChromeBookmarkClientFactory::GetForProfile(&profile_); | 59 managed_ = ManagedBookmarkServiceFactory::GetForProfile(&profile_); |
| 60 DCHECK(client_); | 60 DCHECK(managed_); |
| 61 } | 61 } |
| 62 | 62 |
| 63 static base::DictionaryValue* CreateBookmark(const std::string& title, | 63 static base::DictionaryValue* CreateBookmark(const std::string& title, |
| 64 const std::string& url) { | 64 const std::string& url) { |
| 65 EXPECT_TRUE(GURL(url).is_valid()); | 65 EXPECT_TRUE(GURL(url).is_valid()); |
| 66 base::DictionaryValue* dict = new base::DictionaryValue(); | 66 base::DictionaryValue* dict = new base::DictionaryValue(); |
| 67 dict->SetString("name", title); | 67 dict->SetString("name", title); |
| 68 dict->SetString("url", GURL(url).spec()); | 68 dict->SetString("url", GURL(url).spec()); |
| 69 return dict; | 69 return dict; |
| 70 } | 70 } |
| (...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 125 } else { | 125 } else { |
| 126 return false; | 126 return false; |
| 127 } | 127 } |
| 128 return true; | 128 return true; |
| 129 } | 129 } |
| 130 | 130 |
| 131 content::TestBrowserThreadBundle thread_bundle_; | 131 content::TestBrowserThreadBundle thread_bundle_; |
| 132 TestingProfile profile_; | 132 TestingProfile profile_; |
| 133 TestingPrefServiceSyncable* prefs_; | 133 TestingPrefServiceSyncable* prefs_; |
| 134 bookmarks::MockBookmarkModelObserver observer_; | 134 bookmarks::MockBookmarkModelObserver observer_; |
| 135 ChromeBookmarkClient* client_; | 135 ManagedBookmarkService* managed_; |
| 136 BookmarkModel* model_; | 136 BookmarkModel* model_; |
| 137 | 137 |
| 138 DISALLOW_COPY_AND_ASSIGN(ChromeBookmarkClientTest); | 138 DISALLOW_COPY_AND_ASSIGN(ManagedBookmarkServiceTest); |
| 139 }; | 139 }; |
| 140 | 140 |
| 141 TEST_F(ChromeBookmarkClientTest, EmptyManagedNode) { | 141 TEST_F(ManagedBookmarkServiceTest, EmptyManagedNode) { |
| 142 // Verifies that the managed node is empty and invisible when the policy is | 142 // Verifies that the managed node is empty and invisible when the policy is |
| 143 // not set. | 143 // not set. |
| 144 model_->RemoveObserver(&observer_); | 144 model_->RemoveObserver(&observer_); |
| 145 prefs_->RemoveManagedPref(bookmarks::prefs::kManagedBookmarks); | 145 prefs_->RemoveManagedPref(bookmarks::prefs::kManagedBookmarks); |
| 146 ResetModel(); | 146 ResetModel(); |
| 147 | 147 |
| 148 ASSERT_TRUE(client_->managed_node()); | 148 ASSERT_TRUE(managed_->managed_node()); |
| 149 EXPECT_TRUE(client_->managed_node()->empty()); | 149 EXPECT_TRUE(managed_->managed_node()->empty()); |
| 150 EXPECT_FALSE(client_->managed_node()->IsVisible()); | 150 EXPECT_FALSE(managed_->managed_node()->IsVisible()); |
| 151 } | 151 } |
| 152 | 152 |
| 153 TEST_F(ChromeBookmarkClientTest, LoadInitial) { | 153 TEST_F(ManagedBookmarkServiceTest, LoadInitial) { |
| 154 // Verifies that the initial load picks up the initial policy too. | 154 // Verifies that the initial load picks up the initial policy too. |
| 155 EXPECT_TRUE(model_->bookmark_bar_node()->empty()); | 155 EXPECT_TRUE(model_->bookmark_bar_node()->empty()); |
| 156 EXPECT_TRUE(model_->other_node()->empty()); | 156 EXPECT_TRUE(model_->other_node()->empty()); |
| 157 EXPECT_FALSE(client_->managed_node()->empty()); | 157 EXPECT_FALSE(managed_->managed_node()->empty()); |
| 158 EXPECT_TRUE(client_->managed_node()->IsVisible()); | 158 EXPECT_TRUE(managed_->managed_node()->IsVisible()); |
| 159 | 159 |
| 160 scoped_ptr<base::DictionaryValue> expected(CreateExpectedTree()); | 160 scoped_ptr<base::DictionaryValue> expected(CreateExpectedTree()); |
| 161 EXPECT_TRUE(NodeMatchesValue(client_->managed_node(), expected.get())); | 161 EXPECT_TRUE(NodeMatchesValue(managed_->managed_node(), expected.get())); |
| 162 } | 162 } |
| 163 | 163 |
| 164 TEST_F(ChromeBookmarkClientTest, SwapNodes) { | 164 TEST_F(ManagedBookmarkServiceTest, SwapNodes) { |
| 165 // Swap the Google bookmark with the Folder. | 165 // Swap the Google bookmark with the Folder. |
| 166 scoped_ptr<base::ListValue> updated(CreateTestTree()); | 166 scoped_ptr<base::ListValue> updated(CreateTestTree()); |
| 167 scoped_ptr<base::Value> removed; | 167 scoped_ptr<base::Value> removed; |
| 168 ASSERT_TRUE(updated->Remove(0, &removed)); | 168 ASSERT_TRUE(updated->Remove(0, &removed)); |
| 169 updated->Append(removed.release()); | 169 updated->Append(removed.release()); |
| 170 | 170 |
| 171 // These two nodes should just be swapped. | 171 // These two nodes should just be swapped. |
| 172 const BookmarkNode* parent = client_->managed_node(); | 172 const BookmarkNode* parent = managed_->managed_node(); |
| 173 EXPECT_CALL(observer_, BookmarkNodeMoved(model_, parent, 1, parent, 0)); | 173 EXPECT_CALL(observer_, BookmarkNodeMoved(model_, parent, 1, parent, 0)); |
| 174 prefs_->SetManagedPref(bookmarks::prefs::kManagedBookmarks, | 174 prefs_->SetManagedPref(bookmarks::prefs::kManagedBookmarks, |
| 175 updated->DeepCopy()); | 175 updated->DeepCopy()); |
| 176 Mock::VerifyAndClearExpectations(&observer_); | 176 Mock::VerifyAndClearExpectations(&observer_); |
| 177 | 177 |
| 178 // Verify the final tree. | 178 // Verify the final tree. |
| 179 scoped_ptr<base::DictionaryValue> expected( | 179 scoped_ptr<base::DictionaryValue> expected( |
| 180 CreateFolder(GetManagedFolderTitle(), updated.release())); | 180 CreateFolder(GetManagedFolderTitle(), updated.release())); |
| 181 EXPECT_TRUE(NodeMatchesValue(client_->managed_node(), expected.get())); | 181 EXPECT_TRUE(NodeMatchesValue(managed_->managed_node(), expected.get())); |
| 182 } | 182 } |
| 183 | 183 |
| 184 TEST_F(ChromeBookmarkClientTest, RemoveNode) { | 184 TEST_F(ManagedBookmarkServiceTest, RemoveNode) { |
| 185 // Remove the Folder. | 185 // Remove the Folder. |
| 186 scoped_ptr<base::ListValue> updated(CreateTestTree()); | 186 scoped_ptr<base::ListValue> updated(CreateTestTree()); |
| 187 ASSERT_TRUE(updated->Remove(1, NULL)); | 187 ASSERT_TRUE(updated->Remove(1, NULL)); |
| 188 | 188 |
| 189 const BookmarkNode* parent = client_->managed_node(); | 189 const BookmarkNode* parent = managed_->managed_node(); |
| 190 EXPECT_CALL(observer_, BookmarkNodeRemoved(model_, parent, 1, _, _)); | 190 EXPECT_CALL(observer_, BookmarkNodeRemoved(model_, parent, 1, _, _)); |
| 191 prefs_->SetManagedPref(bookmarks::prefs::kManagedBookmarks, | 191 prefs_->SetManagedPref(bookmarks::prefs::kManagedBookmarks, |
| 192 updated->DeepCopy()); | 192 updated->DeepCopy()); |
| 193 Mock::VerifyAndClearExpectations(&observer_); | 193 Mock::VerifyAndClearExpectations(&observer_); |
| 194 | 194 |
| 195 // Verify the final tree. | 195 // Verify the final tree. |
| 196 scoped_ptr<base::DictionaryValue> expected( | 196 scoped_ptr<base::DictionaryValue> expected( |
| 197 CreateFolder(GetManagedFolderTitle(), updated.release())); | 197 CreateFolder(GetManagedFolderTitle(), updated.release())); |
| 198 EXPECT_TRUE(NodeMatchesValue(client_->managed_node(), expected.get())); | 198 EXPECT_TRUE(NodeMatchesValue(managed_->managed_node(), expected.get())); |
| 199 } | 199 } |
| 200 | 200 |
| 201 TEST_F(ChromeBookmarkClientTest, CreateNewNodes) { | 201 TEST_F(ManagedBookmarkServiceTest, CreateNewNodes) { |
| 202 // Put all the nodes inside another folder. | 202 // Put all the nodes inside another folder. |
| 203 scoped_ptr<base::ListValue> updated(new base::ListValue); | 203 scoped_ptr<base::ListValue> updated(new base::ListValue); |
| 204 updated->Append(CreateFolder("Container", CreateTestTree())); | 204 updated->Append(CreateFolder("Container", CreateTestTree())); |
| 205 | 205 |
| 206 EXPECT_CALL(observer_, BookmarkNodeAdded(model_, _, _)).Times(5); | 206 EXPECT_CALL(observer_, BookmarkNodeAdded(model_, _, _)).Times(5); |
| 207 // The remaining nodes have been pushed to positions 1 and 2; they'll both be | 207 // The remaining nodes have been pushed to positions 1 and 2; they'll both be |
| 208 // removed when at position 1. | 208 // removed when at position 1. |
| 209 const BookmarkNode* parent = client_->managed_node(); | 209 const BookmarkNode* parent = managed_->managed_node(); |
| 210 EXPECT_CALL(observer_, BookmarkNodeRemoved(model_, parent, 1, _, _)) | 210 EXPECT_CALL(observer_, BookmarkNodeRemoved(model_, parent, 1, _, _)) |
| 211 .Times(2); | 211 .Times(2); |
| 212 prefs_->SetManagedPref(bookmarks::prefs::kManagedBookmarks, | 212 prefs_->SetManagedPref(bookmarks::prefs::kManagedBookmarks, |
| 213 updated->DeepCopy()); | 213 updated->DeepCopy()); |
| 214 Mock::VerifyAndClearExpectations(&observer_); | 214 Mock::VerifyAndClearExpectations(&observer_); |
| 215 | 215 |
| 216 // Verify the final tree. | 216 // Verify the final tree. |
| 217 scoped_ptr<base::DictionaryValue> expected( | 217 scoped_ptr<base::DictionaryValue> expected( |
| 218 CreateFolder(GetManagedFolderTitle(), updated.release())); | 218 CreateFolder(GetManagedFolderTitle(), updated.release())); |
| 219 EXPECT_TRUE(NodeMatchesValue(client_->managed_node(), expected.get())); | 219 EXPECT_TRUE(NodeMatchesValue(managed_->managed_node(), expected.get())); |
| 220 } | 220 } |
| 221 | 221 |
| 222 TEST_F(ChromeBookmarkClientTest, RemoveAllUserBookmarks) { | 222 TEST_F(ManagedBookmarkServiceTest, RemoveAllUserBookmarks) { |
| 223 // Remove the policy. | 223 // Remove the policy. |
| 224 const BookmarkNode* parent = client_->managed_node(); | 224 const BookmarkNode* parent = managed_->managed_node(); |
| 225 EXPECT_CALL(observer_, BookmarkNodeRemoved(model_, parent, 0, _, _)) | 225 EXPECT_CALL(observer_, BookmarkNodeRemoved(model_, parent, 0, _, _)) |
| 226 .Times(2); | 226 .Times(2); |
| 227 prefs_->RemoveManagedPref(bookmarks::prefs::kManagedBookmarks); | 227 prefs_->RemoveManagedPref(bookmarks::prefs::kManagedBookmarks); |
| 228 Mock::VerifyAndClearExpectations(&observer_); | 228 Mock::VerifyAndClearExpectations(&observer_); |
| 229 | 229 |
| 230 EXPECT_TRUE(client_->managed_node()->empty()); | 230 EXPECT_TRUE(managed_->managed_node()->empty()); |
| 231 EXPECT_FALSE(client_->managed_node()->IsVisible()); | 231 EXPECT_FALSE(managed_->managed_node()->IsVisible()); |
| 232 } | 232 } |
| 233 | 233 |
| 234 TEST_F(ChromeBookmarkClientTest, IsDescendantOfManagedNode) { | 234 TEST_F(ManagedBookmarkServiceTest, IsDescendantOfManagedNode) { |
| 235 EXPECT_FALSE(bookmarks::IsDescendantOf(model_->root_node(), | 235 EXPECT_FALSE(bookmarks::IsDescendantOf(model_->root_node(), |
| 236 client_->managed_node())); | 236 managed_->managed_node())); |
| 237 EXPECT_FALSE(bookmarks::IsDescendantOf(model_->bookmark_bar_node(), | 237 EXPECT_FALSE(bookmarks::IsDescendantOf(model_->bookmark_bar_node(), |
| 238 client_->managed_node())); | 238 managed_->managed_node())); |
| 239 EXPECT_FALSE(bookmarks::IsDescendantOf(model_->other_node(), | 239 EXPECT_FALSE(bookmarks::IsDescendantOf(model_->other_node(), |
| 240 client_->managed_node())); | 240 managed_->managed_node())); |
| 241 EXPECT_FALSE(bookmarks::IsDescendantOf(model_->mobile_node(), | 241 EXPECT_FALSE(bookmarks::IsDescendantOf(model_->mobile_node(), |
| 242 client_->managed_node())); | 242 managed_->managed_node())); |
| 243 EXPECT_TRUE(bookmarks::IsDescendantOf(client_->managed_node(), | 243 EXPECT_TRUE(bookmarks::IsDescendantOf(managed_->managed_node(), |
| 244 client_->managed_node())); | 244 managed_->managed_node())); |
| 245 | 245 |
| 246 const BookmarkNode* parent = client_->managed_node(); | 246 const BookmarkNode* parent = managed_->managed_node(); |
| 247 ASSERT_EQ(2, parent->child_count()); | 247 ASSERT_EQ(2, parent->child_count()); |
| 248 EXPECT_TRUE(bookmarks::IsDescendantOf(parent->GetChild(0), | 248 EXPECT_TRUE(bookmarks::IsDescendantOf(parent->GetChild(0), |
| 249 client_->managed_node())); | 249 managed_->managed_node())); |
| 250 EXPECT_TRUE(bookmarks::IsDescendantOf(parent->GetChild(1), | 250 EXPECT_TRUE(bookmarks::IsDescendantOf(parent->GetChild(1), |
| 251 client_->managed_node())); | 251 managed_->managed_node())); |
| 252 | 252 |
| 253 parent = parent->GetChild(1); | 253 parent = parent->GetChild(1); |
| 254 ASSERT_EQ(2, parent->child_count()); | 254 ASSERT_EQ(2, parent->child_count()); |
| 255 EXPECT_TRUE(bookmarks::IsDescendantOf(parent->GetChild(0), | 255 EXPECT_TRUE(bookmarks::IsDescendantOf(parent->GetChild(0), |
| 256 client_->managed_node())); | 256 managed_->managed_node())); |
| 257 EXPECT_TRUE(bookmarks::IsDescendantOf(parent->GetChild(1), | 257 EXPECT_TRUE(bookmarks::IsDescendantOf(parent->GetChild(1), |
| 258 client_->managed_node())); | 258 managed_->managed_node())); |
| 259 } | 259 } |
| 260 | 260 |
| 261 TEST_F(ChromeBookmarkClientTest, RemoveAllDoesntRemoveManaged) { | 261 TEST_F(ManagedBookmarkServiceTest, RemoveAllDoesntRemoveManaged) { |
| 262 EXPECT_EQ(2, client_->managed_node()->child_count()); | 262 EXPECT_EQ(2, managed_->managed_node()->child_count()); |
| 263 | 263 |
| 264 EXPECT_CALL(observer_, | 264 EXPECT_CALL(observer_, |
| 265 BookmarkNodeAdded(model_, model_->bookmark_bar_node(), 0)); | 265 BookmarkNodeAdded(model_, model_->bookmark_bar_node(), 0)); |
| 266 EXPECT_CALL(observer_, | 266 EXPECT_CALL(observer_, |
| 267 BookmarkNodeAdded(model_, model_->bookmark_bar_node(), 1)); | 267 BookmarkNodeAdded(model_, model_->bookmark_bar_node(), 1)); |
| 268 model_->AddURL(model_->bookmark_bar_node(), | 268 model_->AddURL(model_->bookmark_bar_node(), |
| 269 0, | 269 0, |
| 270 base::ASCIIToUTF16("Test"), | 270 base::ASCIIToUTF16("Test"), |
| 271 GURL("http://google.com/")); | 271 GURL("http://google.com/")); |
| 272 model_->AddFolder( | 272 model_->AddFolder( |
| 273 model_->bookmark_bar_node(), 1, base::ASCIIToUTF16("Test Folder")); | 273 model_->bookmark_bar_node(), 1, base::ASCIIToUTF16("Test Folder")); |
| 274 EXPECT_EQ(2, model_->bookmark_bar_node()->child_count()); | 274 EXPECT_EQ(2, model_->bookmark_bar_node()->child_count()); |
| 275 Mock::VerifyAndClearExpectations(&observer_); | 275 Mock::VerifyAndClearExpectations(&observer_); |
| 276 | 276 |
| 277 EXPECT_CALL(observer_, BookmarkAllUserNodesRemoved(model_, _)); | 277 EXPECT_CALL(observer_, BookmarkAllUserNodesRemoved(model_, _)); |
| 278 model_->RemoveAllUserBookmarks(); | 278 model_->RemoveAllUserBookmarks(); |
| 279 EXPECT_EQ(2, client_->managed_node()->child_count()); | 279 EXPECT_EQ(2, managed_->managed_node()->child_count()); |
| 280 EXPECT_EQ(0, model_->bookmark_bar_node()->child_count()); | 280 EXPECT_EQ(0, model_->bookmark_bar_node()->child_count()); |
| 281 Mock::VerifyAndClearExpectations(&observer_); | 281 Mock::VerifyAndClearExpectations(&observer_); |
| 282 } | 282 } |
| 283 | 283 |
| 284 TEST_F(ChromeBookmarkClientTest, HasDescendantsOfManagedNode) { | 284 TEST_F(ManagedBookmarkServiceTest, HasDescendantsOfManagedNode) { |
| 285 const BookmarkNode* user_node = model_->AddURL(model_->other_node(), | 285 const BookmarkNode* user_node = model_->AddURL(model_->other_node(), |
| 286 0, | 286 0, |
| 287 base::ASCIIToUTF16("foo bar"), | 287 base::ASCIIToUTF16("foo bar"), |
| 288 GURL("http://www.google.com")); | 288 GURL("http://www.google.com")); |
| 289 const BookmarkNode* managed_node = client_->managed_node()->GetChild(0); | 289 const BookmarkNode* managed_node = managed_->managed_node()->GetChild(0); |
| 290 ASSERT_TRUE(managed_node); | 290 ASSERT_TRUE(managed_node); |
| 291 | 291 |
| 292 std::vector<const BookmarkNode*> nodes; | 292 std::vector<const BookmarkNode*> nodes; |
| 293 EXPECT_FALSE(bookmarks::HasDescendantsOf(nodes, client_->managed_node())); | 293 EXPECT_FALSE(bookmarks::HasDescendantsOf(nodes, managed_->managed_node())); |
| 294 nodes.push_back(user_node); | 294 nodes.push_back(user_node); |
| 295 EXPECT_FALSE(bookmarks::HasDescendantsOf(nodes, client_->managed_node())); | 295 EXPECT_FALSE(bookmarks::HasDescendantsOf(nodes, managed_->managed_node())); |
| 296 nodes.push_back(managed_node); | 296 nodes.push_back(managed_node); |
| 297 EXPECT_TRUE(bookmarks::HasDescendantsOf(nodes, client_->managed_node())); | 297 EXPECT_TRUE(bookmarks::HasDescendantsOf(nodes, managed_->managed_node())); |
| 298 } | 298 } |
| OLD | NEW |