Bug 863347 - Remove about:home from default bookmarks. r=wesj
authorMichael Comella <michael.l.comella@gmail.com>
Fri, 12 Jul 2013 10:51:41 -0700
changeset 143406 3c46c005d67683c7fd3ea3c089b326e8d00d8afa
parent 143405 c5d17b84a826acca8f11c51a0cc0930095615a16
child 143407 cc50c0290cf44bd8c7389387c2e0ed3bc38ecd51
push id25130
push userlrocha@mozilla.com
push dateWed, 21 Aug 2013 09:41:27 +0000
treeherdermozilla-central@b2486721572e [default view] [failures only]
perfherder[talos] [build metrics] [platform microbench] (compared to previous push)
reviewerswesj
bugs863347
milestone25.0a1
first release with
nightly linux32
nightly linux64
nightly mac
nightly win32
nightly win64
last release without
nightly linux32
nightly linux64
nightly mac
nightly win32
nightly win64
Bug 863347 - Remove about:home from default bookmarks. r=wesj * * * TEMP. Try getAllPagesList(..., -1);
mobile/android/base/strings.xml.in
mobile/android/base/tests/BaseTest.java.in
mobile/android/base/tests/testAllPagesTab.java.in
mobile/android/base/tests/testBookmark.java.in
mobile/android/base/tests/testBookmarksTab.java.in
mobile/locales/en-US/profile/bookmarks.inc
mobile/locales/generic/profile/bookmarks.json.in
--- a/mobile/android/base/strings.xml.in
+++ b/mobile/android/base/strings.xml.in
@@ -264,19 +264,16 @@
 
   <string name="bookmarkdefaults_title_addons">@bookmarks_addons@</string>
   <string name="bookmarkdefaults_url_addons">https://addons.mozilla.org/@AB_CD@/android/</string>
 
   <string name="bookmarkdefaults_title_support">@bookmarks_support@</string>
   <string name="bookmarkdefaults_url_support">http://support.mozilla.org/@AB_CD@/products/mobile</string>
   <string name="bookmarkdefaults_favicon_abouthome">chrome/chrome/content/branding/favicon64.png</string>
 
-  <string name="bookmarkdefaults_title_abouthome">@bookmarks_aboutHome@</string>
-  <string name="bookmarkdefaults_url_abouthome">about:home</string>
-
   <!-- Site identity popup -->
   <string name="identity_connected_to">&identity_connected_to;</string>
   <string name="identity_run_by">&identity_run_by;</string>
   <string name="loaded_mixed_content_message">&loaded_mixed_content_message;</string>
   <string name="blocked_mixed_content_message_top">&blocked_mixed_content_message_top;</string>
   <string name="blocked_mixed_content_message_bottom">&blocked_mixed_content_message_bottom;</string>
   <string name="learn_more">&learn_more;</string>
   <string name="enable_protection">&enable_protection;</string>
--- a/mobile/android/base/tests/BaseTest.java.in
+++ b/mobile/android/base/tests/BaseTest.java.in
@@ -40,16 +40,29 @@ abstract class BaseTest extends Activity
 
     private static final String TARGET_PACKAGE_ID = "org.mozilla.gecko";
     private static final String LAUNCH_ACTIVITY_FULL_CLASSNAME="@ANDROID_PACKAGE_NAME@.App";
     private static final int VERIFY_URL_TIMEOUT = 2000;
     private static final int MAX_LIST_ATTEMPTS = 3;
     private static final int MAX_WAIT_ENABLED_TEXT_MS = 10000;
     public static final int MAX_WAIT_MS = 3000;
 
+    // Note: DEFAULT_BOOKMARKS_TITLES.length == DEFAULT_BOOKMARKS_URLS.length
+    protected static final String[] DEFAULT_BOOKMARKS_TITLES = new String[] {
+        "Firefox: About your browser",
+        "Firefox: Support",
+        "Firefox: Customize with add-ons"
+    };
+    protected static final String[] DEFAULT_BOOKMARKS_URLS = new String[] {
+        "about:firefox",
+        "http://support.mozilla.org/en-US/products/mobile",
+        "https://addons.mozilla.org/en-US/android/"
+    };
+    protected static final int DEFAULT_BOOKMARKS_COUNT = DEFAULT_BOOKMARKS_TITLES.length;
+
     private static Class<Activity> mLauncherActivityClass;
     private Activity mActivity;
     protected Solo mSolo;
     protected Driver mDriver;
     protected Assert mAsserter;
     protected Actions mActions;
     protected String mBaseUrl;
     protected String mRawBaseUrl;
