Source code

Revision control

Copy as Markdown

Other Tools

Test Info:

<?xml version="1.0"?>
<!--
Any copyright is dedicated to the Public Domain.
-->
<?xml-stylesheet href="chrome://global/skin" type="text/css"?>
type="text/css"?>
<?xml-stylesheet href="chrome://browser/content/places/places.css"?>
<?xml-stylesheet href="chrome://browser/skin/places/tree-icons.css"?>
title="1163447: selectItems in Places no longer selects items within Toolbar or Sidebar folders"
onload="runTest();">
<script type="application/javascript"
src="chrome://browser/content/places/places-tree.js"/>
<script type="application/javascript" src="head.js" />
<body xmlns="http://www.w3.org/1999/xhtml" />
<tree id="tree"
is="places-tree"
flex="1">
<treecols>
<treecol label="Title" id="title" anonid="title" primary="true" style="order: 1;" flex="1"/>
</treecols>
<treechildren flex="1"/>
</tree>
<script type="application/javascript"><![CDATA[
/**
* Bug 1163447: places-tree should be able to select an item within the toolbar, and
* unfiled bookmarks. Yet not follow recursive folder-shortcuts infinitely.
*/
function runTest() {
SimpleTest.waitForExplicitFinish();
(async function() {
let bmu = PlacesUtils.bookmarks;
await bmu.insert({
parentGuid: bmu.toolbarGuid,
index: bmu.DEFAULT_INDEX,
type: bmu.TYPE_BOOKMARK,
url: `place:parent=${PlacesUtils.bookmarks.toolbarGuid}`,
title: "shortcut to self - causing infinite recursion if not handled properly"
});
await bmu.insert({
parentGuid: bmu.toolbarGuid,
index: bmu.DEFAULT_INDEX,
type: bmu.TYPE_BOOKMARK,
url: `place:parent=${PlacesUtils.bookmarks.unfiledGuid}`,
title: "shortcut to unfiled, within toolbar"
});
let folder = await bmu.insert({
parentGuid: bmu.unfiledGuid,
index: bmu.DEFAULT_INDEX,
type: bmu.TYPE_FOLDER,
title: "folder within unfiled"
});
// Setup the places tree contents.
let tree = document.getElementById("tree");
tree.place = `place:parent=${PlacesUtils.bookmarks.toolbarGuid}`;
// Select the folder via the selectItems(folder.guid) API being tested
tree.selectItems([folder.guid]);
is(tree.selectedNode && tree.selectedNode.bookmarkGuid, folder.guid, "The node was selected through the shortcut");
// Cleanup
await bmu.eraseEverything();
})().catch(err => {
ok(false, `Uncaught error: ${err}`);
}).then(SimpleTest.finish);
}
]]></script>
</window>