| Index: chrome/android/javatests/src/org/chromium/chrome/browser/BookmarksBridgeTest.java
|
| diff --git a/chrome/android/javatests/src/org/chromium/chrome/browser/BookmarksBridgeTest.java b/chrome/android/javatests/src/org/chromium/chrome/browser/BookmarksBridgeTest.java
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..43392e5f19311d5e80781275d372c638a57b905d
|
| --- /dev/null
|
| +++ b/chrome/android/javatests/src/org/chromium/chrome/browser/BookmarksBridgeTest.java
|
| @@ -0,0 +1,137 @@
|
| +// 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.
|
| +
|
| +package org.chromium.chrome.browser;
|
| +
|
| +import android.test.UiThreadTest;
|
| +import android.test.suitebuilder.annotation.SmallTest;
|
| +
|
| +import org.chromium.base.ThreadUtils;
|
| +import org.chromium.base.test.util.Feature;
|
| +import org.chromium.chrome.browser.BookmarksBridge.BookmarkItem;
|
| +import org.chromium.chrome.browser.profiles.Profile;
|
| +import org.chromium.chrome.shell.ChromeShellActivity;
|
| +import org.chromium.chrome.shell.ChromeShellTab;
|
| +import org.chromium.chrome.shell.ChromeShellTestBase;
|
| +import org.chromium.components.bookmarks.BookmarkId;
|
| +
|
| +import java.util.ArrayList;
|
| +import java.util.HashMap;
|
| +import java.util.List;
|
| +
|
| +/**
|
| + * Tests for bookmark bridge
|
| + */
|
| +public class BookmarksBridgeTest extends ChromeShellTestBase {
|
| +
|
| + private ChromeShellActivity mActivity;
|
| + private Profile mProfile;
|
| + private BookmarksBridge mBookmarksBridge;
|
| + private BookmarkId mMobileNode;
|
| + private BookmarkId mOtherNode;
|
| + private BookmarkId mDesktopNode;
|
| +
|
| + @Override
|
| + protected void setUp() throws Exception {
|
| + super.setUp();
|
| + mActivity = launchChromeShellWithBlankPage();
|
| + assertTrue(waitForActiveShellToBeDoneLoading());
|
| + ThreadUtils.runOnUiThreadBlocking(new Runnable() {
|
| + @Override
|
| + public void run() {
|
| + ChromeShellTab tab = mActivity.getActiveTab();
|
| + mProfile = tab.getProfile();
|
| + mBookmarksBridge = new BookmarksBridge(mProfile);
|
| + mBookmarksBridge.loadEmptyPartnerBookmarkShimForTesting();
|
| + mMobileNode = mBookmarksBridge.getMobileFolderId();
|
| + mDesktopNode = mBookmarksBridge.getDesktopFolderId();
|
| + mOtherNode = mBookmarksBridge.getOtherFolderId();
|
| + }
|
| + });
|
| + }
|
| +
|
| + @UiThreadTest
|
| + @SmallTest
|
| + @Feature({"Bookmark"})
|
| + public void testAddBookmarksAndFolders() {
|
| + BookmarkId bookmarkA = mBookmarksBridge.addBookmark(mDesktopNode, 0, "a", "http://a.com");
|
| + verifyBookmark(bookmarkA, "a", "http://a.com/", false, mDesktopNode);
|
| + BookmarkId bookmarkB = mBookmarksBridge.addBookmark(mOtherNode, 0, "b", "http://b.com");
|
| + verifyBookmark(bookmarkB, "b", "http://b.com/", false, mOtherNode);
|
| + BookmarkId bookmarkC = mBookmarksBridge.addBookmark(mMobileNode, 0, "c", "http://c.com");
|
| + verifyBookmark(bookmarkC, "c", "http://c.com/", false, mMobileNode);
|
| + BookmarkId folderA = mBookmarksBridge.addFolder(mOtherNode, 0, "fa");
|
| + verifyBookmark(folderA, "fa", null, true, mOtherNode);
|
| + BookmarkId folderB = mBookmarksBridge.addFolder(mDesktopNode, 0, "fb");
|
| + verifyBookmark(folderB, "fb", null, true, mDesktopNode);
|
| + BookmarkId folderC = mBookmarksBridge.addFolder(mMobileNode, 0, "fc");
|
| + verifyBookmark(folderC, "fc", null, true, mMobileNode);
|
| + BookmarkId bookmarkAA = mBookmarksBridge.addBookmark(folderA, 0, "aa", "http://aa.com");
|
| + verifyBookmark(bookmarkAA, "aa", "http://aa.com/", false, folderA);
|
| + BookmarkId folderAA = mBookmarksBridge.addFolder(folderA, 0, "faa");
|
| + verifyBookmark(folderAA, "faa", null, true, folderA);
|
| + }
|
| +
|
| + private void verifyBookmark(BookmarkId idToVerify, String expectedTitle,
|
| + String expectedUrl, boolean isFolder, BookmarkId expectedParent) {
|
| + assertNotNull(idToVerify);
|
| + BookmarkItem item = mBookmarksBridge.getBookmarkById(idToVerify);
|
| + assertEquals(expectedTitle, item.getTitle());
|
| + assertEquals(item.isFolder(), isFolder);
|
| + if (!isFolder) assertEquals(expectedUrl, item.getUrl());
|
| + assertEquals(item.getParentId(), expectedParent);
|
| + }
|
| +
|
| + @UiThreadTest
|
| + @SmallTest
|
| + @Feature({"Bookmark"})
|
| + public void testGetAllFoldersWithDepths() {
|
| + BookmarkId folderA = mBookmarksBridge.addFolder(mMobileNode, 0, "a");
|
| + BookmarkId folderB = mBookmarksBridge.addFolder(mDesktopNode, 0, "b");
|
| + BookmarkId folderC = mBookmarksBridge.addFolder(mOtherNode, 0, "c");
|
| + BookmarkId folderAA = mBookmarksBridge.addFolder(folderA, 0, "aa");
|
| + BookmarkId folderBA = mBookmarksBridge.addFolder(folderB, 0, "ba");
|
| + BookmarkId folderAAA = mBookmarksBridge.addFolder(folderAA, 0, "aaa");
|
| + BookmarkId folderAAAA = mBookmarksBridge.addFolder(folderAAA, 0, "aaaa");
|
| +
|
| + mBookmarksBridge.addBookmark(mMobileNode, 0, "ua", "http://www.google.com");
|
| + mBookmarksBridge.addBookmark(mDesktopNode, 0, "ua", "http://www.google.com");
|
| + mBookmarksBridge.addBookmark(mOtherNode, 0, "ua", "http://www.google.com");
|
| + mBookmarksBridge.addBookmark(folderA, 0, "ua", "http://www.medium.com");
|
| +
|
| + // Map folders to depths as expected results
|
| + HashMap<BookmarkId, Integer> idToDepth = new HashMap<BookmarkId, Integer>();
|
| + idToDepth.put(folderA, 0);
|
| + idToDepth.put(folderAA, 1);
|
| + idToDepth.put(folderAAA, 2);
|
| + idToDepth.put(folderAAAA, 3);
|
| + idToDepth.put(mDesktopNode, 0);
|
| + idToDepth.put(folderB, 1);
|
| + idToDepth.put(folderBA, 2);
|
| + idToDepth.put(folderC, 0);
|
| +
|
| + List<BookmarkId> folderList = new ArrayList<BookmarkId>();
|
| + List<Integer> depthList = new ArrayList<Integer>();
|
| + mBookmarksBridge.getAllFoldersWithDepths(folderList, depthList);
|
| +
|
| + assertEquals("Returned folder list has different size (" + folderList.size()
|
| + + ") from depth list (" + depthList.size() + ").",
|
| + folderList.size(), depthList.size());
|
| + assertEquals("Returned lists have different sizes (" + folderList.size()
|
| + + ") from expected size (" + idToDepth.size() + ").",
|
| + folderList.size(), idToDepth.size());
|
| +
|
| + for (int i = 0; i < folderList.size(); i++) {
|
| + assertNotNull(folderList.get(i));
|
| + assertNotNull(depthList.get(i));
|
| + assertTrue("Returned list contained unexpected key: " + folderList.get(i),
|
| + idToDepth.containsKey(folderList.get(i)));
|
| + assertEquals(depthList.get(i), idToDepth.get(folderList.get(i)));
|
| + idToDepth.remove(folderList.get(i));
|
| + }
|
| +
|
| + assertEquals("Expected list contains elements that are not in returned list",
|
| + idToDepth.size(), 0);
|
| + }
|
| +}
|
|
|