// Copyright 2014 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 "base/base64.h" #include "base/strings/utf_string_conversions.h" #include "components/bookmarks/browser/bookmark_model.h" #include "components/bookmarks/test/test_bookmark_client.h" #include "components/enhanced_bookmarks/enhanced_bookmark_utils.h" #include "testing/gtest/include/gtest/gtest.h" using bookmarks::TestBookmarkClient; namespace { const GURL bookmark_url("http://example.com/index.html"); class EnhancedBookmarkUtilsTest : public testing::Test { public: EnhancedBookmarkUtilsTest() {} virtual ~EnhancedBookmarkUtilsTest() {} protected: DISALLOW_COPY_AND_ASSIGN(EnhancedBookmarkUtilsTest); // Adds a bookmark as the subnode at index 0 to other_node. // |name| should be ASCII encoded. // Returns the newly added bookmark. const BookmarkNode* AddBookmark(BookmarkModel* model, std::string name) { return model->AddURL(model->other_node(), 0, // index. base::ASCIIToUTF16(name), bookmark_url); } }; TEST_F(EnhancedBookmarkUtilsTest, TestBookmarkSearch) { TestBookmarkClient bookmark_client; scoped_ptr bookmark_model(bookmark_client.CreateModel()); const BookmarkNode* node1 = AddBookmark(bookmark_model.get(), "john hopkins"); const BookmarkNode* node2 = AddBookmark(bookmark_model.get(), "JohN hopkins"); const BookmarkNode* node3 = AddBookmark(bookmark_model.get(), "katy perry"); const BookmarkNode* node4 = AddBookmark(bookmark_model.get(), "lil'john13"); const BookmarkNode* node5 = AddBookmark(bookmark_model.get(), "jo hn"); std::vector result = enhanced_bookmarks::FindBookmarksWithQuery(bookmark_model.get(), "john"); ASSERT_EQ(result.size(), 3u); CHECK(std::find(result.begin(), result.end(), node1) != result.end()); CHECK(std::find(result.begin(), result.end(), node2) != result.end()); CHECK(std::find(result.begin(), result.end(), node4) != result.end()); CHECK(std::find(result.begin(), result.end(), node3) == result.end()); CHECK(std::find(result.begin(), result.end(), node5) == result.end()); }; } // namespace