toolkit/components/places/tests/unit/test_399264_string_to_query.js

changeset 0
6474c204b198
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/toolkit/components/places/tests/unit/test_399264_string_to_query.js	Wed Dec 31 06:09:35 2014 +0100
     1.3 @@ -0,0 +1,77 @@
     1.4 +/* -*- Mode: Java; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
     1.5 +/* vim:set ts=2 sw=2 sts=2 et: */
     1.6 +/* This Source Code Form is subject to the terms of the Mozilla Public
     1.7 + * License, v. 2.0. If a copy of the MPL was not distributed with this
     1.8 + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
     1.9 +
    1.10 +/**
    1.11 + * Obtains the id of the folder obtained from the query.
    1.12 + *
    1.13 + * @param aQuery
    1.14 + *        The query to obtain the folder id from.
    1.15 + * @returns the folder id of the folder of the root node of the query.
    1.16 + */
    1.17 +function folder_id(aQuery)
    1.18 +{
    1.19 +  var hs = Cc["@mozilla.org/browser/nav-history-service;1"].
    1.20 +           getService(Ci.nsINavHistoryService);
    1.21 +
    1.22 +  dump("Checking query '" + aQuery + "'\n");
    1.23 +  var options = { };
    1.24 +  var queries = { };
    1.25 +  var size = { };
    1.26 +  hs.queryStringToQueries(aQuery, queries, size, options);
    1.27 +  var result = hs.executeQueries(queries.value, size.value, options.value);
    1.28 +  var root = result.root;
    1.29 +  root.containerOpen = true;
    1.30 +  do_check_true(root.hasChildren);
    1.31 +  var folderID = root.getChild(0).parent.itemId;
    1.32 +  root.containerOpen = false;
    1.33 +  return folderID;
    1.34 +}
    1.35 +
    1.36 +function run_test()
    1.37 +{
    1.38 +  var hs = Cc["@mozilla.org/browser/nav-history-service;1"].
    1.39 +           getService(Ci.nsINavHistoryService);
    1.40 +  var bs = Cc["@mozilla.org/browser/nav-bookmarks-service;1"].
    1.41 +           getService(Ci.nsINavBookmarksService);
    1.42 +
    1.43 +  const QUERIES = [
    1.44 +      "place:folder=PLACES_ROOT"
    1.45 +    , "place:folder=BOOKMARKS_MENU"
    1.46 +    , "place:folder=TAGS"
    1.47 +    , "place:folder=UNFILED_BOOKMARKS"
    1.48 +    , "place:folder=TOOLBAR"
    1.49 +  ];
    1.50 +  const FOLDER_IDS = [
    1.51 +      bs.placesRoot
    1.52 +    , bs.bookmarksMenuFolder
    1.53 +    , bs.tagsFolder
    1.54 +    , bs.unfiledBookmarksFolder
    1.55 +    , bs.toolbarFolder
    1.56 +  ];
    1.57 +
    1.58 +  // add something in the bookmarks menu folder so a query to it returns results
    1.59 +  bs.insertBookmark(bs.bookmarksMenuFolder, uri("http://example.com/bmf/"),
    1.60 +                    Ci.nsINavBookmarksService.DEFAULT_INDEX, "bmf");
    1.61 +
    1.62 +  // add something to the tags folder
    1.63 +  var ts = Cc["@mozilla.org/browser/tagging-service;1"].
    1.64 +           getService(Ci.nsITaggingService);
    1.65 +  ts.tagURI(uri("http://www.example.com/"), ["tag"]);
    1.66 +
    1.67 +  // add something to the unfiled bookmarks folder
    1.68 +  bs.insertBookmark(bs.unfiledBookmarksFolder, uri("http://example.com/ubf/"),
    1.69 +                    Ci.nsINavBookmarksService.DEFAULT_INDEX, "ubf");
    1.70 +
    1.71 +  // add something to the toolbar folder
    1.72 +  bs.insertBookmark(bs.toolbarFolder, uri("http://example.com/tf/"),
    1.73 +                    Ci.nsINavBookmarksService.DEFAULT_INDEX, "tf");
    1.74 +
    1.75 +  for (var i = 0; i < QUERIES.length; i++) {
    1.76 +    var result = folder_id(QUERIES[i]);
    1.77 +    dump("expected " + FOLDER_IDS[i] + ", got " + result + "\n");
    1.78 +    do_check_eq(FOLDER_IDS[i], result);
    1.79 +  }
    1.80 +}

mercurial