--- a/mobile/android/base/tests/testAllPagesTab.java.in
+++ b/mobile/android/base/tests/testAllPagesTab.java.in
@@ -19,54 +19,51 @@ import @ANDROID_PACKAGE_NAME@.*;
 /* Tests opening the all pages tab, that items look correct, clicking on an item
    and long tapping on an item
 */
 
 public class testAllPagesTab extends BaseTest {
     private static final String ABOUT_HOME_URL = "about:home";
     private static ListView listview = null;
 
-    private String[] mBookmarks = new String[] {
-        "Firefox: About your browser",
-        "Firefox Start",
-        "Firefox: Support",
-        "Firefox: Customize with add-ons"
-    };
+    private static int topSitesCount = DEFAULT_BOOKMARKS_COUNT;
 
     @Override
     protected int getTestType() {
         return TEST_MOCHITEST;
     }
 
     public void testAllPagesTab() {
         blockForGeckoReady();
 
         // load one page so there is something in our history
         String url = getAbsoluteUrl("/robocop/robocop_big_link.html");
         loadUrl(url);
+        topSitesCount += 1; // Increment for "Big Link" Top Site since the URL was loaded above.
 
         testList(url);
-        testClick("about:firefox");
+        testClick(DEFAULT_BOOKMARKS_URLS[0]);
         testContextMenu(url);
     }
 
     private void testList(String url) {
-        final ListView list = getAllPagesList(mBookmarks[0], 5);
+        final ListView list = getAllPagesList(DEFAULT_BOOKMARKS_TITLES[0], topSitesCount);
 
         // some basic checks for the tab strip
         TabWidget tabwidget = (TabWidget)mSolo.getView(TabWidget.class, 0);
         mAsserter.is(tabwidget.getTabCount(), 3, "Three tabs shown");
         mAsserter.is(tabwidget.isStripEnabled(), false, "Strip is hidden");
 
         // check that the right tab is selected
         TabHost host = (TabHost)mSolo.getView(TabHost.class, 0);
         // This test fails, only when we're running tests
         // mAsserter.is(host.getCurrentTab(), 0, "All pages tab is selected in tab strip");
 
-        mAsserter.isnot(list, null, "checking that all pages list exists and has 5 children (the default bookmarks)");
+        mAsserter.isnot(list, null, "checking that all pages list exists and has " +
+                topSitesCount + " children (the default bookmarks)");
         final int count = list.getAdapter().getCount();
 
         String loadUrl = "";
         for (int i = count - 1; i >= 0; i--) {
             View child = list.getChildAt(i);
             if (child == null) {
                 // this may simply indicate that the item is not visible
                 Object item = list.getAdapter().getItem(i);
@@ -82,17 +79,17 @@ public class testAllPagesTab extends Bas
                 if (v instanceof TextView) {
                     TextView t = (TextView)v;
                     String string = t.getText().toString();
                     mAsserter.ok(!TextUtils.isEmpty(string), "TextView is filled in", string);
                     if (i == 1 || string.startsWith("http")) {
                         loadUrl = string;
                     }
 
-                    if (isBookmark(mBookmarks, string)) {
+                    if (isBookmark(DEFAULT_BOOKMARKS_TITLES, string)) {
                         expectedImages = 2;
                     }
                 } else if (v instanceof ImageView) {
                     imageViews.add((ImageView)v);
                 }
             }
 
             int visible = 0;
@@ -103,34 +100,34 @@ public class testAllPagesTab extends Bas
 
             mAsserter.is(visible, expectedImages, "Correct number of ImageViews visible");
         }
 
         mActions.sendSpecialKey(Actions.SpecialKey.BACK);
     }
 
     private void testContextMenu(String url) {
-        ListView list = getAllPagesList(mBookmarks[0], 5);
+        ListView list = getAllPagesList(DEFAULT_BOOKMARKS_TITLES[0], topSitesCount);
 
         View child = list.getChildAt(0);
         mAsserter.ok(child != null, "first list item can be retrieved", child != null ? child.toString() : "null!");
         mSolo.clickLongOnView(child);
 
         // TODO: Test clicking these does the right thing
         mAsserter.ok(mSolo.waitForText("Open in New Tab"), "Context menu has Open in New Tab option", "Open in New Tab");
         mAsserter.ok(mSolo.waitForText("Share"), "Context menu has Share option", "Share");
         mAsserter.ok(mSolo.searchText("Remove", true), "Context menu has Remove option", "Remove");
         mAsserter.ok(mSolo.searchText("Add to Home Screen", true), "Context menu has Add to Home Screen option", "Add to Home Screen");
 
         mActions.sendSpecialKey(Actions.SpecialKey.BACK);
         mActions.sendSpecialKey(Actions.SpecialKey.BACK);
     }
 
     private void testClick(String url) {
-        ListView list = getAllPagesList(mBookmarks[0], 5);
+        ListView list = getAllPagesList(DEFAULT_BOOKMARKS_TITLES[0], topSitesCount);
 
         Actions.EventExpecter contentEventExpecter = mActions.expectGeckoEvent("DOMContentLoaded");
 
         // Avoid clicking the first item. Its the first item because its in an open tab, and will just switch to it
         View child = list.getChildAt(1);
         mAsserter.ok(child != null, "first list item can be retrieved", child != null ? child.toString() : "null!");
         // dump text for this child, to be sure of which list item is clicked
         ArrayList<View> views = mSolo.getViews(child);
--- a/mobile/android/base/tests/testBookmark.java.in
+++ b/mobile/android/base/tests/testBookmark.java.in
@@ -12,22 +12,16 @@ import android.content.ContentResolver;
 public class testBookmark extends PixelTest  {
     private static final String ABOUT_HOME_URL = "about:firefox";
     private static String BOOKMARK_URL = "/robocop/robocop_blank_01.html";
     private static String BOOKMARK_TITLE = "Browser Blank Page 01";
     private ClassLoader mClassLoader;
     private Method mAddBookmark;
     private Method mRemoveBookmark;
     private Method mIsBookmarked;
-    private String[] defaultBookmarks = new String[] {
-        "about:firefox",
-        "about:home",
-        "http://support.mozilla.org/en-US/products/mobile",
-        "https://addons.mozilla.org/en-US/android/"
-    };
 
     @Override
     protected int getTestType() {
         return TEST_MOCHITEST;
     }
 
     public void testBookmark() {
         BOOKMARK_URL = getAbsoluteUrl(BOOKMARK_URL);
@@ -65,35 +59,37 @@ public class testBookmark extends PixelT
     }
 
     public void runAwesomeScreenTest() {
         final long PAINT_CLEAR_DELAY = 1000;  // milliseconds
 
         blockForGeckoReady();
 
         // Open the bookmark list and check the root folder view
-        ListView bookmarksList = getBookmarksList(ABOUT_HOME_URL, 4);
+        ListView bookmarksList = getBookmarksList(ABOUT_HOME_URL, DEFAULT_BOOKMARKS_COUNT);
 
-        mAsserter.ok(bookmarksList != null, "checking that bookmarks list exists", "bookmarks list exists and has 4 children (the default bookmarks)");
+        mAsserter.ok(bookmarksList != null, "checking that bookmarks list exists", "bookmarks list exists and has " +
+                DEFAULT_BOOKMARKS_COUNT + " children (the default bookmarks)");
 
         // No folders should be visible if no desktop bookmarks exist
         int count = bookmarksList.getAdapter().getCount();
         for (int i = 0; i < count; i++) {
             Cursor c = (Cursor)bookmarksList.getItemAtPosition(i);
             String url = c.getString(c.getColumnIndexOrThrow("url"));
-            mAsserter.ok(Arrays.binarySearch(defaultBookmarks, url) > -1,
+            mAsserter.ok(Arrays.binarySearch(DEFAULT_BOOKMARKS_URLS, url) > -1,
                          "Find default bookmark", "Default bookmark for " + url + " found");
         }
 
         insertOneBookmark();
         waitForText(BOOKMARK_TITLE);
 
-        mAsserter.is(bookmarksList.getAdapter().getCount(), 5,
-            "bookmarks list has 5 children (the default bookmarks and the new one)");
- 
+        final int bookmarksCount = DEFAULT_BOOKMARKS_COUNT + 1;
+        mAsserter.is(bookmarksList.getAdapter().getCount(), bookmarksCount, "bookmarks list has " +
+                bookmarksCount + " children (the default bookmarks and the new one)");
+
         // Click on the bookmark we created and wait for the bookmarked page to load
         Actions.RepeatedEventExpecter paintExpecter = mActions.expectPaint();
         View child = bookmarksList.getChildAt(1);
         mAsserter.ok(child != null, "list item can be retrieved", child != null ? child.toString() : "null!");
         mSolo.clickOnView(child);
         paintExpecter.blockUntilClear(PAINT_CLEAR_DELAY);
         paintExpecter.unregisterListener();
 
--- a/mobile/android/base/tests/testBookmarksTab.java.in
+++ b/mobile/android/base/tests/testBookmarksTab.java.in
@@ -37,18 +37,20 @@ public class testBookmarksTab extends Ba
         addOrUpdateBookmark("BOOKMARK_TITLE", url, false);
 
         testList(url);
         testContextMenu(url);
     }
 
     private void testList(String url) {
         View child;
-        ListView list = getBookmarksList("about:firefox", 5);
-        mAsserter.isnot(list, null, "checking that bookmarks list exists and has 5 children (defaults + a folder)");
+        final int bookmarksCount = DEFAULT_BOOKMARKS_COUNT + 1;
+        ListView list = getBookmarksList(DEFAULT_BOOKMARKS_URLS[0], bookmarksCount);
+        mAsserter.isnot(list, null, "checking that bookmarks list exists and has " +
+                bookmarksCount + " children (defaults + a folder)");
 
         int count = list.getAdapter().getCount();
         for (int i = count - 1; i >= 0; i--) {
             child = list.getChildAt(i);
             compareRow(child, i == 0 ? 1 : 2, 1);
         }
 
         child = list.getChildAt(0);
--- a/mobile/locales/en-US/profile/bookmarks.inc
+++ b/mobile/locales/en-US/profile/bookmarks.inc
@@ -21,13 +21,9 @@
 # LOCALIZATION NOTE (bookmarks_addons):
 # link title for https://addons.mozilla.org/en-US/mobile
 #define bookmarks_addons Firefox: Customize with add-ons
 
 # LOCALIZATION NOTE (bookmarks_support):
 # link title for https://support.mozilla.org/mobile
 #define bookmarks_support Firefox: Support
 
-# LOCALIZATION NOTE (bookmarks_aboutHome):
-# link title for about:home
-#define bookmarks_aboutHome Firefox Start
-
 #unfilter emptyLines
--- a/mobile/locales/generic/profile/bookmarks.json.in
+++ b/mobile/locales/generic/profile/bookmarks.json.in
@@ -6,15 +6,12 @@
        {"index":1,"title":"@bookmarks_aboutBrowser@", "type":"text/x-moz-place", "uri":"about:firefox",
         "iconUri":"chrome://branding/content/favicon32.png"
        },
        {"index":2,"title":"@bookmarks_addons@",   "type":"text/x-moz-place", "uri":"https://addons.mozilla.org/@AB_CD@/mobile/",
         "icon":""
        },
        {"index":3,"title":"@bookmarks_support@",  "type":"text/x-moz-place", "uri":"http://support.mozilla.org/@AB_CD@/mobile",
         "icon":""
-       },
-       {"index":4,"title":"@bookmarks_aboutHome@", "type":"text/x-moz-place", "uri":"about:home",
-        "iconUri":"chrome://branding/content/favicon32.png"
        }
      ]
   }]
 }