mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
Added test_bookmark_sharing to version control; note this doesn't pass right now (and in fact the main test is commented out.)
This commit is contained in:
parent
d99bde9ec1
commit
dae06b83f1
@ -35,7 +35,7 @@
|
|||||||
*
|
*
|
||||||
* ***** END LICENSE BLOCK ***** */
|
* ***** END LICENSE BLOCK ***** */
|
||||||
|
|
||||||
const EXPORTED_SYMBOLS = ['BookmarksEngine'];
|
const EXPORTED_SYMBOLS = ['BookmarksEngine', 'BookmarksSharingManager'];
|
||||||
|
|
||||||
const Cc = Components.classes;
|
const Cc = Components.classes;
|
||||||
const Ci = Components.interfaces;
|
const Ci = Components.interfaces;
|
||||||
@ -65,6 +65,7 @@ Cu.import("resource://weave/trackers.js");
|
|||||||
Cu.import("resource://weave/identity.js");
|
Cu.import("resource://weave/identity.js");
|
||||||
Cu.import("resource://weave/xmpp/xmppClient.js");
|
Cu.import("resource://weave/xmpp/xmppClient.js");
|
||||||
Cu.import("resource://weave/notifications.js");
|
Cu.import("resource://weave/notifications.js");
|
||||||
|
Cu.import("resource://weave/sharing.js");
|
||||||
|
|
||||||
Function.prototype.async = Async.sugar;
|
Function.prototype.async = Async.sugar;
|
||||||
|
|
||||||
@ -203,8 +204,11 @@ BookmarksSharingManager.prototype = {
|
|||||||
the UI. */
|
the UI. */
|
||||||
|
|
||||||
// Create the outgoing share folder on the server
|
// Create the outgoing share folder on the server
|
||||||
|
dump("Blah!\n");
|
||||||
this._createOutgoingShare.async( this, self.cb, selectedFolder, username );
|
this._createOutgoingShare.async( this, self.cb, selectedFolder, username );
|
||||||
|
dump( "Gonna yield?\n" );
|
||||||
let serverPath = yield;
|
let serverPath = yield;
|
||||||
|
dump("in _share: annotated with serverPath = \" + serverPath + \"\n");
|
||||||
this._updateOutgoingShare.async( this, self.cb, selectedFolder );
|
this._updateOutgoingShare.async( this, self.cb, selectedFolder );
|
||||||
yield;
|
yield;
|
||||||
|
|
||||||
@ -477,9 +481,9 @@ BookmarksSharingManager.prototype = {
|
|||||||
self.done();
|
self.done();
|
||||||
},
|
},
|
||||||
|
|
||||||
_createIncomingShare: function BookmarkEngine__createShare(user,
|
_createIncomingShare: function BmkSharing__createShare(user,
|
||||||
serverPath,
|
serverPath,
|
||||||
title) {
|
title) {
|
||||||
/* Creates a new folder in the bookmark menu for the incoming share.
|
/* Creates a new folder in the bookmark menu for the incoming share.
|
||||||
user is the weave id of the user who is offering the folder to us;
|
user is the weave id of the user who is offering the folder to us;
|
||||||
serverPath is the path on the server where the shared data is located,
|
serverPath is the path on the server where the shared data is located,
|
||||||
|
115
services/sync/tests/unit/test_bookmark_sharing.js
Normal file
115
services/sync/tests/unit/test_bookmark_sharing.js
Normal file
@ -0,0 +1,115 @@
|
|||||||
|
Cu.import("resource://weave/engines/bookmarks.js");
|
||||||
|
Cu.import("resource://weave/util.js");
|
||||||
|
Cu.import("resource://weave/async.js");
|
||||||
|
Cu.import("resource://weave/sharing.js");
|
||||||
|
|
||||||
|
Function.prototype.async = Async.sugar;
|
||||||
|
|
||||||
|
load("bookmark_setup.js");
|
||||||
|
|
||||||
|
function FakeMicrosummaryService() {
|
||||||
|
return {hasMicrosummary: function() { return false; }};
|
||||||
|
}
|
||||||
|
|
||||||
|
function FakeAnnotationService() {
|
||||||
|
this._annotations = {};
|
||||||
|
}
|
||||||
|
FakeAnnotationService.prototype = {
|
||||||
|
EXPIRE_NEVER: 0,
|
||||||
|
getItemAnnotation: function (aItemId, aName) {
|
||||||
|
if (this._annotations[aItemId] != undefined)
|
||||||
|
if (this._annotations[aItemId][aName])
|
||||||
|
return this._annotations[aItemId][aName];
|
||||||
|
return null;
|
||||||
|
},
|
||||||
|
setItemAnnotation: function (aItemId, aName, aValue, aFlags, aExpiration) {
|
||||||
|
if (this._annotations[aItemId] == undefined)
|
||||||
|
this._annotations[aItemId] = {};
|
||||||
|
this._annotations[aItemId][aName] = aValue;
|
||||||
|
dump( "Annotated item " + aItemId + " with " + aName + " = " + aValue + "\n");
|
||||||
|
//ignore flags and expiration
|
||||||
|
},
|
||||||
|
getItemsWithAnnotation: function(aName, resultCount, results) {
|
||||||
|
var list = [];
|
||||||
|
for ( var x in this._annotations) {
|
||||||
|
if (this._annotations[x][aName] != undefined) {
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function FakeSharingApi() {
|
||||||
|
}
|
||||||
|
FakeSharingApi.prototype = {
|
||||||
|
shareWithUsers: function FakeSharingApi_shareWith(path, users, onComplete) {
|
||||||
|
// TODO just set a flag on the fake DAV thing.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Sharing.Api = FakeSharingApi;
|
||||||
|
|
||||||
|
|
||||||
|
var annoSvc = new FakeAnnotationService();
|
||||||
|
|
||||||
|
function makeBookmarksEngine() {
|
||||||
|
let engine = new BookmarksEngine();
|
||||||
|
engine._store.__ms = new FakeMicrosummaryService();
|
||||||
|
let shareManager = engine._sharing;
|
||||||
|
shareManager.__annoSvc = annoSvc; // use fake annotation service
|
||||||
|
return engine;
|
||||||
|
}
|
||||||
|
|
||||||
|
function run_test() {
|
||||||
|
let bms = Cc["@mozilla.org/browser/nav-bookmarks-service;1"].
|
||||||
|
getService(Ci.nsINavBookmarksService);
|
||||||
|
|
||||||
|
|
||||||
|
var syncTesting = new SyncTestingInfrastructure( makeBookmarksEngine );
|
||||||
|
|
||||||
|
let folderName = "Funny Pictures of Manatees and Walruses";
|
||||||
|
let folderToShare = bms.createFolder( bms.bookmarksMenuFolder,
|
||||||
|
folderName, -1 );
|
||||||
|
let lolrusBm = bms.insertBookmark(folderToShare,
|
||||||
|
uri("http://www.lolrus.com"),
|
||||||
|
-1, "LOLrus" );
|
||||||
|
let lolateeBm = bms.insertBookmark(folderToShare,
|
||||||
|
uri("http://www.lolatee.com"),
|
||||||
|
-1, "LOLatee" );
|
||||||
|
|
||||||
|
// Note xmpp.enabled is set to false by the SyncTestingInfrastructure.
|
||||||
|
|
||||||
|
let username = "rusty";
|
||||||
|
let engine = makeBookmarksEngine();
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
// TODO async function can't be called like this, call it from
|
||||||
|
// an async callback thingy in SyncTestingInfrastructure.
|
||||||
|
shareManager._share.async( shareManager, null, folderToShare, "jonas" );
|
||||||
|
|
||||||
|
dump( "folderToShare = " + folderToShare + "\n");
|
||||||
|
// Get the server path from folder annotation...
|
||||||
|
let serverPath = annoSvc.getItemAnnotation( folderToShare,
|
||||||
|
"weave/shared-server-path" );
|
||||||
|
dump( "Shared it to server path " + serverPath + "\n");
|
||||||
|
|
||||||
|
// get off rusty's computer, switch to Jonas's computer:
|
||||||
|
syncTesting.saveClientState( "rusty computer 1" );
|
||||||
|
syncTesting.resetClientState();
|
||||||
|
|
||||||
|
// These next two lines simulate what would happen when jonas received
|
||||||
|
// the xmpp message and clicked "accept".
|
||||||
|
shareManager._createIncomingShare(username, serverPath, folderName);
|
||||||
|
shareManager._updateAllIncomingShares();
|
||||||
|
|
||||||
|
// now look for a bookmark folder with an incoming-share annotation
|
||||||
|
let a = annoSvc.getItemsWithAnnotation("weave/shared-incoming",
|
||||||
|
{});
|
||||||
|
do_check_eq( a.length, 1); // should be just one
|
||||||
|
// TODO next look at its children:
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user