Commit 9bc8bdf3 authored by JC Brand's avatar JC Brand

Test updates after updating to use latest strophe.js

`toLocaleString` now returns element attributes in alphabetical order
(for better cross-browser consistency).

Also, `toLocaleString` is now used in favor of `outerHTML` because
browsers aren't consistent with one another in their output.
parent 79b8ed71
This source diff could not be displayed because it is too large. You can view the blob instead.
...@@ -14089,9 +14089,7 @@ ...@@ -14089,9 +14089,7 @@
"dev": true "dev": true
}, },
"strophe.js": { "strophe.js": {
"version": "1.2.16", "version": "github:strophe/strophejs#a2692dcfdaf7d591254ac73f3d8584992b6f8da7",
"resolved": "https://registry.npmjs.org/strophe.js/-/strophe.js-1.2.16.tgz",
"integrity": "sha512-r/Uq7aqrusg25Y0qHwV48cFnMY6K/CuZdGt3EggRx3kY4sMv8lG+AFoMlrmTcYVMG1BaJvQfv9Cthw4Ll8z7fQ==",
"dev": true "dev": true
}, },
"strophejs-plugin-ping": { "strophejs-plugin-ping": {
...@@ -14100,7 +14098,7 @@ ...@@ -14100,7 +14098,7 @@
"integrity": "sha1-NXEmxTZZSwZmjhh4c4Ey+sNciJY=", "integrity": "sha1-NXEmxTZZSwZmjhh4c4Ey+sNciJY=",
"dev": true, "dev": true,
"requires": { "requires": {
"strophe.js": "1.2.16" "strophe.js": "github:strophe/strophejs#a2692dcfdaf7d591254ac73f3d8584992b6f8da7"
} }
}, },
"strophejs-plugin-register": { "strophejs-plugin-register": {
......
...@@ -97,32 +97,32 @@ ...@@ -97,32 +97,32 @@
return test_utils.waitUntil(() => sent_stanza); return test_utils.waitUntil(() => sent_stanza);
}).then(() => { }).then(() => {
expect(sent_stanza.toLocaleString()).toBe( expect(sent_stanza.toLocaleString()).toBe(
"<iq type='set' from='dummy@localhost/resource' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq from="dummy@localhost/resource" id="${IQ_id}" type="set" xmlns="jabber:client">`+
"<pubsub xmlns='http://jabber.org/protocol/pubsub'>"+ `<pubsub xmlns="http://jabber.org/protocol/pubsub">`+
"<publish node='storage:bookmarks'>"+ `<publish node="storage:bookmarks">`+
"<item id='current'>"+ `<item id="current">`+
"<storage xmlns='storage:bookmarks'>"+ `<storage xmlns="storage:bookmarks">`+
"<conference name='Play&amp;apos;s the Thing' autojoin='true' jid='theplay@conference.shakespeare.lit'>"+ `<conference autojoin="true" jid="theplay@conference.shakespeare.lit" name="Play&amp;apos;s the Thing">`+
"<nick>JC</nick>"+ `<nick>JC</nick>`+
"</conference>"+ `</conference>`+
"</storage>"+ `</storage>`+
"</item>"+ `</item>`+
"</publish>"+ `</publish>`+
"<publish-options>"+ `<publish-options>`+
"<x xmlns='jabber:x:data' type='submit'>"+ `<x type="submit" xmlns="jabber:x:data">`+
"<field var='FORM_TYPE' type='hidden'>"+ `<field type="hidden" var="FORM_TYPE">`+
"<value>http://jabber.org/protocol/pubsub#publish-options</value>"+ `<value>http://jabber.org/protocol/pubsub#publish-options</value>`+
"</field>"+ `</field>`+
"<field var='pubsub#persist_items'>"+ `<field var="pubsub#persist_items">`+
"<value>true</value>"+ `<value>true</value>`+
"</field>"+ `</field>`+
"<field var='pubsub#access_model'>"+ `<field var="pubsub#access_model">`+
"<value>whitelist</value>"+ `<value>whitelist</value>`+
"</field>"+ `</field>`+
"</x>"+ `</x>`+
"</publish-options>"+ `</publish-options>`+
"</pubsub>"+ `</pubsub>`+
"</iq>" `</iq>`
); );
/* Server acknowledges successful storage /* Server acknowledges successful storage
* *
...@@ -245,28 +245,28 @@ ...@@ -245,28 +245,28 @@
// conferences to bookmark (since we removed the one and // conferences to bookmark (since we removed the one and
// only bookmark). // only bookmark).
expect(sent_stanza.toLocaleString()).toBe( expect(sent_stanza.toLocaleString()).toBe(
"<iq type='set' from='dummy@localhost/resource' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq from="dummy@localhost/resource" id="${IQ_id}" type="set" xmlns="jabber:client">`+
"<pubsub xmlns='http://jabber.org/protocol/pubsub'>"+ `<pubsub xmlns="http://jabber.org/protocol/pubsub">`+
"<publish node='storage:bookmarks'>"+ `<publish node="storage:bookmarks">`+
"<item id='current'>"+ `<item id="current">`+
"<storage xmlns='storage:bookmarks'/>"+ `<storage xmlns="storage:bookmarks"/>`+
"</item>"+ `</item>`+
"</publish>"+ `</publish>`+
"<publish-options>"+ `<publish-options>`+
"<x xmlns='jabber:x:data' type='submit'>"+ `<x type="submit" xmlns="jabber:x:data">`+
"<field var='FORM_TYPE' type='hidden'>"+ `<field type="hidden" var="FORM_TYPE">`+
"<value>http://jabber.org/protocol/pubsub#publish-options</value>"+ `<value>http://jabber.org/protocol/pubsub#publish-options</value>`+
"</field>"+ `</field>`+
"<field var='pubsub#persist_items'>"+ `<field var="pubsub#persist_items">`+
"<value>true</value>"+ `<value>true</value>`+
"</field>"+ `</field>`+
"<field var='pubsub#access_model'>"+ `<field var="pubsub#access_model">`+
"<value>whitelist</value>"+ `<value>whitelist</value>`+
"</field>"+ `</field>`+
"</x>"+ `</x>`+
"</publish-options>"+ `</publish-options>`+
"</pubsub>"+ `</pubsub>`+
"</iq>" `</iq>`
); );
done(); done();
}); });
......
...@@ -221,8 +221,8 @@ ...@@ -221,8 +221,8 @@
_converse.connection._dataRecv(test_utils.createRequest(presence)); _converse.connection._dataRecv(test_utils.createRequest(presence));
expect(_converse.connection.sendIQ).toHaveBeenCalled(); expect(_converse.connection.sendIQ).toHaveBeenCalled();
expect(sent_IQ.toLocaleString()).toBe( expect(sent_IQ.toLocaleString()).toBe(
"<iq to='room@conference.example.org' type='get' xmlns='jabber:client' id='"+IQ_id+ `<iq id="${IQ_id}" to="room@conference.example.org" type="get" xmlns="jabber:client">`+
"'><query xmlns='http://jabber.org/protocol/muc#owner'/></iq>" `<query xmlns="http://jabber.org/protocol/muc#owner"/></iq>`
); );
var node = Strophe.xmlHtmlNode( var node = Strophe.xmlHtmlNode(
'<iq xmlns="jabber:client"'+ '<iq xmlns="jabber:client"'+
...@@ -334,16 +334,17 @@ ...@@ -334,16 +334,17 @@
* node="x-roomuser-item"/> * node="x-roomuser-item"/>
* </iq> * </iq>
*/ */
return test_utils.waitUntil(() => _.get(_.filter( return test_utils.waitUntil(() => _.filter(
IQ_stanzas, IQ_stanzas,
s => sizzle(`iq[to="${room_jid}"] query[node="x-roomuser-item"]`, s.nodeTree).length s => sizzle(`iq[to="${room_jid}"] query[node="x-roomuser-item"]`, s.nodeTree).length
).pop(), 'nodeTree') ).pop()
); );
}).then(stanza => { }).then(node => {
expect(stanza.outerHTML.trim()).toBe( const stanza = node.nodeTree;
`<iq to="lounge@localhost" from="dummy@localhost/resource" `+ expect(node.toLocaleString()).toBe(
`type="get" xmlns="jabber:client" id="${stanza.getAttribute("id")}">`+ `<iq from="dummy@localhost/resource" id="${stanza.getAttribute("id")}" to="lounge@localhost" `+
`<query xmlns="http://jabber.org/protocol/disco#info" node="x-roomuser-item"/></iq>`); `type="get" xmlns="jabber:client">`+
`<query node="x-roomuser-item" xmlns="http://jabber.org/protocol/disco#info"/></iq>`);
/* <iq xmlns="jabber:client" type="error" to="jordie.langen@chat.example.org/converse.js-11659299" from="myroom@conference.chat.example.org"> /* <iq xmlns="jabber:client" type="error" to="jordie.langen@chat.example.org/converse.js-11659299" from="myroom@conference.chat.example.org">
* <error type="cancel"> * <error type="cancel">
...@@ -403,9 +404,9 @@ ...@@ -403,9 +404,9 @@
* </iq> * </iq>
*/ */
expect(sent_IQ.toLocaleString()).toBe( expect(sent_IQ.toLocaleString()).toBe(
"<iq to='lounge@localhost' type='set' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" to="lounge@localhost" type="set" xmlns="jabber:client">`+
"<query xmlns='http://jabber.org/protocol/muc#owner'><x xmlns='jabber:x:data' type='submit'/>"+ `<query xmlns="http://jabber.org/protocol/muc#owner"><x type="submit" xmlns="jabber:x:data"/>`+
"</query></iq>"); `</query></iq>`);
done(); done();
}).catch(_.partial(_converse.log, _, Strophe.LogLevel.FATAL)); }).catch(_.partial(_converse.log, _, Strophe.LogLevel.FATAL));
})); }));
...@@ -882,9 +883,9 @@ ...@@ -882,9 +883,9 @@
* </iq> * </iq>
*/ */
expect(sent_IQ.toLocaleString()).toBe( expect(sent_IQ.toLocaleString()).toBe(
"<iq to='coven@chat.shakespeare.lit' type='get' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="`+IQ_id+`" to="coven@chat.shakespeare.lit" type="get" xmlns="jabber:client">`+
"<query xmlns='http://jabber.org/protocol/muc#owner'/>"+ `<query xmlns="http://jabber.org/protocol/muc#owner"/>`+
"</iq>"); `</iq>`);
/* Server responds with the configuration form. /* Server responds with the configuration form.
* See: // http://xmpp.org/extensions/xep-0045.html#example-165 * See: // http://xmpp.org/extensions/xep-0045.html#example-165
...@@ -1291,16 +1292,17 @@ ...@@ -1291,16 +1292,17 @@
* node='x-roomuser-item'/> * node='x-roomuser-item'/>
* </iq> * </iq>
*/ */
return test_utils.waitUntil(() => _.get(_.filter( return test_utils.waitUntil(() => _.filter(
IQ_stanzas, IQ_stanzas,
s => sizzle(`iq[to="${room_jid}"] query[node="x-roomuser-item"]`, s.nodeTree).length s => sizzle(`iq[to="${room_jid}"] query[node="x-roomuser-item"]`, s.nodeTree).length
).pop(), 'nodeTree') ).pop()
); );
}).then(iq => { }).then(node => {
expect(iq.outerHTML).toBe( const iq = node.nodeTree;
`<iq to="lounge@localhost" from="dummy@localhost/resource" `+ expect(node.toLocaleString()).toBe(
`type="get" xmlns="jabber:client" id="${iq.getAttribute('id')}">`+ `<iq from="dummy@localhost/resource" id="${iq.getAttribute('id')}" to="lounge@localhost" `+
`<query xmlns="http://jabber.org/protocol/disco#info" node="x-roomuser-item"/></iq>`); `type="get" xmlns="jabber:client">`+
`<query node="x-roomuser-item" xmlns="http://jabber.org/protocol/disco#info"/></iq>`);
/* <iq from='coven@chat.shakespeare.lit' /* <iq from='coven@chat.shakespeare.lit'
* id='getnick1' * id='getnick1'
...@@ -1403,11 +1405,12 @@ ...@@ -1403,11 +1405,12 @@
expect(window.prompt).toHaveBeenCalled(); expect(window.prompt).toHaveBeenCalled();
expect(view.model.directInvite).toHaveBeenCalled(); expect(view.model.directInvite).toHaveBeenCalled();
expect(sent_stanza.toLocaleString()).toBe( expect(sent_stanza.toLocaleString()).toBe(
"<message from='dummy@localhost/resource' to='felix.amsel@localhost' id='" + `<message from="dummy@localhost/resource" `+
sent_stanza.nodeTree.getAttribute('id') + `id="${sent_stanza.nodeTree.getAttribute("id")}" `+
"' xmlns='jabber:client'>"+ `to="felix.amsel@localhost" `+
"<x xmlns='jabber:x:conference' jid='lounge@localhost' reason='Please join!'/>"+ `xmlns="jabber:client">`+
"</message>" `<x jid="lounge@localhost" reason="Please join!" xmlns="jabber:x:conference"/>`+
`</message>`
); );
} }
done(); done();
...@@ -1722,15 +1725,16 @@ ...@@ -1722,15 +1725,16 @@
_converse.api.rooms.open(room_jid, {'nick': 'some1'}) _converse.api.rooms.open(room_jid, {'nick': 'some1'})
.then(() => { .then(() => {
return test_utils.waitUntil(() => _.get(_.filter( return test_utils.waitUntil(() => _.filter(
IQ_stanzas, IQ_stanzas,
iq => iq.nodeTree.querySelector( iq => iq.nodeTree.querySelector(
`iq[to="${room_jid}"] query[xmlns="http://jabber.org/protocol/disco#info"]` `iq[to="${room_jid}"] query[xmlns="http://jabber.org/protocol/disco#info"]`
)).pop(), 'nodeTree')); )).pop());
}).then(stanza => { }).then(node => {
// Check that the groupchat queried for the feautures. // Check that the groupchat queried for the feautures.
expect(stanza.outerHTML).toBe( const stanza = node.nodeTree;
`<iq from="dummy@localhost/resource" to="${room_jid}" type="get" xmlns="jabber:client" id="${stanza.getAttribute("id")}">`+ expect(node.toLocaleString()).toBe(
`<iq from="dummy@localhost/resource" id="${stanza.getAttribute("id")}" to="${room_jid}" type="get" xmlns="jabber:client">`+
`<query xmlns="http://jabber.org/protocol/disco#info"/>`+ `<query xmlns="http://jabber.org/protocol/disco#info"/>`+
`</iq>`); `</iq>`);
...@@ -2130,8 +2134,8 @@ ...@@ -2130,8 +2134,8 @@
keyCode: 13 keyCode: 13
}); });
expect(_converse.connection.send).toHaveBeenCalled(); expect(_converse.connection.send).toHaveBeenCalled();
expect(sent_stanza.outerHTML).toBe( expect(Strophe.serialize(sent_stanza)).toBe(
`<iq to="lounge@muc.localhost" type="set" xmlns="jabber:client" id="${sent_stanza.getAttribute('id')}">`+ `<iq id="${sent_stanza.getAttribute('id')}" to="lounge@muc.localhost" type="set" xmlns="jabber:client">`+
`<query xmlns="http://jabber.org/protocol/muc#admin">`+ `<query xmlns="http://jabber.org/protocol/muc#admin">`+
`<item affiliation="member" jid="marc@localhost">`+ `<item affiliation="member" jid="marc@localhost">`+
`<reason>Welcome to the club!</reason>`+ `<reason>Welcome to the club!</reason>`+
...@@ -2148,19 +2152,14 @@ ...@@ -2148,19 +2152,14 @@
}); });
_converse.connection.IQ_stanzas = []; _converse.connection.IQ_stanzas = [];
_converse.connection._dataRecv(test_utils.createRequest(result)); _converse.connection._dataRecv(test_utils.createRequest(result));
return test_utils.waitUntil(() => _.filter(
return test_utils.waitUntil(() => {
return _.filter(
_converse.connection.IQ_stanzas, _converse.connection.IQ_stanzas,
(iq) => { iq => iq.nodeTree.querySelector('iq[to="lounge@muc.localhost"][type="get"] item[affiliation="member"]')).pop()
const node = iq.nodeTree.querySelector('iq[to="lounge@muc.localhost"][type="get"] item[affiliation="member"]'); );
if (node) { iq_stanza = iq.nodeTree;} }).then(node => {
return node; iq_stanza = node.nodeTree;
}).length; expect(node.toLocaleString()).toBe(
}); `<iq id="${iq_stanza.getAttribute('id')}" to="lounge@muc.localhost" type="get" xmlns="jabber:client">`+
}).then(() => {
expect(iq_stanza.outerHTML).toBe(
`<iq to="lounge@muc.localhost" type="get" xmlns="jabber:client" id="${iq_stanza.getAttribute('id')}">`+
`<query xmlns="http://jabber.org/protocol/muc#admin">`+ `<query xmlns="http://jabber.org/protocol/muc#admin">`+
`<item affiliation="member"/>`+ `<item affiliation="member"/>`+
`</query>`+ `</query>`+
...@@ -2178,18 +2177,14 @@ ...@@ -2178,18 +2177,14 @@
_converse.connection._dataRecv(test_utils.createRequest(result)); _converse.connection._dataRecv(test_utils.createRequest(result));
expect(view.model.occupants.length).toBe(2); expect(view.model.occupants.length).toBe(2);
return test_utils.waitUntil(() => { return test_utils.waitUntil(() => _.filter(
return _.filter(
_converse.connection.IQ_stanzas, _converse.connection.IQ_stanzas,
(iq) => { (iq) => iq.nodeTree.querySelector('iq[to="lounge@muc.localhost"][type="get"] item[affiliation="owner"]')).pop()
const node = iq.nodeTree.querySelector('iq[to="lounge@muc.localhost"][type="get"] item[affiliation="owner"]'); );
if (node) { iq_stanza = iq.nodeTree;} }).then(node => {
return node; iq_stanza = node.nodeTree;
}).length; expect(node.toLocaleString()).toBe(
}); `<iq id="${iq_stanza.getAttribute('id')}" to="lounge@muc.localhost" type="get" xmlns="jabber:client">`+
}).then(() => {
expect(iq_stanza.outerHTML).toBe(
`<iq to="lounge@muc.localhost" type="get" xmlns="jabber:client" id="${iq_stanza.getAttribute('id')}">`+
`<query xmlns="http://jabber.org/protocol/muc#admin">`+ `<query xmlns="http://jabber.org/protocol/muc#admin">`+
`<item affiliation="owner"/>`+ `<item affiliation="owner"/>`+
`</query>`+ `</query>`+
...@@ -2207,18 +2202,14 @@ ...@@ -2207,18 +2202,14 @@
_converse.connection._dataRecv(test_utils.createRequest(result)); _converse.connection._dataRecv(test_utils.createRequest(result));
expect(view.model.occupants.length).toBe(2); expect(view.model.occupants.length).toBe(2);
return test_utils.waitUntil(() => { return test_utils.waitUntil(() => _.filter(
return _.filter(
_converse.connection.IQ_stanzas, _converse.connection.IQ_stanzas,
(iq) => { (iq) => iq.nodeTree.querySelector('iq[to="lounge@muc.localhost"][type="get"] item[affiliation="admin"]')).pop()
const node = iq.nodeTree.querySelector('iq[to="lounge@muc.localhost"][type="get"] item[affiliation="admin"]'); );
if (node) { iq_stanza = iq.nodeTree;} }).then(node => {
return node; const iq_stanza = node.nodeTree;
}).length; expect(node.toLocaleString()).toBe(
}); `<iq id="${iq_stanza.getAttribute('id')}" to="lounge@muc.localhost" type="get" xmlns="jabber:client">`+
}).then(() => {
expect(iq_stanza.outerHTML).toBe(
`<iq to="lounge@muc.localhost" type="get" xmlns="jabber:client" id="${iq_stanza.getAttribute('id')}">`+
`<query xmlns="http://jabber.org/protocol/muc#admin">`+ `<query xmlns="http://jabber.org/protocol/muc#admin">`+
`<item affiliation="admin"/>`+ `<item affiliation="admin"/>`+
`</query>`+ `</query>`+
...@@ -2276,8 +2267,8 @@ ...@@ -2276,8 +2267,8 @@
}); });
expect(sent_stanza.textContent).toBe('This is a new subject'); expect(sent_stanza.textContent).toBe('This is a new subject');
expect(sent_stanza.outerHTML).toBe( expect(Strophe.serialize(sent_stanza).toLocaleString()).toBe(
'<message to="lounge@localhost" from="dummy@localhost/resource" type="groupchat" xmlns="jabber:client">'+ '<message from="dummy@localhost/resource" to="lounge@localhost" type="groupchat" xmlns="jabber:client">'+
'<subject xmlns="jabber:client">This is a new subject</subject>'+ '<subject xmlns="jabber:client">This is a new subject</subject>'+
'</message>'); '</message>');
...@@ -2289,8 +2280,8 @@ ...@@ -2289,8 +2280,8 @@
keyCode: 13 keyCode: 13
}); });
expect(sent_stanza.textContent).toBe('This is yet another subject'); expect(sent_stanza.textContent).toBe('This is yet another subject');
expect(sent_stanza.outerHTML).toBe( expect(Strophe.serialize(sent_stanza).toLocaleString()).toBe(
'<message to="lounge@localhost" from="dummy@localhost/resource" type="groupchat" xmlns="jabber:client">'+ '<message from="dummy@localhost/resource" to="lounge@localhost" type="groupchat" xmlns="jabber:client">'+
'<subject xmlns="jabber:client">This is yet another subject</subject>'+ '<subject xmlns="jabber:client">This is yet another subject</subject>'+
'</message>'); '</message>');
done(); done();
...@@ -2380,13 +2371,13 @@ ...@@ -2380,13 +2371,13 @@
expect(view.showErrorMessage.calls.count()).toBe(2); expect(view.showErrorMessage.calls.count()).toBe(2);
// Check that the member list now gets updated // Check that the member list now gets updated
expect(sent_IQ.toLocaleString()).toBe( expect(sent_IQ.toLocaleString()).toBe(
"<iq to='lounge@localhost' type='set' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" to="lounge@localhost" type="set" xmlns="jabber:client">`+
"<query xmlns='http://jabber.org/protocol/muc#admin'>"+ `<query xmlns="http://jabber.org/protocol/muc#admin">`+
"<item affiliation='owner' jid='annoyingGuy'>"+ `<item affiliation="owner" jid="annoyingGuy">`+
"<reason>You&apos;re responsible</reason>"+ `<reason>You&apos;re responsible</reason>`+
"</item>"+ `</item>`+
"</query>"+ `</query>`+
"</iq>"); `</iq>`);
presence = $pres({ presence = $pres({
'from': 'lounge@localhost/annoyingGuy', 'from': 'lounge@localhost/annoyingGuy',
...@@ -2461,13 +2452,13 @@ ...@@ -2461,13 +2452,13 @@
expect(view.model.setAffiliation).toHaveBeenCalled(); expect(view.model.setAffiliation).toHaveBeenCalled();
// Check that the member list now gets updated // Check that the member list now gets updated
expect(sent_IQ.toLocaleString()).toBe( expect(sent_IQ.toLocaleString()).toBe(
"<iq to='lounge@localhost' type='set' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" to="lounge@localhost" type="set" xmlns="jabber:client">`+
"<query xmlns='http://jabber.org/protocol/muc#admin'>"+ `<query xmlns="http://jabber.org/protocol/muc#admin">`+
"<item affiliation='outcast' jid='annoyingGuy'>"+ `<item affiliation="outcast" jid="annoyingGuy">`+
"<reason>You&apos;re annoying</reason>"+ `<reason>You&apos;re annoying</reason>`+
"</item>"+ `</item>`+
"</query>"+ `</query>`+
"</iq>"); `</iq>`);
presence = $pres({ presence = $pres({
'from': 'lounge@localhost/annoyingGuy', 'from': 'lounge@localhost/annoyingGuy',
...@@ -2541,13 +2532,13 @@ ...@@ -2541,13 +2532,13 @@
expect(view.showErrorMessage.calls.count()).toBe(1); expect(view.showErrorMessage.calls.count()).toBe(1);
expect(view.modifyRole).toHaveBeenCalled(); expect(view.modifyRole).toHaveBeenCalled();
expect(sent_IQ.toLocaleString()).toBe( expect(sent_IQ.toLocaleString()).toBe(
"<iq to='lounge@localhost' type='set' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" to="lounge@localhost" type="set" xmlns="jabber:client">`+
"<query xmlns='http://jabber.org/protocol/muc#admin'>"+ `<query xmlns="http://jabber.org/protocol/muc#admin">`+
"<item nick='annoyingGuy' role='none'>"+ `<item nick="annoyingGuy" role="none">`+
"<reason>You&apos;re annoying</reason>"+ `<reason>You&apos;re annoying</reason>`+
"</item>"+ `</item>`+
"</query>"+ `</query>`+
"</iq>"); `</iq>`);
/* <presence /* <presence
* from='harfleur@chat.shakespeare.lit/pistol' * from='harfleur@chat.shakespeare.lit/pistol'
...@@ -2645,13 +2636,13 @@ ...@@ -2645,13 +2636,13 @@
expect(view.showErrorMessage.calls.count()).toBe(1); expect(view.showErrorMessage.calls.count()).toBe(1);
expect(view.modifyRole).toHaveBeenCalled(); expect(view.modifyRole).toHaveBeenCalled();
expect(sent_IQ.toLocaleString()).toBe( expect(sent_IQ.toLocaleString()).toBe(
"<iq to='lounge@localhost' type='set' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" to="lounge@localhost" type="set" xmlns="jabber:client">`+
"<query xmlns='http://jabber.org/protocol/muc#admin'>"+ `<query xmlns="http://jabber.org/protocol/muc#admin">`+
"<item nick='trustworthyguy' role='moderator'>"+ `<item nick="trustworthyguy" role="moderator">`+
"<reason>You&apos;re trustworthy</reason>"+ `<reason>You&apos;re trustworthy</reason>`+
"</item>"+ `</item>`+
"</query>"+ `</query>`+
"</iq>"); `</iq>`);
/* <presence /* <presence
* from='coven@chat.shakespeare.lit/thirdwitch' * from='coven@chat.shakespeare.lit/thirdwitch'
...@@ -2682,13 +2673,13 @@ ...@@ -2682,13 +2673,13 @@
expect(view.showChatEvent.calls.count()).toBe(1); expect(view.showChatEvent.calls.count()).toBe(1);
expect(view.modifyRole).toHaveBeenCalled(); expect(view.modifyRole).toHaveBeenCalled();
expect(sent_IQ.toLocaleString()).toBe( expect(sent_IQ.toLocaleString()).toBe(
"<iq to='lounge@localhost' type='set' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" to="lounge@localhost" type="set" xmlns="jabber:client">`+
"<query xmlns='http://jabber.org/protocol/muc#admin'>"+ `<query xmlns="http://jabber.org/protocol/muc#admin">`+
"<item nick='trustworthyguy' role='participant'>"+ `<item nick="trustworthyguy" role="participant">`+
"<reason>Perhaps not</reason>"+ `<reason>Perhaps not</reason>`+
"</item>"+ `</item>`+
"</query>"+ `</query>`+
"</iq>"); `</iq>`);
/* <presence /* <presence
* from='coven@chat.shakespeare.lit/thirdwitch' * from='coven@chat.shakespeare.lit/thirdwitch'
...@@ -2783,13 +2774,13 @@ ...@@ -2783,13 +2774,13 @@
expect(view.showErrorMessage.calls.count()).toBe(1); expect(view.showErrorMessage.calls.count()).toBe(1);
expect(view.modifyRole).toHaveBeenCalled(); expect(view.modifyRole).toHaveBeenCalled();
expect(sent_IQ.toLocaleString()).toBe( expect(sent_IQ.toLocaleString()).toBe(
"<iq to='lounge@localhost' type='set' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" to="lounge@localhost" type="set" xmlns="jabber:client">`+
"<query xmlns='http://jabber.org/protocol/muc#admin'>"+ `<query xmlns="http://jabber.org/protocol/muc#admin">`+
"<item nick='annoyingGuy' role='visitor'>"+ `<item nick="annoyingGuy" role="visitor">`+
"<reason>You&apos;re annoying</reason>"+ `<reason>You&apos;re annoying</reason>`+
"</item>"+ `</item>`+
"</query>"+ `</query>`+
"</iq>"); `</iq>`);
/* <presence /* <presence
* from='coven@chat.shakespeare.lit/thirdwitch' * from='coven@chat.shakespeare.lit/thirdwitch'
...@@ -2820,13 +2811,13 @@ ...@@ -2820,13 +2811,13 @@
expect(view.showChatEvent.calls.count()).toBe(1); expect(view.showChatEvent.calls.count()).toBe(1);
expect(view.modifyRole).toHaveBeenCalled(); expect(view.modifyRole).toHaveBeenCalled();
expect(sent_IQ.toLocaleString()).toBe( expect(sent_IQ.toLocaleString()).toBe(
"<iq to='lounge@localhost' type='set' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" to="lounge@localhost" type="set" xmlns="jabber:client">`+
"<query xmlns='http://jabber.org/protocol/muc#admin'>"+ `<query xmlns="http://jabber.org/protocol/muc#admin">`+
"<item nick='annoyingGuy' role='participant'>"+ `<item nick="annoyingGuy" role="participant">`+
"<reason>Now you can talk again</reason>"+ `<reason>Now you can talk again</reason>`+
"</item>"+ `</item>`+
"</query>"+ `</query>`+
"</iq>"); `</iq>`);
/* <presence /* <presence
* from='coven@chat.shakespeare.lit/thirdwitch' * from='coven@chat.shakespeare.lit/thirdwitch'
...@@ -3160,15 +3151,16 @@ ...@@ -3160,15 +3151,16 @@
_converse.api.rooms.open(room_jid, {'nick': 'dummy'}) _converse.api.rooms.open(room_jid, {'nick': 'dummy'})
.then(() => { .then(() => {
return test_utils.waitUntil(() => _.get(_.filter( return test_utils.waitUntil(() => _.filter(
IQ_stanzas, IQ_stanzas,
iq => iq.nodeTree.querySelector( iq => iq.nodeTree.querySelector(
`iq[to="${room_jid}"] query[xmlns="http://jabber.org/protocol/disco#info"]` `iq[to="${room_jid}"] query[xmlns="http://jabber.org/protocol/disco#info"]`
)).pop(), 'nodeTree')); )).pop());
}).then(stanza => { }).then(node => {
// Check that the groupchat queried for the feautures. // Check that the groupchat queried for the feautures.
expect(stanza.outerHTML).toBe( const stanza = node.nodeTree;
`<iq from="dummy@localhost/resource" to="${room_jid}" type="get" xmlns="jabber:client" id="${stanza.getAttribute("id")}">`+ expect(node.toLocaleString()).toBe(
`<iq from="dummy@localhost/resource" id="${stanza.getAttribute("id")}" to="${room_jid}" type="get" xmlns="jabber:client">`+
`<query xmlns="http://jabber.org/protocol/disco#info"/>`+ `<query xmlns="http://jabber.org/protocol/disco#info"/>`+
`</iq>`); `</iq>`);
...@@ -3215,23 +3207,23 @@ ...@@ -3215,23 +3207,23 @@
var member_iq_id = IQ_ids.pop(); var member_iq_id = IQ_ids.pop();
expect(sent_IQs.pop().toLocaleString()).toBe( expect(sent_IQs.pop().toLocaleString()).toBe(
"<iq to='coven@chat.shakespeare.lit' type='get' xmlns='jabber:client' id='"+admin_iq_id+"'>"+ `<iq id="${admin_iq_id}" to="coven@chat.shakespeare.lit" type="get" xmlns="jabber:client">`+
"<query xmlns='http://jabber.org/protocol/muc#admin'>"+ `<query xmlns="http://jabber.org/protocol/muc#admin">`+
"<item affiliation='admin'/>"+ `<item affiliation="admin"/>`+
"</query>"+ `</query>`+
"</iq>"); `</iq>`);
expect(sent_IQs.pop().toLocaleString()).toBe( expect(sent_IQs.pop().toLocaleString()).toBe(
"<iq to='coven@chat.shakespeare.lit' type='get' xmlns='jabber:client' id='"+owner_iq_id+"'>"+ `<iq id="${owner_iq_id}" to="coven@chat.shakespeare.lit" type="get" xmlns="jabber:client">`+
"<query xmlns='http://jabber.org/protocol/muc#admin'>"+ `<query xmlns="http://jabber.org/protocol/muc#admin">`+
"<item affiliation='owner'/>"+ `<item affiliation="owner"/>`+
"</query>"+ `</query>`+
"</iq>"); `</iq>`);
expect(sent_IQs.pop().toLocaleString()).toBe( expect(sent_IQs.pop().toLocaleString()).toBe(
"<iq to='coven@chat.shakespeare.lit' type='get' xmlns='jabber:client' id='"+member_iq_id+"'>"+ `<iq id="${member_iq_id}" to="coven@chat.shakespeare.lit" type="get" xmlns="jabber:client">`+
"<query xmlns='http://jabber.org/protocol/muc#admin'>"+ `<query xmlns="http://jabber.org/protocol/muc#admin">`+
"<item affiliation='member'/>"+ `<item affiliation="member"/>`+
"</query>"+ `</query>`+
"</iq>"); `</iq>`);
/* Now the service sends the member list to the user /* Now the service sends the member list to the user
* *
...@@ -3294,18 +3286,18 @@ ...@@ -3294,18 +3286,18 @@
)).pop(), 'nodeTree')); )).pop(), 'nodeTree'));
}).then(stanza => { }).then(stanza => {
expect(stanza.outerHTML, expect(stanza.outerHTML,
"<iq to='coven@chat.shakespeare.lit' type='set' xmlns='jabber:client' id='"+IQ_ids.pop()+"'>"+ `<iq id="${IQ_ids.pop()}" to="coven@chat.shakespeare.lit" type="set" xmlns="jabber:client">`+
"<query xmlns='http://jabber.org/protocol/muc#admin'>"+ `<query xmlns="http://jabber.org/protocol/muc#admin">`+
"<item affiliation='member' jid='"+invitee_jid+"'>"+ `<item affiliation="member" jid="${invitee_jid}">`+
"<reason>Please join this groupchat</reason>"+ `<reason>Please join this groupchat</reason>`+
"</item>"+ `</item>`+
"</query>"+ `</query>`+
"</iq>"); `</iq>`);
// Finally check that the user gets invited. // Finally check that the user gets invited.
expect(sent_stanza.toLocaleString()).toBe( // Strophe adds the xmlns attr (although not in spec) expect(sent_stanza.toLocaleString()).toBe( // Strophe adds the xmlns attr (although not in spec)
"<message from='dummy@localhost/resource' to='"+invitee_jid+"' id='"+sent_id+"' xmlns='jabber:client'>"+ `<message from="dummy@localhost/resource" id="${sent_id}" to="${invitee_jid}" xmlns="jabber:client">`+
"<x xmlns='jabber:x:conference' jid='coven@chat.shakespeare.lit' reason='Please join this groupchat'/>"+ `<x jid="coven@chat.shakespeare.lit" reason="Please join this groupchat" xmlns="jabber:x:conference"/>`+
"</message>" `</message>`
); );
done(); done();
}).catch(_.partial(_converse.log, _, Strophe.LogLevel.FATAL)); }).catch(_.partial(_converse.log, _, Strophe.LogLevel.FATAL));
...@@ -3443,9 +3435,9 @@ ...@@ -3443,9 +3435,9 @@
return test_utils.waitUntil(() => _converse.chatboxes.length); return test_utils.waitUntil(() => _converse.chatboxes.length);
}).then(() => { }).then(() => {
expect(sent_stanza.toLocaleString()).toBe( expect(sent_stanza.toLocaleString()).toBe(
"<iq to='chat.shakespear.lit' from='dummy@localhost/resource' type='get' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq from="dummy@localhost/resource" id="${IQ_id}" to="chat.shakespear.lit" type="get" xmlns="jabber:client">`+
"<query xmlns='http://jabber.org/protocol/disco#items'/>"+ `<query xmlns="http://jabber.org/protocol/disco#items"/>`+
"</iq>" `</iq>`
); );
var iq = $iq({ var iq = $iq({
......
...@@ -223,9 +223,9 @@ ...@@ -223,9 +223,9 @@
input_name.value = 'Someone'; input_name.value = 'Someone';
modal.el.querySelector('button[type="submit"]').click(); modal.el.querySelector('button[type="submit"]').click();
expect(sent_stanza.toLocaleString()).toEqual( expect(sent_stanza.toLocaleString()).toEqual(
"<iq type='set' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" type="set" xmlns="jabber:client">`+
"<query xmlns='jabber:iq:roster'><item jid='someone@localhost' name='Someone'/></query>"+ `<query xmlns="jabber:iq:roster"><item jid="someone@localhost" name="Someone"/></query>`+
"</iq>"); `</iq>`);
done(); done();
}); });
})); }));
...@@ -294,9 +294,9 @@ ...@@ -294,9 +294,9 @@
expect(modal.el.querySelector('input[name="jid"]').value).toBe('marty@mcfly.net'); expect(modal.el.querySelector('input[name="jid"]').value).toBe('marty@mcfly.net');
modal.el.querySelector('button[type="submit"]').click(); modal.el.querySelector('button[type="submit"]').click();
expect(sent_stanza.toLocaleString()).toEqual( expect(sent_stanza.toLocaleString()).toEqual(
"<iq type='set' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" type="set" xmlns="jabber:client">`+
"<query xmlns='jabber:iq:roster'><item jid='marty@mcfly.net' name='Marty McFly'/></query>"+ `<query xmlns="jabber:iq:roster"><item jid="marty@mcfly.net" name="Marty McFly"/></query>`+
"</iq>"); `</iq>`);
window.XMLHttpRequest = XMLHttpRequestBackup; window.XMLHttpRequest = XMLHttpRequestBackup;
done(); done();
}); });
......
...@@ -74,14 +74,10 @@ ...@@ -74,14 +74,10 @@
i++; i++;
} }
expect(_converse.sendCSI).toHaveBeenCalledWith('inactive'); expect(_converse.sendCSI).toHaveBeenCalledWith('inactive');
expect(sent_stanza.toLocaleString()).toBe( expect(sent_stanza.toLocaleString()).toBe('<inactive xmlns="urn:xmpp:csi:0"/>');
"<inactive xmlns='urn:xmpp:csi:0'/>"
);
_converse.onUserActivity(); _converse.onUserActivity();
expect(_converse.sendCSI).toHaveBeenCalledWith('active'); expect(_converse.sendCSI).toHaveBeenCalledWith('active');
expect(sent_stanza.toLocaleString()).toBe( expect(sent_stanza.toLocaleString()).toBe('<active xmlns="urn:xmpp:csi:0"/>');
"<active xmlns='urn:xmpp:csi:0'/>"
);
// Reset values // Reset values
_converse.csi_waiting_time = 0; _converse.csi_waiting_time = 0;
_converse.disco_entities.get(_converse.domain).features['urn:xmpp:csi:0'] = false; _converse.disco_entities.get(_converse.domain).features['urn:xmpp:csi:0'] = false;
......
...@@ -118,9 +118,9 @@ ...@@ -118,9 +118,9 @@
}); });
var IQ_id = IQ_ids[IQ_stanzas.indexOf(stanza)]; var IQ_id = IQ_ids[IQ_stanzas.indexOf(stanza)];
expect(stanza.toLocaleString()).toBe( expect(stanza.toLocaleString()).toBe(
"<iq from='dummy@localhost/resource' to='upload.localhost' type='get' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq from="dummy@localhost/resource" id="`+IQ_id+`" to="upload.localhost" type="get" xmlns="jabber:client">`+
"<query xmlns='http://jabber.org/protocol/disco#info'/>"+ `<query xmlns="http://jabber.org/protocol/disco#info"/>`+
"</iq>"); `</iq>`);
// Upload service responds and reports a maximum file size of 5MiB // Upload service responds and reports a maximum file size of 5MiB
/* <iq from='upload.montague.tld' /* <iq from='upload.montague.tld'
...@@ -301,16 +301,17 @@ ...@@ -301,16 +301,17 @@
}).then(function () { }).then(function () {
var iq = IQ_stanzas.pop(); var iq = IQ_stanzas.pop();
expect(iq.toLocaleString()).toBe( expect(iq.toLocaleString()).toBe(
"<iq from='dummy@localhost/resource' "+ `<iq from="dummy@localhost/resource" `+
"to='upload.montague.tld' "+ `id="${iq.nodeTree.getAttribute("id")}" `+
"type='get' "+ `to="upload.montague.tld" `+
"xmlns='jabber:client' "+ `type="get" `+
"id='"+iq.nodeTree.getAttribute('id')+"'>"+ `xmlns="jabber:client">`+
"<request xmlns='urn:xmpp:http:upload:0' "+ `<request `+
"filename='my-juliet.jpg' "+ `content-type="image/jpeg" `+
"size='23456' "+ `filename="my-juliet.jpg" `+
"content-type='image/jpeg'/>"+ `size="23456" `+
"</iq>"); `xmlns="urn:xmpp:http:upload:0"/>`+
`</iq>`);
var base_url = document.URL.split(window.location.pathname)[0]; var base_url = document.URL.split(window.location.pathname)[0];
var message = base_url+"/logo/conversejs-filled.svg"; var message = base_url+"/logo/conversejs-filled.svg";
...@@ -352,19 +353,18 @@ ...@@ -352,19 +353,18 @@
return sent_stanza; return sent_stanza;
}, 1000).then(function () { }, 1000).then(function () {
expect(sent_stanza.toLocaleString()).toBe( expect(sent_stanza.toLocaleString()).toBe(
"<message from='dummy@localhost/resource' "+ `<message from="dummy@localhost/resource" `+
"to='irini.vlastuin@localhost' "+ `id="${sent_stanza.nodeTree.getAttribute("id")}" `+
"type='chat' "+ `to="irini.vlastuin@localhost" `+
"id='"+sent_stanza.nodeTree.getAttribute('id')+"' xmlns='jabber:client'>"+ `type="chat" `+
"<body>"+message+"</body>"+ `xmlns="jabber:client">`+
"<active xmlns='http://jabber.org/protocol/chatstates'/>"+ `<body>${message}</body>`+
"<x xmlns='jabber:x:oob'>"+ `<active xmlns="http://jabber.org/protocol/chatstates"/>`+
"<url>"+message+"</url>"+ `<x xmlns="jabber:x:oob">`+
"</x>"+ `<url>${message}</url>`+
"</message>"); `</x>`+
return test_utils.waitUntil(function () { `</message>`);
return view.el.querySelector('.chat-image'); return test_utils.waitUntil(() => view.el.querySelector('.chat-image'), 1000);
}, 1000);
}).then(function () { }).then(function () {
// Check that the image renders // Check that the image renders
expect(view.el.querySelector('.chat-msg .chat-msg__media').innerHTML.trim()).toEqual( expect(view.el.querySelector('.chat-msg .chat-msg__media').innerHTML.trim()).toEqual(
...@@ -408,16 +408,17 @@ ...@@ -408,16 +408,17 @@
}).then(function () { }).then(function () {
var iq = IQ_stanzas.pop(); var iq = IQ_stanzas.pop();
expect(iq.toLocaleString()).toBe( expect(iq.toLocaleString()).toBe(
"<iq from='dummy@localhost/resource' "+ `<iq from="dummy@localhost/resource" `+
"to='upload.montague.tld' "+ `id="${iq.nodeTree.getAttribute("id")}" `+
"type='get' "+ `to="upload.montague.tld" `+
"xmlns='jabber:client' "+ `type="get" `+
"id='"+iq.nodeTree.getAttribute('id')+"'>"+ `xmlns="jabber:client">`+
"<request xmlns='urn:xmpp:http:upload:0' "+ `<request `+
"filename='my-juliet.jpg' "+ `content-type="image/jpeg" `+
"size='23456' "+ `filename="my-juliet.jpg" `+
"content-type='image/jpeg'/>"+ `size="23456" `+
"</iq>"); `xmlns="urn:xmpp:http:upload:0"/>`+
`</iq>`);
var base_url = document.URL.split(window.location.pathname)[0]; var base_url = document.URL.split(window.location.pathname)[0];
var message = base_url+"/logo/conversejs-filled.svg"; var message = base_url+"/logo/conversejs-filled.svg";
...@@ -455,23 +456,21 @@ ...@@ -455,23 +456,21 @@
}); });
_converse.connection._dataRecv(test_utils.createRequest(stanza)); _converse.connection._dataRecv(test_utils.createRequest(stanza));
return test_utils.waitUntil(function () { return test_utils.waitUntil(() => sent_stanza, 1000).then(function () {
return sent_stanza;
}, 1000).then(function () {
expect(sent_stanza.toLocaleString()).toBe( expect(sent_stanza.toLocaleString()).toBe(
"<message from='dummy@localhost/resource' "+ `<message `+
"to='lounge@localhost' "+ `from="dummy@localhost/resource" `+
"type='groupchat' "+ `id="${sent_stanza.nodeTree.getAttribute("id")}" `+
"id='"+sent_stanza.nodeTree.getAttribute('id')+"' xmlns='jabber:client'>"+ `to="lounge@localhost" `+
"<body>"+message+"</body>"+ `type="groupchat" `+
"<active xmlns='http://jabber.org/protocol/chatstates'/>"+ `xmlns="jabber:client">`+
"<x xmlns='jabber:x:oob'>"+ `<body>${message}</body>`+
"<url>"+message+"</url>"+ `<active xmlns="http://jabber.org/protocol/chatstates"/>`+
"</x>"+ `<x xmlns="jabber:x:oob">`+
"</message>"); `<url>${message}</url>`+
return test_utils.waitUntil(function () { `</x>`+
return view.el.querySelector('.chat-image'); `</message>`);
}, 1000); return test_utils.waitUntil(() => view.el.querySelector('.chat-image'), 1000);
}).then(function () { }).then(function () {
// Check that the image renders // Check that the image renders
expect(view.el.querySelector('.chat-msg .chat-msg__media').innerHTML.trim()).toEqual( expect(view.el.querySelector('.chat-msg .chat-msg__media').innerHTML.trim()).toEqual(
...@@ -569,9 +568,9 @@ ...@@ -569,9 +568,9 @@
}); });
var IQ_id = IQ_ids[IQ_stanzas.indexOf(stanza)]; var IQ_id = IQ_ids[IQ_stanzas.indexOf(stanza)];
expect(stanza.toLocaleString()).toBe( expect(stanza.toLocaleString()).toBe(
"<iq from='dummy@localhost/resource' to='upload.localhost' type='get' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq from="dummy@localhost/resource" id="${IQ_id}" to="upload.localhost" type="get" xmlns="jabber:client">`+
"<query xmlns='http://jabber.org/protocol/disco#info'/>"+ `<query xmlns="http://jabber.org/protocol/disco#info"/>`+
"</iq>"); `</iq>`);
// Upload service responds and reports a maximum file size of 5MiB // Upload service responds and reports a maximum file size of 5MiB
stanza = $iq({'type': 'result', 'to': 'dummy@localhost/resource', 'id': IQ_id, 'from': 'upload.localhost'}) stanza = $iq({'type': 'result', 'to': 'dummy@localhost/resource', 'id': IQ_id, 'from': 'upload.localhost'})
...@@ -650,16 +649,17 @@ ...@@ -650,16 +649,17 @@
}).then(function () { }).then(function () {
const iq = IQ_stanzas.pop(); const iq = IQ_stanzas.pop();
expect(iq.toLocaleString()).toBe( expect(iq.toLocaleString()).toBe(
"<iq from='dummy@localhost/resource' "+ `<iq from="dummy@localhost/resource" `+
"to='upload.montague.tld' "+ `id="${iq.nodeTree.getAttribute("id")}" `+
"type='get' "+ `to="upload.montague.tld" `+
"xmlns='jabber:client' "+ `type="get" `+
"id='"+iq.nodeTree.getAttribute('id')+"'>"+ `xmlns="jabber:client">`+
"<request xmlns='urn:xmpp:http:upload:0' "+ `<request `+
"filename='my-juliet.jpg' "+ `content-type="image/jpeg" `+
"size='23456' "+ `filename="my-juliet.jpg" `+
"content-type='image/jpeg'/>"+ `size="23456" `+
"</iq>"); `xmlns="urn:xmpp:http:upload:0"/>`+
`</iq>`);
const base_url = document.URL.split(window.location.pathname)[0]; const base_url = document.URL.split(window.location.pathname)[0];
const message = base_url+"/logo/conversejs-filled.svg"; const message = base_url+"/logo/conversejs-filled.svg";
......
...@@ -81,7 +81,7 @@ ...@@ -81,7 +81,7 @@
_converse.api.archive.query(); _converse.api.archive.query();
var queryid = sent_stanza.nodeTree.querySelector('query').getAttribute('queryid'); var queryid = sent_stanza.nodeTree.querySelector('query').getAttribute('queryid');
expect(sent_stanza.toString()).toBe( expect(sent_stanza.toString()).toBe(
"<iq type='set' xmlns='jabber:client' id='"+IQ_id+"'><query xmlns='urn:xmpp:mam:2' queryid='"+queryid+"'/></iq>"); `<iq id="${IQ_id}" type="set" xmlns="jabber:client"><query queryid="${queryid}" xmlns="urn:xmpp:mam:2"/></iq>`);
done(); done();
})); }));
...@@ -103,19 +103,18 @@ ...@@ -103,19 +103,18 @@
_converse.api.archive.query({'with':'juliet@capulet.lit'}); _converse.api.archive.query({'with':'juliet@capulet.lit'});
var queryid = sent_stanza.nodeTree.querySelector('query').getAttribute('queryid'); var queryid = sent_stanza.nodeTree.querySelector('query').getAttribute('queryid');
expect(sent_stanza.toString()).toBe( expect(sent_stanza.toString()).toBe(
"<iq type='set' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" type="set" xmlns="jabber:client">`+
"<query xmlns='urn:xmpp:mam:2' queryid='"+queryid+"'>"+ `<query queryid="${queryid}" xmlns="urn:xmpp:mam:2">`+
"<x xmlns='jabber:x:data' type='submit'>"+ `<x type="submit" xmlns="jabber:x:data">`+
"<field var='FORM_TYPE' type='hidden'>"+ `<field type="hidden" var="FORM_TYPE">`+
"<value>urn:xmpp:mam:2</value>"+ `<value>urn:xmpp:mam:2</value>`+
"</field>"+ `</field>`+
"<field var='with'>"+ `<field var="with">`+
"<value>juliet@capulet.lit</value>"+ `<value>juliet@capulet.lit</value>`+
"</field>"+ `</field>`+
"</x>"+ `</x>`+
"</query>"+ `</query>`+
"</iq>" `</iq>`);
);
done(); done();
}); });
})); }));
...@@ -142,15 +141,15 @@ ...@@ -142,15 +141,15 @@
var queryid = sent_stanza.nodeTree.querySelector('query').getAttribute('queryid'); var queryid = sent_stanza.nodeTree.querySelector('query').getAttribute('queryid');
expect(sent_stanza.toString()).toBe( expect(sent_stanza.toString()).toBe(
"<iq type='set' to='coven@chat.shakespeare.lit' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" to="coven@chat.shakespeare.lit" type="set" xmlns="jabber:client">`+
"<query xmlns='urn:xmpp:mam:2' queryid='"+queryid+"'>"+ `<query queryid="${queryid}" xmlns="urn:xmpp:mam:2">`+
"<x xmlns='jabber:x:data' type='submit'>"+ `<x type="submit" xmlns="jabber:x:data">`+
"<field var='FORM_TYPE' type='hidden'>"+ `<field type="hidden" var="FORM_TYPE">`+
"<value>urn:xmpp:mam:2</value>"+ `<value>urn:xmpp:mam:2</value>`+
"</field>"+ `</field>`+
"</x>"+ `</x>`+
"</query>"+ `</query>`+
"</iq>"); `</iq>`);
done(); done();
}); });
})); }));
...@@ -257,21 +256,21 @@ ...@@ -257,21 +256,21 @@
}); });
var queryid = sent_stanza.nodeTree.querySelector('query').getAttribute('queryid'); var queryid = sent_stanza.nodeTree.querySelector('query').getAttribute('queryid');
expect(sent_stanza.toString()).toBe( expect(sent_stanza.toString()).toBe(
"<iq type='set' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" type="set" xmlns="jabber:client">`+
"<query xmlns='urn:xmpp:mam:2' queryid='"+queryid+"'>"+ `<query queryid="${queryid}" xmlns="urn:xmpp:mam:2">`+
"<x xmlns='jabber:x:data' type='submit'>"+ `<x type="submit" xmlns="jabber:x:data">`+
"<field var='FORM_TYPE' type='hidden'>"+ `<field type="hidden" var="FORM_TYPE">`+
"<value>urn:xmpp:mam:2</value>"+ `<value>urn:xmpp:mam:2</value>`+
"</field>"+ `</field>`+
"<field var='start'>"+ `<field var="start">`+
"<value>"+moment(start).format()+"</value>"+ `<value>${moment(start).format()}</value>`+
"</field>"+ `</field>`+
"<field var='end'>"+ `<field var="end">`+
"<value>"+moment(end).format()+"</value>"+ `<value>${moment(end).format()}</value>`+
"</field>"+ `</field>`+
"</x>"+ `</x>`+
"</query>"+ `</query>`+
"</iq>" `</iq>`
); );
done(); done();
}); });
...@@ -315,18 +314,18 @@ ...@@ -315,18 +314,18 @@
_converse.api.archive.query({'start': start}); _converse.api.archive.query({'start': start});
var queryid = sent_stanza.nodeTree.querySelector('query').getAttribute('queryid'); var queryid = sent_stanza.nodeTree.querySelector('query').getAttribute('queryid');
expect(sent_stanza.toString()).toBe( expect(sent_stanza.toString()).toBe(
"<iq type='set' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" type="set" xmlns="jabber:client">`+
"<query xmlns='urn:xmpp:mam:2' queryid='"+queryid+"'>"+ `<query queryid="${queryid}" xmlns="urn:xmpp:mam:2">`+
"<x xmlns='jabber:x:data' type='submit'>"+ `<x type="submit" xmlns="jabber:x:data">`+
"<field var='FORM_TYPE' type='hidden'>"+ `<field type="hidden" var="FORM_TYPE">`+
"<value>urn:xmpp:mam:2</value>"+ `<value>urn:xmpp:mam:2</value>`+
"</field>"+ `</field>`+
"<field var='start'>"+ `<field var="start">`+
"<value>"+moment(start).format()+"</value>"+ `<value>${moment(start).format()}</value>`+
"</field>"+ `</field>`+
"</x>"+ `</x>`+
"</query>"+ `</query>`+
"</iq>" `</iq>`
); );
done(); done();
}); });
...@@ -352,21 +351,21 @@ ...@@ -352,21 +351,21 @@
_converse.api.archive.query({'start': start, 'max':10}); _converse.api.archive.query({'start': start, 'max':10});
var queryid = sent_stanza.nodeTree.querySelector('query').getAttribute('queryid'); var queryid = sent_stanza.nodeTree.querySelector('query').getAttribute('queryid');
expect(sent_stanza.toString()).toBe( expect(sent_stanza.toString()).toBe(
"<iq type='set' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" type="set" xmlns="jabber:client">`+
"<query xmlns='urn:xmpp:mam:2' queryid='"+queryid+"'>"+ `<query queryid="${queryid}" xmlns="urn:xmpp:mam:2">`+
"<x xmlns='jabber:x:data' type='submit'>"+ `<x type="submit" xmlns="jabber:x:data">`+
"<field var='FORM_TYPE' type='hidden'>"+ `<field type="hidden" var="FORM_TYPE">`+
"<value>urn:xmpp:mam:2</value>"+ `<value>urn:xmpp:mam:2</value>`+
"</field>"+ `</field>`+
"<field var='start'>"+ `<field var="start">`+
"<value>"+moment(start).format()+"</value>"+ `<value>${moment(start).format()}</value>`+
"</field>"+ `</field>`+
"</x>"+ `</x>`+
"<set xmlns='http://jabber.org/protocol/rsm'>"+ `<set xmlns="http://jabber.org/protocol/rsm">`+
"<max>10</max>"+ `<max>10</max>`+
"</set>"+ `</set>`+
"</query>"+ `</query>`+
"</iq>" `</iq>`
); );
done(); done();
}); });
...@@ -395,23 +394,22 @@ ...@@ -395,23 +394,22 @@
}); });
var queryid = sent_stanza.nodeTree.querySelector('query').getAttribute('queryid'); var queryid = sent_stanza.nodeTree.querySelector('query').getAttribute('queryid');
expect(sent_stanza.toString()).toBe( expect(sent_stanza.toString()).toBe(
"<iq type='set' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" type="set" xmlns="jabber:client">`+
"<query xmlns='urn:xmpp:mam:2' queryid='"+queryid+"'>"+ `<query queryid="${queryid}" xmlns="urn:xmpp:mam:2">`+
"<x xmlns='jabber:x:data' type='submit'>"+ `<x type="submit" xmlns="jabber:x:data">`+
"<field var='FORM_TYPE' type='hidden'>"+ `<field type="hidden" var="FORM_TYPE">`+
"<value>urn:xmpp:mam:2</value>"+ `<value>urn:xmpp:mam:2</value>`+
"</field>"+ `</field>`+
"<field var='start'>"+ `<field var="start">`+
"<value>"+moment(start).format()+"</value>"+ `<value>${moment(start).format()}</value>`+
"</field>"+ `</field>`+
"</x>"+ `</x>`+
"<set xmlns='http://jabber.org/protocol/rsm'>"+ `<set xmlns="http://jabber.org/protocol/rsm">`+
"<max>10</max>"+ `<max>10</max>`+
"<after>09af3-cc343-b409f</after>"+ `<after>09af3-cc343-b409f</after>`+
"</set>"+ `</set>`+
"</query>"+ `</query>`+
"</iq>" `</iq>`);
);
done(); done();
}); });
})); }));
...@@ -434,20 +432,19 @@ ...@@ -434,20 +432,19 @@
_converse.api.archive.query({'before': '', 'max':10}); _converse.api.archive.query({'before': '', 'max':10});
var queryid = sent_stanza.nodeTree.querySelector('query').getAttribute('queryid'); var queryid = sent_stanza.nodeTree.querySelector('query').getAttribute('queryid');
expect(sent_stanza.toString()).toBe( expect(sent_stanza.toString()).toBe(
"<iq type='set' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" type="set" xmlns="jabber:client">`+
"<query xmlns='urn:xmpp:mam:2' queryid='"+queryid+"'>"+ `<query queryid="${queryid}" xmlns="urn:xmpp:mam:2">`+
"<x xmlns='jabber:x:data' type='submit'>"+ `<x type="submit" xmlns="jabber:x:data">`+
"<field var='FORM_TYPE' type='hidden'>"+ `<field type="hidden" var="FORM_TYPE">`+
"<value>urn:xmpp:mam:2</value>"+ `<value>urn:xmpp:mam:2</value>`+
"</field>"+ `</field>`+
"</x>"+ `</x>`+
"<set xmlns='http://jabber.org/protocol/rsm'>"+ `<set xmlns="http://jabber.org/protocol/rsm">`+
"<max>10</max>"+ `<max>10</max>`+
"<before></before>"+ `<before></before>`+
"</set>"+ `</set>`+
"</query>"+ `</query>`+
"</iq>" `</iq>`);
);
done(); done();
}); });
})); }));
...@@ -478,25 +475,24 @@ ...@@ -478,25 +475,24 @@
var queryid = sent_stanza.nodeTree.querySelector('query').getAttribute('queryid'); var queryid = sent_stanza.nodeTree.querySelector('query').getAttribute('queryid');
expect(sent_stanza.toString()).toBe( expect(sent_stanza.toString()).toBe(
"<iq type='set' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" type="set" xmlns="jabber:client">`+
"<query xmlns='urn:xmpp:mam:2' queryid='"+queryid+"'>"+ `<query queryid="${queryid}" xmlns="urn:xmpp:mam:2">`+
"<x xmlns='jabber:x:data' type='submit'>"+ `<x type="submit" xmlns="jabber:x:data">`+
"<field var='FORM_TYPE' type='hidden'>"+ `<field type="hidden" var="FORM_TYPE">`+
"<value>urn:xmpp:mam:2</value>"+ `<value>urn:xmpp:mam:2</value>`+
"</field>"+ `</field>`+
"<field var='with'>"+ `<field var="with">`+
"<value>romeo@montague.lit</value>"+ `<value>romeo@montague.lit</value>`+
"</field>"+ `</field>`+
"<field var='start'>"+ `<field var="start">`+
"<value>"+moment(rsm.start).format()+"</value>"+ `<value>${moment(rsm.start).format()}</value>`+
"</field>"+ `</field>`+
"</x>"+ `</x>`+
"<set xmlns='http://jabber.org/protocol/rsm'>"+ `<set xmlns="http://jabber.org/protocol/rsm">`+
"<max>10</max>"+ `<max>10</max>`+
"</set>"+ `</set>`+
"</query>"+ `</query>`+
"</iq>" `</iq>`);
);
done(); done();
}); });
})); }));
...@@ -619,10 +615,9 @@ ...@@ -619,10 +615,9 @@
expect(_converse.connection.sendIQ).toHaveBeenCalled(); expect(_converse.connection.sendIQ).toHaveBeenCalled();
expect(sent_stanza.toLocaleString()).toBe( expect(sent_stanza.toLocaleString()).toBe(
"<iq type='get' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" type="get" xmlns="jabber:client">`+
"<prefs xmlns='urn:xmpp:mam:2'/>"+ `<prefs xmlns="urn:xmpp:mam:2"/>`+
"</iq>" `</iq>`);
);
/* Example 20. Server responds with current preferences /* Example 20. Server responds with current preferences
* *
...@@ -643,12 +638,12 @@ ...@@ -643,12 +638,12 @@
expect(_converse.connection.sendIQ.calls.count()).toBe(2); expect(_converse.connection.sendIQ.calls.count()).toBe(2);
expect(sent_stanza.toString()).toBe( expect(sent_stanza.toString()).toBe(
"<iq type='set' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" type="set" xmlns="jabber:client">`+
"<prefs xmlns='urn:xmpp:mam:2' default='never'>"+ `<prefs default="never" xmlns="urn:xmpp:mam:2">`+
"<always><jid>romeo@montague.lit</jid></always>"+ `<always><jid>romeo@montague.lit</jid></always>`+
"<never><jid>montague@montague.lit</jid></never>"+ `<never><jid>montague@montague.lit</jid></never>`+
"</prefs>"+ `</prefs>`+
"</iq>" `</iq>`
); );
expect(feature.get('preference')).toBe(undefined); expect(feature.get('preference')).toBe(undefined);
......
...@@ -69,12 +69,12 @@ ...@@ -69,12 +69,12 @@
const msg = _converse.connection.send.calls.all()[0].args[0]; const msg = _converse.connection.send.calls.all()[0].args[0];
expect(msg.toLocaleString()) expect(msg.toLocaleString())
.toBe(`<message from='dummy@localhost/resource' `+ .toBe(`<message from="dummy@localhost/resource" id="${msg.nodeTree.getAttribute("id")}" `+
`to='max.frankfurter@localhost' type='chat' id='${msg.nodeTree.getAttribute('id')}' `+ `to="max.frankfurter@localhost" type="chat" `+
`xmlns='jabber:client'>`+ `xmlns="jabber:client">`+
`<body>But soft, what light through yonder window breaks?</body>`+ `<body>But soft, what light through yonder window breaks?</body>`+
`<active xmlns='http://jabber.org/protocol/chatstates'/>`+ `<active xmlns="http://jabber.org/protocol/chatstates"/>`+
`<replace xmlns='urn:xmpp:message-correct:0' id='${first_msg.get('msgid')}'/>`+ `<replace id="${first_msg.get("msgid")}" xmlns="urn:xmpp:message-correct:0"/>`+
`</message>`); `</message>`);
expect(view.model.messages.models.length).toBe(1); expect(view.model.messages.models.length).toBe(1);
const corrected_message = view.model.messages.at(0); const corrected_message = view.model.messages.at(0);
...@@ -172,12 +172,12 @@ ...@@ -172,12 +172,12 @@
const msg = _converse.connection.send.calls.all()[0].args[0]; const msg = _converse.connection.send.calls.all()[0].args[0];
expect(msg.toLocaleString()) expect(msg.toLocaleString())
.toBe(`<message from='dummy@localhost/resource' `+ .toBe(`<message from="dummy@localhost/resource" id="${msg.nodeTree.getAttribute("id")}" `+
`to='max.frankfurter@localhost' type='chat' id='${msg.nodeTree.getAttribute('id')}' `+ `to="max.frankfurter@localhost" type="chat" `+
`xmlns='jabber:client'>`+ `xmlns="jabber:client">`+
`<body>But soft, what light through yonder window breaks?</body>`+ `<body>But soft, what light through yonder window breaks?</body>`+
`<active xmlns='http://jabber.org/protocol/chatstates'/>`+ `<active xmlns="http://jabber.org/protocol/chatstates"/>`+
`<replace xmlns='urn:xmpp:message-correct:0' id='${first_msg.get('msgid')}'/>`+ `<replace id="${first_msg.get("msgid")}" xmlns="urn:xmpp:message-correct:0"/>`+
`</message>`); `</message>`);
expect(view.model.messages.models.length).toBe(1); expect(view.model.messages.models.length).toBe(1);
const corrected_message = view.model.messages.at(0); const corrected_message = view.model.messages.at(0);
...@@ -2090,12 +2090,12 @@ ...@@ -2090,12 +2090,12 @@
const msg = _converse.connection.send.calls.all()[0].args[0]; const msg = _converse.connection.send.calls.all()[0].args[0];
expect(msg.toLocaleString()) expect(msg.toLocaleString())
.toBe(`<message from='dummy@localhost/resource' `+ .toBe(`<message from="dummy@localhost/resource" id="${msg.nodeTree.getAttribute("id")}" `+
`to='lounge@localhost' type='groupchat' id='${msg.nodeTree.getAttribute('id')}' `+ `to="lounge@localhost" type="groupchat" `+
`xmlns='jabber:client'>`+ `xmlns="jabber:client">`+
`<body>But soft, what light through yonder window breaks?</body>`+ `<body>But soft, what light through yonder window breaks?</body>`+
`<active xmlns='http://jabber.org/protocol/chatstates'/>`+ `<active xmlns="http://jabber.org/protocol/chatstates"/>`+
`<replace xmlns='urn:xmpp:message-correct:0' id='${first_msg.get('msgid')}'/>`+ `<replace id="${first_msg.get("msgid")}" xmlns="urn:xmpp:message-correct:0"/>`+
`</message>`); `</message>`);
expect(view.model.messages.models.length).toBe(1); expect(view.model.messages.models.length).toBe(1);
...@@ -2291,14 +2291,14 @@ ...@@ -2291,14 +2291,14 @@
view.keyPressed(enter_event); view.keyPressed(enter_event);
const msg = _converse.connection.send.calls.all()[0].args[0]; const msg = _converse.connection.send.calls.all()[0].args[0];
expect(msg.toLocaleString()) expect(msg.toLocaleString())
.toBe(`<message from='dummy@localhost/resource' `+ .toBe(`<message from="dummy@localhost/resource" id="${msg.nodeTree.getAttribute("id")}" `+
`to='lounge@localhost' type='groupchat' id='${msg.nodeTree.getAttribute('id')}' `+ `to="lounge@localhost" type="groupchat" `+
`xmlns='jabber:client'>`+ `xmlns="jabber:client">`+
`<body>hello z3r0 gibson mr.robot, how are you?</body>`+ `<body>hello z3r0 gibson mr.robot, how are you?</body>`+
`<active xmlns='http://jabber.org/protocol/chatstates'/>`+ `<active xmlns="http://jabber.org/protocol/chatstates"/>`+
`<reference xmlns='urn:xmpp:reference:0' begin='18' end='26' type='mention' uri='xmpp:mr.robot@localhost'/>`+ `<reference begin="18" end="26" type="mention" uri="xmpp:mr.robot@localhost" xmlns="urn:xmpp:reference:0"/>`+
`<reference xmlns='urn:xmpp:reference:0' begin='11' end='17' type='mention' uri='xmpp:gibson@localhost'/>`+ `<reference begin="11" end="17" type="mention" uri="xmpp:gibson@localhost" xmlns="urn:xmpp:reference:0"/>`+
`<reference xmlns='urn:xmpp:reference:0' begin='6' end='10' type='mention' uri='xmpp:z3r0@localhost'/>`+ `<reference begin="6" end="10" type="mention" uri="xmpp:z3r0@localhost" xmlns="urn:xmpp:reference:0"/>`+
`</message>`); `</message>`);
const first_msg = view.model.messages.findWhere({'message': 'hello z3r0 gibson mr.robot, how are you?'}); const first_msg = view.model.messages.findWhere({'message': 'hello z3r0 gibson mr.robot, how are you?'});
...@@ -2316,15 +2316,15 @@ ...@@ -2316,15 +2316,15 @@
const correction = _converse.connection.send.calls.all()[1].args[0]; const correction = _converse.connection.send.calls.all()[1].args[0];
expect(correction.toLocaleString()) expect(correction.toLocaleString())
.toBe(`<message from='dummy@localhost/resource' `+ .toBe(`<message from="dummy@localhost/resource" id="${correction.nodeTree.getAttribute("id")}" `+
`to='lounge@localhost' type='groupchat' id='${correction.nodeTree.getAttribute('id')}' `+ `to="lounge@localhost" type="groupchat" `+
`xmlns='jabber:client'>`+ `xmlns="jabber:client">`+
`<body>hello z3r0 gibson sw0rdf1sh, how are you?</body>`+ `<body>hello z3r0 gibson sw0rdf1sh, how are you?</body>`+
`<active xmlns='http://jabber.org/protocol/chatstates'/>`+ `<active xmlns="http://jabber.org/protocol/chatstates"/>`+
`<reference xmlns='urn:xmpp:reference:0' begin='18' end='27' type='mention' uri='xmpp:sw0rdf1sh@localhost'/>`+ `<reference begin="18" end="27" type="mention" uri="xmpp:sw0rdf1sh@localhost" xmlns="urn:xmpp:reference:0"/>`+
`<reference xmlns='urn:xmpp:reference:0' begin='11' end='17' type='mention' uri='xmpp:gibson@localhost'/>`+ `<reference begin="11" end="17" type="mention" uri="xmpp:gibson@localhost" xmlns="urn:xmpp:reference:0"/>`+
`<reference xmlns='urn:xmpp:reference:0' begin='6' end='10' type='mention' uri='xmpp:z3r0@localhost'/>`+ `<reference begin="6" end="10" type="mention" uri="xmpp:z3r0@localhost" xmlns="urn:xmpp:reference:0"/>`+
`<replace xmlns='urn:xmpp:message-correct:0' id='${msg.nodeTree.getAttribute('id')}'/>`+ `<replace id="${msg.nodeTree.getAttribute("id")}" xmlns="urn:xmpp:message-correct:0"/>`+
`</message>`); `</message>`);
done(); done();
}).catch(_.partial(console.error, _)); }).catch(_.partial(console.error, _));
...@@ -2365,14 +2365,14 @@ ...@@ -2365,14 +2365,14 @@
const msg = _converse.connection.send.calls.all()[0].args[0]; const msg = _converse.connection.send.calls.all()[0].args[0];
expect(msg.toLocaleString()) expect(msg.toLocaleString())
.toBe(`<message from='dummy@localhost/resource' `+ .toBe(`<message from="dummy@localhost/resource" id="${msg.nodeTree.getAttribute("id")}" `+
`to='lounge@localhost' type='groupchat' id='${msg.nodeTree.getAttribute('id')}' `+ `to="lounge@localhost" type="groupchat" `+
`xmlns='jabber:client'>`+ `xmlns="jabber:client">`+
`<body>hello z3r0 gibson mr.robot, how are you?</body>`+ `<body>hello z3r0 gibson mr.robot, how are you?</body>`+
`<active xmlns='http://jabber.org/protocol/chatstates'/>`+ `<active xmlns="http://jabber.org/protocol/chatstates"/>`+
`<reference xmlns='urn:xmpp:reference:0' begin='18' end='26' type='mention' uri='xmpp:mr.robot@localhost'/>`+ `<reference begin="18" end="26" type="mention" uri="xmpp:mr.robot@localhost" xmlns="urn:xmpp:reference:0"/>`+
`<reference xmlns='urn:xmpp:reference:0' begin='11' end='17' type='mention' uri='xmpp:gibson@localhost'/>`+ `<reference begin="11" end="17" type="mention" uri="xmpp:gibson@localhost" xmlns="urn:xmpp:reference:0"/>`+
`<reference xmlns='urn:xmpp:reference:0' begin='6' end='10' type='mention' uri='xmpp:z3r0@localhost'/>`+ `<reference begin="6" end="10" type="mention" uri="xmpp:z3r0@localhost" xmlns="urn:xmpp:reference:0"/>`+
`</message>`); `</message>`);
done(); done();
}).catch(_.partial(console.error, _)); }).catch(_.partial(console.error, _));
......
...@@ -183,18 +183,19 @@ ...@@ -183,18 +183,19 @@
return test_utils.waitUntil(() => sent_stanza); return test_utils.waitUntil(() => sent_stanza);
}).then(() => { }).then(() => {
expect(sent_stanza.toLocaleString()).toBe( expect(sent_stanza.toLocaleString()).toBe(
`<message from='dummy@localhost/resource' to='max.frankfurter@localhost' `+ `<message from="dummy@localhost/resource" id="${sent_stanza.nodeTree.getAttribute("id")}" `+
`type='chat' id='${sent_stanza.nodeTree.getAttribute('id')}' xmlns='jabber:client'>`+ `to="max.frankfurter@localhost" `+
`type="chat" xmlns="jabber:client">`+
`<body>This is an OMEMO encrypted message which your client doesn’t seem to support. Find more information on https://conversations.im/omemo</body>`+ `<body>This is an OMEMO encrypted message which your client doesn’t seem to support. Find more information on https://conversations.im/omemo</body>`+
`<encrypted xmlns='eu.siacs.conversations.axolotl'>`+ `<encrypted xmlns="eu.siacs.conversations.axolotl">`+
`<header sid='123456789'>`+ `<header sid="123456789">`+
`<key rid='482886413b977930064a5888b92134fe'>YzFwaDNSNzNYNw==</key>`+ `<key rid="482886413b977930064a5888b92134fe">YzFwaDNSNzNYNw==</key>`+
`<key rid='555'>YzFwaDNSNzNYNw==</key>`+ `<key rid="555">YzFwaDNSNzNYNw==</key>`+
`<iv>${sent_stanza.nodeTree.querySelector('iv').textContent}</iv>`+ `<iv>${sent_stanza.nodeTree.querySelector("iv").textContent}</iv>`+
`</header>`+ `</header>`+
`<payload>${sent_stanza.nodeTree.querySelector('payload').textContent}</payload>`+ `<payload>${sent_stanza.nodeTree.querySelector("payload").textContent}</payload>`+
`</encrypted>`+ `</encrypted>`+
`<store xmlns='urn:xmpp:hints'/>`+ `<store xmlns="urn:xmpp:hints"/>`+
`</message>`); `</message>`);
// Test reception of an encrypted message // Test reception of an encrypted message
...@@ -296,20 +297,20 @@ ...@@ -296,20 +297,20 @@
}).then(() => test_utils.waitUntil(() => bundleHasBeenPublished(_converse))) }).then(() => test_utils.waitUntil(() => bundleHasBeenPublished(_converse)))
.then(iq_stanza => { .then(iq_stanza => {
expect(iq_stanza.toLocaleString()).toBe( expect(iq_stanza.toLocaleString()).toBe(
`<iq from='dummy@localhost' type='set' xmlns='jabber:client' id='${iq_stanza.nodeTree.getAttribute('id')}'>`+ `<iq from="dummy@localhost" id="${iq_stanza.nodeTree.getAttribute("id")}" type="set" xmlns="jabber:client">`+
`<pubsub xmlns='http://jabber.org/protocol/pubsub'>`+ `<pubsub xmlns="http://jabber.org/protocol/pubsub">`+
`<publish node='eu.siacs.conversations.axolotl.bundles:123456789'>`+ `<publish node="eu.siacs.conversations.axolotl.bundles:123456789">`+
`<item>`+ `<item>`+
`<bundle xmlns='eu.siacs.conversations.axolotl'>`+ `<bundle xmlns="eu.siacs.conversations.axolotl">`+
`<signedPreKeyPublic signedPreKeyId='0'>${btoa('1234')}</signedPreKeyPublic>`+ `<signedPreKeyPublic signedPreKeyId="0">${btoa("1234")}</signedPreKeyPublic>`+
`<signedPreKeySignature>${btoa('11112222333344445555')}</signedPreKeySignature>`+ `<signedPreKeySignature>${btoa("11112222333344445555")}</signedPreKeySignature>`+
`<identityKey>${btoa('1234')}</identityKey>`+ `<identityKey>${btoa("1234")}</identityKey>`+
`<prekeys>`+ `<prekeys>`+
`<preKeyPublic preKeyId='0'>${btoa('1234')}</preKeyPublic>`+ `<preKeyPublic preKeyId="0">${btoa("1234")}</preKeyPublic>`+
`<preKeyPublic preKeyId='1'>${btoa('1234')}</preKeyPublic>`+ `<preKeyPublic preKeyId="1">${btoa("1234")}</preKeyPublic>`+
`<preKeyPublic preKeyId='2'>${btoa('1234')}</preKeyPublic>`+ `<preKeyPublic preKeyId="2">${btoa("1234")}</preKeyPublic>`+
`<preKeyPublic preKeyId='3'>${btoa('1234')}</preKeyPublic>`+ `<preKeyPublic preKeyId="3">${btoa("1234")}</preKeyPublic>`+
`<preKeyPublic preKeyId='4'>${btoa('1234')}</preKeyPublic>`+ `<preKeyPublic preKeyId="4">${btoa("1234")}</preKeyPublic>`+
`</prekeys>`+ `</prekeys>`+
`</bundle>`+ `</bundle>`+
`</item>`+ `</item>`+
...@@ -336,9 +337,9 @@ ...@@ -336,9 +337,9 @@
test_utils.waitUntil(() => deviceListFetched(_converse, _converse.bare_jid)) test_utils.waitUntil(() => deviceListFetched(_converse, _converse.bare_jid))
.then(iq_stanza => { .then(iq_stanza => {
expect(iq_stanza.toLocaleString()).toBe( expect(iq_stanza.toLocaleString()).toBe(
`<iq type='get' from='dummy@localhost' to='dummy@localhost' xmlns='jabber:client' id='${iq_stanza.nodeTree.getAttribute('id')}'>`+ `<iq from="dummy@localhost" id="${iq_stanza.nodeTree.getAttribute("id")}" to="dummy@localhost" type="get" xmlns="jabber:client">`+
`<pubsub xmlns='http://jabber.org/protocol/pubsub'>`+ `<pubsub xmlns="http://jabber.org/protocol/pubsub">`+
`<items node='eu.siacs.conversations.axolotl.devicelist'/>`+ `<items node="eu.siacs.conversations.axolotl.devicelist"/>`+
`</pubsub>`+ `</pubsub>`+
`</iq>`); `</iq>`);
...@@ -453,13 +454,13 @@ ...@@ -453,13 +454,13 @@
// Check that our own device is added again, but that removed // Check that our own device is added again, but that removed
// devices are not added. // devices are not added.
expect(iq_stanza.toLocaleString()).toBe( expect(iq_stanza.toLocaleString()).toBe(
`<iq from='dummy@localhost' type='set' xmlns='jabber:client' id='${iq_stanza.nodeTree.getAttribute(`id`)}'>`+ `<iq from="dummy@localhost" id="${iq_stanza.nodeTree.getAttribute(`id`)}" type="set" xmlns="jabber:client">`+
`<pubsub xmlns='http://jabber.org/protocol/pubsub'>`+ `<pubsub xmlns="http://jabber.org/protocol/pubsub">`+
`<publish node='eu.siacs.conversations.axolotl.devicelist'>`+ `<publish node="eu.siacs.conversations.axolotl.devicelist">`+
`<item>`+ `<item>`+
`<list xmlns='eu.siacs.conversations.axolotl'>`+ `<list xmlns="eu.siacs.conversations.axolotl">`+
`<device id='123456789'/>`+ `<device id="123456789"/>`+
`<device id='444'/>`+ `<device id="444"/>`+
`</list>`+ `</list>`+
`</item>`+ `</item>`+
`</publish>`+ `</publish>`+
...@@ -487,9 +488,9 @@ ...@@ -487,9 +488,9 @@
test_utils.waitUntil(() => deviceListFetched(_converse, _converse.bare_jid)) test_utils.waitUntil(() => deviceListFetched(_converse, _converse.bare_jid))
.then(iq_stanza => { .then(iq_stanza => {
expect(iq_stanza.toLocaleString()).toBe( expect(iq_stanza.toLocaleString()).toBe(
`<iq type='get' from='dummy@localhost' to='dummy@localhost' xmlns='jabber:client' id='${iq_stanza.nodeTree.getAttribute('id')}'>`+ `<iq from="dummy@localhost" id="${iq_stanza.nodeTree.getAttribute("id")}" to="dummy@localhost" type="get" xmlns="jabber:client">`+
`<pubsub xmlns='http://jabber.org/protocol/pubsub'>`+ `<pubsub xmlns="http://jabber.org/protocol/pubsub">`+
`<items node='eu.siacs.conversations.axolotl.devicelist'/>`+ `<items node="eu.siacs.conversations.axolotl.devicelist"/>`+
`</pubsub>`+ `</pubsub>`+
`</iq>`); `</iq>`);
...@@ -666,17 +667,17 @@ ...@@ -666,17 +667,17 @@
return test_utils.waitUntil(() => bundleHasBeenPublished(_converse)); return test_utils.waitUntil(() => bundleHasBeenPublished(_converse));
}).then(iq_stanza => { }).then(iq_stanza => {
expect(iq_stanza.toLocaleString()).toBe( expect(iq_stanza.toLocaleString()).toBe(
`<iq from='dummy@localhost' type='set' xmlns='jabber:client' id='${iq_stanza.nodeTree.getAttribute('id')}'>`+ `<iq from="dummy@localhost" id="${iq_stanza.nodeTree.getAttribute("id")}" type="set" xmlns="jabber:client">`+
`<pubsub xmlns='http://jabber.org/protocol/pubsub'>`+ `<pubsub xmlns="http://jabber.org/protocol/pubsub">`+
`<publish node='eu.siacs.conversations.axolotl.bundles:123456789'>`+ `<publish node="eu.siacs.conversations.axolotl.bundles:123456789">`+
`<item>`+ `<item>`+
`<bundle xmlns='eu.siacs.conversations.axolotl'>`+ `<bundle xmlns="eu.siacs.conversations.axolotl">`+
`<signedPreKeyPublic signedPreKeyId='0'>${btoa('1234')}</signedPreKeyPublic>`+ `<signedPreKeyPublic signedPreKeyId="0">${btoa("1234")}</signedPreKeyPublic>`+
`<signedPreKeySignature>${btoa('11112222333344445555')}</signedPreKeySignature>`+ `<signedPreKeySignature>${btoa("11112222333344445555")}</signedPreKeySignature>`+
`<identityKey>${btoa('1234')}</identityKey>`+ `<identityKey>${btoa("1234")}</identityKey>`+
`<prekeys>`+ `<prekeys>`+
`<preKeyPublic preKeyId='0'>${btoa('1234')}</preKeyPublic>`+ `<preKeyPublic preKeyId="0">${btoa("1234")}</preKeyPublic>`+
`<preKeyPublic preKeyId='1'>${btoa('1234')}</preKeyPublic>`+ `<preKeyPublic preKeyId="1">${btoa("1234")}</preKeyPublic>`+
`</prekeys>`+ `</prekeys>`+
`</bundle>`+ `</bundle>`+
`</item>`+ `</item>`+
...@@ -708,9 +709,9 @@ ...@@ -708,9 +709,9 @@
test_utils.waitUntil(() => deviceListFetched(_converse, _converse.bare_jid)) test_utils.waitUntil(() => deviceListFetched(_converse, _converse.bare_jid))
.then(iq_stanza => { .then(iq_stanza => {
expect(iq_stanza.toLocaleString()).toBe( expect(iq_stanza.toLocaleString()).toBe(
`<iq type='get' from='dummy@localhost' to='dummy@localhost' xmlns='jabber:client' id='${iq_stanza.nodeTree.getAttribute('id')}'>`+ `<iq from="dummy@localhost" id="${iq_stanza.nodeTree.getAttribute("id")}" to="dummy@localhost" type="get" xmlns="jabber:client">`+
`<pubsub xmlns='http://jabber.org/protocol/pubsub'>`+ `<pubsub xmlns="http://jabber.org/protocol/pubsub">`+
`<items node='eu.siacs.conversations.axolotl.devicelist'/>`+ `<items node="eu.siacs.conversations.axolotl.devicelist"/>`+
`</pubsub>`+ `</pubsub>`+
`</iq>`); `</iq>`);
...@@ -736,13 +737,13 @@ ...@@ -736,13 +737,13 @@
return test_utils.waitUntil(() => ownDeviceHasBeenPublished(_converse)); return test_utils.waitUntil(() => ownDeviceHasBeenPublished(_converse));
}).then(iq_stanza => { }).then(iq_stanza => {
expect(iq_stanza.toLocaleString()).toBe( expect(iq_stanza.toLocaleString()).toBe(
`<iq from='dummy@localhost' type='set' xmlns='jabber:client' id='${iq_stanza.nodeTree.getAttribute(`id`)}'>`+ `<iq from="dummy@localhost" id="${iq_stanza.nodeTree.getAttribute(`id`)}" type="set" xmlns="jabber:client">`+
`<pubsub xmlns='http://jabber.org/protocol/pubsub'>`+ `<pubsub xmlns="http://jabber.org/protocol/pubsub">`+
`<publish node='eu.siacs.conversations.axolotl.devicelist'>`+ `<publish node="eu.siacs.conversations.axolotl.devicelist">`+
`<item>`+ `<item>`+
`<list xmlns='eu.siacs.conversations.axolotl'>`+ `<list xmlns="eu.siacs.conversations.axolotl">`+
`<device id='482886413b977930064a5888b92134fe'/>`+ `<device id="482886413b977930064a5888b92134fe"/>`+
`<device id='123456789'/>`+ `<device id="123456789"/>`+
`</list>`+ `</list>`+
`</item>`+ `</item>`+
`</publish>`+ `</publish>`+
...@@ -781,9 +782,9 @@ ...@@ -781,9 +782,9 @@
return test_utils.waitUntil(() => deviceListFetched(_converse, contact_jid)); return test_utils.waitUntil(() => deviceListFetched(_converse, contact_jid));
}).then(iq_stanza => { }).then(iq_stanza => {
expect(iq_stanza.toLocaleString()).toBe( expect(iq_stanza.toLocaleString()).toBe(
`<iq type='get' from='dummy@localhost' to='${contact_jid}' xmlns='jabber:client' id='${iq_stanza.nodeTree.getAttribute('id')}'>`+ `<iq from="dummy@localhost" id="${iq_stanza.nodeTree.getAttribute("id")}" to="${contact_jid}" type="get" xmlns="jabber:client">`+
`<pubsub xmlns='http://jabber.org/protocol/pubsub'>`+ `<pubsub xmlns="http://jabber.org/protocol/pubsub">`+
`<items node='eu.siacs.conversations.axolotl.devicelist'/>`+ `<items node="eu.siacs.conversations.axolotl.devicelist"/>`+
`</pubsub>`+ `</pubsub>`+
`</iq>`); `</iq>`);
...@@ -870,8 +871,8 @@ ...@@ -870,8 +871,8 @@
}).then(() => test_utils.waitUntil(() => deviceListFetched(_converse, contact_jid))) }).then(() => test_utils.waitUntil(() => deviceListFetched(_converse, contact_jid)))
.then(iq_stanza => { .then(iq_stanza => {
expect(iq_stanza.toLocaleString()).toBe( expect(iq_stanza.toLocaleString()).toBe(
`<iq type='get' from='dummy@localhost' to='max.frankfurter@localhost' xmlns='jabber:client' id='${iq_stanza.nodeTree.getAttribute('id')}'>`+ `<iq from="dummy@localhost" id="${iq_stanza.nodeTree.getAttribute("id")}" to="max.frankfurter@localhost" type="get" xmlns="jabber:client">`+
`<pubsub xmlns='http://jabber.org/protocol/pubsub'><items node='eu.siacs.conversations.axolotl.devicelist'/></pubsub>`+ `<pubsub xmlns="http://jabber.org/protocol/pubsub"><items node="eu.siacs.conversations.axolotl.devicelist"/></pubsub>`+
`</iq>`); `</iq>`);
const stanza = $iq({ const stanza = $iq({
...@@ -890,9 +891,9 @@ ...@@ -890,9 +891,9 @@
}).then(() => test_utils.waitUntil(() => bundleFetched(_converse, contact_jid, '555'))) }).then(() => test_utils.waitUntil(() => bundleFetched(_converse, contact_jid, '555')))
.then(iq_stanza => { .then(iq_stanza => {
expect(iq_stanza.toLocaleString()).toBe( expect(iq_stanza.toLocaleString()).toBe(
`<iq type='get' from='dummy@localhost' to='max.frankfurter@localhost' xmlns='jabber:client' id='${iq_stanza.nodeTree.getAttribute('id')}'>`+ `<iq from="dummy@localhost" id="${iq_stanza.nodeTree.getAttribute("id")}" to="max.frankfurter@localhost" type="get" xmlns="jabber:client">`+
`<pubsub xmlns='http://jabber.org/protocol/pubsub'>`+ `<pubsub xmlns="http://jabber.org/protocol/pubsub">`+
`<items node='eu.siacs.conversations.axolotl.bundles:555'/>`+ `<items node="eu.siacs.conversations.axolotl.bundles:555"/>`+
`</pubsub>`+ `</pubsub>`+
`</iq>`); `</iq>`);
......
...@@ -44,9 +44,9 @@ ...@@ -44,9 +44,9 @@
}); });
_converse.ping(); _converse.ping();
expect(sent_stanza.toLocaleString()).toBe( expect(sent_stanza.toLocaleString()).toBe(
"<iq type='get' to='localhost' id='"+IQ_id+"' xmlns='jabber:client'>"+ `<iq id="${IQ_id}" to="localhost" type="get" xmlns="jabber:client">`+
"<ping xmlns='urn:xmpp:ping'/>"+ `<ping xmlns="urn:xmpp:ping"/>`+
"</iq>"); `</iq>`);
})); }));
}); });
}); });
......
...@@ -34,42 +34,42 @@ ...@@ -34,42 +34,42 @@
const presence = _converse.xmppstatus.constructPresence(); const presence = _converse.xmppstatus.constructPresence();
expect(presence.toLocaleString()).toBe( expect(presence.toLocaleString()).toBe(
"<presence xmlns='jabber:client'>"+ `<presence xmlns="jabber:client">`+
"<priority>0</priority>"+ `<priority>0</priority>`+
"<c xmlns='http://jabber.org/protocol/caps' hash='sha-1' node='https://conversejs.org' ver='QgayPKawpkPSDYmwT/WM94uAlu0='/>"+ `<c hash="sha-1" node="https://conversejs.org" ver="QgayPKawpkPSDYmwT/WM94uAlu0=" xmlns="http://jabber.org/protocol/caps"/>`+
"</presence>") `</presence>`)
done(); done();
})); }));
it("has a given priority", mock.initConverse(function (_converse) { it("has a given priority", mock.initConverse(function (_converse) {
var pres = _converse.xmppstatus.constructPresence('online', 'Hello world'); var pres = _converse.xmppstatus.constructPresence('online', 'Hello world');
expect(pres.toLocaleString()).toBe( expect(pres.toLocaleString()).toBe(
"<presence xmlns='jabber:client'>"+ `<presence xmlns="jabber:client">`+
"<status>Hello world</status>"+ `<status>Hello world</status>`+
"<priority>0</priority>"+ `<priority>0</priority>`+
"<c xmlns='http://jabber.org/protocol/caps' hash='sha-1' node='https://conversejs.org' ver='K7kn/M6VtmdMyo61pgn/jkZlax8='/>"+ `<c hash="sha-1" node="https://conversejs.org" ver="K7kn/M6VtmdMyo61pgn/jkZlax8=" xmlns="http://jabber.org/protocol/caps"/>`+
"</presence>" `</presence>`
); );
_converse.priority = 2; _converse.priority = 2;
pres = _converse.xmppstatus.constructPresence('away', 'Going jogging'); pres = _converse.xmppstatus.constructPresence('away', 'Going jogging');
expect(pres.toLocaleString()).toBe( expect(pres.toLocaleString()).toBe(
"<presence xmlns='jabber:client'>"+ `<presence xmlns="jabber:client">`+
"<show>away</show>"+ `<show>away</show>`+
"<status>Going jogging</status>"+ `<status>Going jogging</status>`+
"<priority>2</priority>"+ `<priority>2</priority>`+
"<c xmlns='http://jabber.org/protocol/caps' hash='sha-1' node='https://conversejs.org' ver='K7kn/M6VtmdMyo61pgn/jkZlax8='/>"+ `<c hash="sha-1" node="https://conversejs.org" ver="K7kn/M6VtmdMyo61pgn/jkZlax8=" xmlns="http://jabber.org/protocol/caps"/>`+
"</presence>" `</presence>`
); );
delete _converse.priority; delete _converse.priority;
pres = _converse.xmppstatus.constructPresence('dnd', 'Doing taxes'); pres = _converse.xmppstatus.constructPresence('dnd', 'Doing taxes');
expect(pres.toLocaleString()).toBe( expect(pres.toLocaleString()).toBe(
"<presence xmlns='jabber:client'>"+ `<presence xmlns="jabber:client">`+
"<show>dnd</show>"+ `<show>dnd</show>`+
"<status>Doing taxes</status>"+ `<status>Doing taxes</status>`+
"<priority>0</priority>"+ `<priority>0</priority>`+
"<c xmlns='http://jabber.org/protocol/caps' hash='sha-1' node='https://conversejs.org' ver='K7kn/M6VtmdMyo61pgn/jkZlax8='/>"+ `<c hash="sha-1" node="https://conversejs.org" ver="K7kn/M6VtmdMyo61pgn/jkZlax8=" xmlns="http://jabber.org/protocol/caps"/>`+
"</presence>" `</presence>`
); );
})); }));
...@@ -94,27 +94,23 @@ ...@@ -94,27 +94,23 @@
modal.el.querySelector('[type="submit"]').click(); modal.el.querySelector('[type="submit"]').click();
expect(view.model.sendPresence).toHaveBeenCalled(); expect(view.model.sendPresence).toHaveBeenCalled();
expect(_converse.connection.send.calls.mostRecent().args[0].toLocaleString()) expect(_converse.connection.send.calls.mostRecent().args[0].toLocaleString())
.toBe("<presence xmlns='jabber:client'>"+ .toBe(`<presence xmlns="jabber:client">`+
"<status>My custom status</status>"+ `<status>My custom status</status>`+
"<priority>0</priority>"+ `<priority>0</priority>`+
"<c xmlns='http://jabber.org/protocol/caps' hash='sha-1' node='https://conversejs.org' ver='K7kn/M6VtmdMyo61pgn/jkZlax8='/>"+ `<c hash="sha-1" node="https://conversejs.org" ver="K7kn/M6VtmdMyo61pgn/jkZlax8=" xmlns="http://jabber.org/protocol/caps"/>`+
"</presence>") `</presence>`)
return test_utils.waitUntil(function () { return test_utils.waitUntil(() => modal.el.getAttribute('aria-hidden') === "true");
return modal.el.getAttribute('aria-hidden') === "true";
});
}).then(function () { }).then(function () {
cbview.el.querySelector('.change-status').click() cbview.el.querySelector('.change-status').click()
return test_utils.waitUntil(function () { return test_utils.waitUntil(() => modal.el.getAttribute('aria-hidden') === "false", 1000);
return modal.el.getAttribute('aria-hidden') === "false";
}, 1000);
}).then(function () { }).then(function () {
modal.el.querySelector('label[for="radio-busy"]').click(); // Change status to "dnd" modal.el.querySelector('label[for="radio-busy"]').click(); // Change status to "dnd"
modal.el.querySelector('[type="submit"]').click(); modal.el.querySelector('[type="submit"]').click();
expect(_converse.connection.send.calls.mostRecent().args[0].toLocaleString()) expect(_converse.connection.send.calls.mostRecent().args[0].toLocaleString())
.toBe("<presence xmlns='jabber:client'><show>dnd</show><status>My custom status</status><priority>0</priority>"+ .toBe(`<presence xmlns="jabber:client"><show>dnd</show><status>My custom status</status><priority>0</priority>`+
"<c xmlns='http://jabber.org/protocol/caps' hash='sha-1' node='https://conversejs.org' ver='K7kn/M6VtmdMyo61pgn/jkZlax8='/>"+ `<c hash="sha-1" node="https://conversejs.org" ver="K7kn/M6VtmdMyo61pgn/jkZlax8=" xmlns="http://jabber.org/protocol/caps"/>`+
"</presence>") `</presence>`)
done(); done();
}); });
})); }));
......
...@@ -121,11 +121,11 @@ ...@@ -121,11 +121,11 @@
*/ */
expect(_converse.roster.sendContactAddIQ).toHaveBeenCalled(); expect(_converse.roster.sendContactAddIQ).toHaveBeenCalled();
expect(sent_stanza.toLocaleString()).toBe( expect(sent_stanza.toLocaleString()).toBe(
"<iq type='set' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" type="set" xmlns="jabber:client">`+
"<query xmlns='jabber:iq:roster'>"+ `<query xmlns="jabber:iq:roster">`+
"<item jid='contact@example.org' name='contact@example.org'/>"+ `<item jid="contact@example.org" name="contact@example.org"/>`+
"</query>"+ `</query>`+
"</iq>" `</iq>`
); );
/* As a result, the user's server (1) MUST initiate a roster push /* As a result, the user's server (1) MUST initiate a roster push
* for the new roster item to all available resources associated * for the new roster item to all available resources associated
...@@ -185,9 +185,9 @@ ...@@ -185,9 +185,9 @@
}).then(function () { }).then(function () {
expect(contact.subscribe).toHaveBeenCalled(); expect(contact.subscribe).toHaveBeenCalled();
expect(sent_stanza.toLocaleString()).toBe( // Strophe adds the xmlns attr (although not in spec) expect(sent_stanza.toLocaleString()).toBe( // Strophe adds the xmlns attr (although not in spec)
"<presence to='contact@example.org' type='subscribe' xmlns='jabber:client'>"+ `<presence to="contact@example.org" type="subscribe" xmlns="jabber:client">`+
"<nick xmlns='http://jabber.org/protocol/nick'>Max Mustermann</nick>"+ `<nick xmlns="http://jabber.org/protocol/nick">Max Mustermann</nick>`+
"</presence>" `</presence>`
); );
/* As a result, the user's server MUST initiate a second roster /* As a result, the user's server MUST initiate a second roster
* push to all of the user's available resources that have * push to all of the user's available resources that have
...@@ -254,7 +254,7 @@ ...@@ -254,7 +254,7 @@
*/ */
expect(contact.ackSubscribe).toHaveBeenCalled(); expect(contact.ackSubscribe).toHaveBeenCalled();
expect(sent_stanza.toLocaleString()).toBe( // Strophe adds the xmlns attr (although not in spec) expect(sent_stanza.toLocaleString()).toBe( // Strophe adds the xmlns attr (although not in spec)
"<presence type='subscribe' to='contact@example.org' xmlns='jabber:client'/>" `<presence to="contact@example.org" type="subscribe" xmlns="jabber:client"/>`
); );
/* The user's server MUST initiate a roster push to all of the user's /* The user's server MUST initiate a roster push to all of the user's
...@@ -283,7 +283,7 @@ ...@@ -283,7 +283,7 @@
_converse.connection._dataRecv(test_utils.createRequest(stanza)); _converse.connection._dataRecv(test_utils.createRequest(stanza));
// Check that the IQ set was acknowledged. // Check that the IQ set was acknowledged.
expect(sent_stanza.toLocaleString()).toBe( // Strophe adds the xmlns attr (although not in spec) expect(sent_stanza.toLocaleString()).toBe( // Strophe adds the xmlns attr (although not in spec)
"<iq type='result' id='"+IQ_id+"' from='dummy@localhost/resource' xmlns='jabber:client'/>" `<iq from="dummy@localhost/resource" id="${IQ_id}" type="result" xmlns="jabber:client"/>`
); );
expect(_converse.roster.updateContact).toHaveBeenCalled(); expect(_converse.roster.updateContact).toHaveBeenCalled();
...@@ -341,7 +341,7 @@ ...@@ -341,7 +341,7 @@
*/ */
expect(contact.authorize).toHaveBeenCalled(); expect(contact.authorize).toHaveBeenCalled();
expect(sent_stanza.toLocaleString()).toBe( expect(sent_stanza.toLocaleString()).toBe(
"<presence to='contact@example.org' type='subscribed' xmlns='jabber:client'/>" `<presence to="contact@example.org" type="subscribed" xmlns="jabber:client"/>`
); );
/* As a result, the user's server MUST initiate a /* As a result, the user's server MUST initiate a
...@@ -446,18 +446,18 @@ ...@@ -446,18 +446,18 @@
*/ */
expect(contact.ackUnsubscribe).toHaveBeenCalled(); expect(contact.ackUnsubscribe).toHaveBeenCalled();
expect(sent_stanza.toLocaleString()).toBe( expect(sent_stanza.toLocaleString()).toBe(
"<presence type='unsubscribe' to='contact@example.org' xmlns='jabber:client'/>" `<presence to="contact@example.org" type="unsubscribe" xmlns="jabber:client"/>`
); );
/* _converse.js will then also automatically remove the /* _converse.js will then also automatically remove the
* contact from the user's roster. * contact from the user's roster.
*/ */
expect(sent_IQ.toLocaleString()).toBe( expect(sent_IQ.toLocaleString()).toBe(
"<iq type='set' xmlns='jabber:client'>"+ `<iq type="set" xmlns="jabber:client">`+
"<query xmlns='jabber:iq:roster'>"+ `<query xmlns="jabber:iq:roster">`+
"<item jid='contact@example.org' subscription='remove'/>"+ `<item jid="contact@example.org" subscription="remove"/>`+
"</query>"+ `</query>`+
"</iq>" `</iq>`
); );
done(); done();
})); }));
...@@ -511,11 +511,11 @@ ...@@ -511,11 +511,11 @@
* </iq> * </iq>
*/ */
expect(sent_IQ.toLocaleString()).toBe( expect(sent_IQ.toLocaleString()).toBe(
"<iq type='set' xmlns='jabber:client' id='"+IQ_id+"'>"+ `<iq id="${IQ_id}" type="set" xmlns="jabber:client">`+
"<query xmlns='jabber:iq:roster'>"+ `<query xmlns="jabber:iq:roster">`+
"<item jid='annegreet.gomez@localhost' subscription='remove'/>"+ `<item jid="annegreet.gomez@localhost" subscription="remove"/>`+
"</query>"+ `</query>`+
"</iq>"); `</iq>`);
// Receive confirmation from the contact's server // Receive confirmation from the contact's server
// <iq type='result' id='remove1'/> // <iq type='result' id='remove1'/>
......
...@@ -33,19 +33,14 @@ ...@@ -33,19 +33,14 @@
[{'category': 'account', 'type':'registered'}], [{'category': 'account', 'type':'registered'}],
['urn:xmpp:push:0'], [], 'info')) ['urn:xmpp:push:0'], [], 'info'))
.then(() => { .then(() => {
return test_utils.waitUntil(() => { return test_utils.waitUntil(() =>
const node = _.filter(IQ_stanzas, function (iq) { _.filter(IQ_stanzas, iq => iq.nodeTree.querySelector('iq[type="set"] enable[xmlns="urn:xmpp:push:0"]')).pop()
return iq.nodeTree.querySelector('iq[type="set"] enable[xmlns="urn:xmpp:push:0"]'); )
}).pop(); }).then(node => {
if (node) { const stanza = node.nodeTree;
stanza = node.nodeTree; expect(node.toLocaleString()).toEqual(
return true; `<iq id="${stanza.getAttribute('id')}" type="set" xmlns="jabber:client">`+
} '<enable jid="push-5@client.example" node="yxs32uqsflafdk3iuqo" xmlns="urn:xmpp:push:0"/>'+
})
}).then(() => {
expect(stanza.outerHTML).toEqual(
`<iq type="set" xmlns="jabber:client" id="${stanza.getAttribute('id')}">`+
'<enable xmlns="urn:xmpp:push:0" jid="push-5@client.example" node="yxs32uqsflafdk3iuqo"/>'+
'</iq>' '</iq>'
) )
_converse.connection._dataRecv(test_utils.createRequest($iq({ _converse.connection._dataRecv(test_utils.createRequest($iq({
...@@ -85,9 +80,9 @@ ...@@ -85,9 +80,9 @@
return test_utils.waitUntil( return test_utils.waitUntil(
() => _.filter(IQ_stanzas, (iq) => iq.nodeTree.querySelector('iq[type="set"] enable[xmlns="urn:xmpp:push:0"]')).pop()) () => _.filter(IQ_stanzas, (iq) => iq.nodeTree.querySelector('iq[type="set"] enable[xmlns="urn:xmpp:push:0"]')).pop())
}).then(stanza => { }).then(stanza => {
expect(stanza.nodeTree.outerHTML).toEqual( expect(stanza.toLocaleString()).toEqual(
`<iq type="set" xmlns="jabber:client" to="chat.shakespeare.lit" id="${stanza.nodeTree.getAttribute('id')}">`+ `<iq id="${stanza.nodeTree.getAttribute('id')}" to="chat.shakespeare.lit" type="set" xmlns="jabber:client">`+
'<enable xmlns="urn:xmpp:push:0" jid="push-5@client.example" node="yxs32uqsflafdk3iuqo"/>'+ '<enable jid="push-5@client.example" node="yxs32uqsflafdk3iuqo" xmlns="urn:xmpp:push:0"/>'+
'</iq>' '</iq>'
) )
_converse.connection._dataRecv(test_utils.createRequest($iq({ _converse.connection._dataRecv(test_utils.createRequest($iq({
...@@ -111,7 +106,6 @@ ...@@ -111,7 +106,6 @@
const IQ_stanzas = _converse.connection.IQ_stanzas; const IQ_stanzas = _converse.connection.IQ_stanzas;
let stanza; let stanza;
expect(_converse.session.get('push_enabled')).toBeFalsy(); expect(_converse.session.get('push_enabled')).toBeFalsy();
test_utils.waitUntilDiscoConfirmed( test_utils.waitUntilDiscoConfirmed(
...@@ -119,20 +113,13 @@ ...@@ -119,20 +113,13 @@
_converse.bare_jid, _converse.bare_jid,
[{'category': 'account', 'type':'registered'}], [{'category': 'account', 'type':'registered'}],
['urn:xmpp:push:0'], [], 'info') ['urn:xmpp:push:0'], [], 'info')
.then(() => { .then(() => test_utils.waitUntil(
return test_utils.waitUntil(() => { () => _.filter(IQ_stanzas, iq => iq.nodeTree.querySelector('iq[type="set"] disable[xmlns="urn:xmpp:push:0"]')).pop()
const node = _.filter(IQ_stanzas, function (iq) { )).then(node => {
return iq.nodeTree.querySelector('iq[type="set"] disable[xmlns="urn:xmpp:push:0"]'); const stanza = node.nodeTree;
}).pop(); expect(node.toLocaleString()).toEqual(
if (node) { `<iq id="${stanza.getAttribute('id')}" type="set" xmlns="jabber:client">`+
stanza = node.nodeTree; '<disable jid="push-5@client.example" node="yxs32uqsflafdk3iuqo" xmlns="urn:xmpp:push:0"/>'+
return true;
}
})
}).then(() => {
expect(stanza.outerHTML).toEqual(
`<iq type="set" xmlns="jabber:client" id="${stanza.getAttribute('id')}">`+
'<disable xmlns="urn:xmpp:push:0" jid="push-5@client.example" node="yxs32uqsflafdk3iuqo"/>'+
'</iq>' '</iq>'
) )
_converse.connection._dataRecv(test_utils.createRequest($iq({ _converse.connection._dataRecv(test_utils.createRequest($iq({
...@@ -168,21 +155,14 @@ ...@@ -168,21 +155,14 @@
_converse.bare_jid, _converse.bare_jid,
[{'category': 'account', 'type':'registered'}], [{'category': 'account', 'type':'registered'}],
['urn:xmpp:push:0'], [], 'info')) ['urn:xmpp:push:0'], [], 'info'))
.then(() => { .then(() => test_utils.waitUntil(
return test_utils.waitUntil(() => { () => _.filter(IQ_stanzas, iq => iq.nodeTree.querySelector('iq[type="set"] enable[xmlns="urn:xmpp:push:0"]')).pop()
const node = _.filter(IQ_stanzas, function (iq) { )).then(node => {
return iq.nodeTree.querySelector('iq[type="set"] enable[xmlns="urn:xmpp:push:0"]'); const stanza = node.nodeTree;
}).pop(); expect(node.toLocaleString()).toEqual(
if (node) { `<iq id="${stanza.getAttribute('id')}" type="set" xmlns="jabber:client">`+
stanza = node.nodeTree; '<enable jid="push-5@client.example" node="yxs32uqsflafdk3iuqo" xmlns="urn:xmpp:push:0">'+
return true; '<x type="submit" xmlns="jabber:x:data">'+
}
})
}).then(() => {
expect(stanza.outerHTML).toEqual(
`<iq type="set" xmlns="jabber:client" id="${stanza.getAttribute('id')}">`+
'<enable xmlns="urn:xmpp:push:0" jid="push-5@client.example" node="yxs32uqsflafdk3iuqo">'+
'<x xmlns="jabber:x:data" type="submit">'+
'<field var="FORM_TYPE"><value>http://jabber.org/protocol/pubsub#publish-options</value></field>'+ '<field var="FORM_TYPE"><value>http://jabber.org/protocol/pubsub#publish-options</value></field>'+
'<field var="secret"><value>eruio234vzxc2kla-91</value></field>'+ '<field var="secret"><value>eruio234vzxc2kla-91</value></field>'+
'</x>'+ '</x>'+
......
...@@ -265,17 +265,17 @@ ...@@ -265,17 +265,17 @@
expect(_converse.connection.send).toHaveBeenCalled(); expect(_converse.connection.send).toHaveBeenCalled();
stanza = _converse.connection.send.calls.argsFor(0)[0].tree(); stanza = _converse.connection.send.calls.argsFor(0)[0].tree();
expect(stanza.outerHTML.trim().replace(/(\n|\s{2,})/g, '')).toEqual( expect(Strophe.serialize(stanza).toLocaleString().trim().replace(/(\n|\s{2,})/g, '')).toEqual(
'<iq type="set" id="'+stanza.getAttribute('id')+'" xmlns="jabber:client">'+ '<iq id="'+stanza.getAttribute('id')+'" type="set" xmlns="jabber:client">'+
'<query xmlns="jabber:iq:register">'+ '<query xmlns="jabber:iq:register">'+
'<x xmlns="jabber:x:data" type="submit">'+ '<x type="submit" xmlns="jabber:x:data">'+
'<field xmlns="http://www.w3.org/1999/xhtml" var="username">'+ '<field var="username">'+
'<value>testusername</value>'+ '<value>testusername</value>'+
'</field>'+ '</field>'+
'<field xmlns="http://www.w3.org/1999/xhtml" var="password">'+ '<field var="password">'+
'<value>testpassword</value>'+ '<value>testpassword</value>'+
'</field>'+ '</field>'+
'<field xmlns="http://www.w3.org/1999/xhtml" var="email">'+ '<field var="email">'+
'<value>test@email.local</value>'+ '<value>test@email.local</value>'+
'</field>'+ '</field>'+
'</x>'+ '</x>'+
......
...@@ -30,14 +30,15 @@ ...@@ -30,14 +30,15 @@
preventDefault: _.noop, preventDefault: _.noop,
keyCode: 13 keyCode: 13
}); });
return test_utils.waitUntil(() => _.get(_.filter( return test_utils.waitUntil(() => _.filter(
_converse.connection.IQ_stanzas, _converse.connection.IQ_stanzas,
iq => sizzle(`iq[to="coven@chat.shakespeare.lit"][type="get"] query[xmlns="jabber:iq:register"]`, iq.nodeTree).length iq => sizzle(`iq[to="coven@chat.shakespeare.lit"][type="get"] query[xmlns="jabber:iq:register"]`, iq.nodeTree).length
).pop(), 'nodeTree')); ).pop());
}).then(stanza => { }).then(node => {
expect(stanza.outerHTML) const stanza = node.nodeTree;
.toBe(`<iq to="coven@chat.shakespeare.lit" from="dummy@localhost/resource" `+ expect(node.toLocaleString())
`type="get" xmlns="jabber:client" id="${stanza.getAttribute('id')}">`+ .toBe(`<iq from="dummy@localhost/resource" id="${stanza.getAttribute('id')}" to="coven@chat.shakespeare.lit" `+
`type="get" xmlns="jabber:client">`+
`<query xmlns="jabber:iq:register"/></iq>`); `<query xmlns="jabber:iq:register"/></iq>`);
view = _converse.chatboxviews.get(room_jid); view = _converse.chatboxviews.get(room_jid);
const result = $iq({ const result = $iq({
...@@ -53,15 +54,16 @@ ...@@ -53,15 +54,16 @@
'var': 'muc#register_roomnick' 'var': 'muc#register_roomnick'
}).c('required'); }).c('required');
_converse.connection._dataRecv(test_utils.createRequest(result)); _converse.connection._dataRecv(test_utils.createRequest(result));
return test_utils.waitUntil(() => _.get(_.filter( return test_utils.waitUntil(() => _.filter(
_converse.connection.IQ_stanzas, _converse.connection.IQ_stanzas,
iq => sizzle(`iq[to="coven@chat.shakespeare.lit"][type="set"] query[xmlns="jabber:iq:register"]`, iq.nodeTree).length iq => sizzle(`iq[to="coven@chat.shakespeare.lit"][type="set"] query[xmlns="jabber:iq:register"]`, iq.nodeTree).length
).pop(), 'nodeTree')); ).pop());
}).then(stanza => { }).then(node => {
expect(stanza.outerHTML).toBe( const stanza = node.nodeTree;
`<iq to="coven@chat.shakespeare.lit" from="dummy@localhost/resource" type="set" xmlns="jabber:client" id="${stanza.getAttribute('id')}">`+ expect(node.toLocaleString()).toBe(
`<iq from="dummy@localhost/resource" id="${stanza.getAttribute('id')}" to="coven@chat.shakespeare.lit" type="set" xmlns="jabber:client">`+
`<query xmlns="jabber:iq:register">`+ `<query xmlns="jabber:iq:register">`+
`<x xmlns="jabber:x:data" type="submit">`+ `<x type="submit" xmlns="jabber:x:data">`+
`<field var="FORM_TYPE"><value>http://jabber.org/protocol/muc#register</value></field>`+ `<field var="FORM_TYPE"><value>http://jabber.org/protocol/muc#register</value></field>`+
`<field var="muc#register_roomnick"><value>romeo</value></field>`+ `<field var="muc#register_roomnick"><value>romeo</value></field>`+
`</x>`+ `</x>`+
...@@ -123,14 +125,15 @@ ...@@ -123,14 +125,15 @@
}).up() }).up()
.c('status').attrs({code:'110'}); .c('status').attrs({code:'110'});
_converse.connection._dataRecv(test_utils.createRequest(presence)); _converse.connection._dataRecv(test_utils.createRequest(presence));
return test_utils.waitUntil(() => _.get(_.filter( return test_utils.waitUntil(() => _.filter(
_converse.connection.IQ_stanzas, _converse.connection.IQ_stanzas,
iq => sizzle(`iq[to="coven@chat.shakespeare.lit"][type="get"] query[xmlns="jabber:iq:register"]`, iq.nodeTree).length iq => sizzle(`iq[to="coven@chat.shakespeare.lit"][type="get"] query[xmlns="jabber:iq:register"]`, iq.nodeTree).length
).pop(), 'nodeTree')); ).pop());
}).then(stanza => { }).then(node => {
expect(stanza.outerHTML) const stanza = node.nodeTree;
.toBe(`<iq to="coven@chat.shakespeare.lit" from="dummy@localhost/resource" `+ expect(node.toLocaleString())
`type="get" xmlns="jabber:client" id="${stanza.getAttribute('id')}">`+ .toBe(`<iq from="dummy@localhost/resource" id="${stanza.getAttribute('id')}" to="coven@chat.shakespeare.lit" `+
`type="get" xmlns="jabber:client">`+
`<query xmlns="jabber:iq:register"/></iq>`); `<query xmlns="jabber:iq:register"/></iq>`);
view = _converse.chatboxviews.get(room_jid); view = _converse.chatboxviews.get(room_jid);
const result = $iq({ const result = $iq({
...@@ -146,15 +149,16 @@ ...@@ -146,15 +149,16 @@
'var': 'muc#register_roomnick' 'var': 'muc#register_roomnick'
}).c('required'); }).c('required');
_converse.connection._dataRecv(test_utils.createRequest(result)); _converse.connection._dataRecv(test_utils.createRequest(result));
return test_utils.waitUntil(() => _.get(_.filter( return test_utils.waitUntil(() => _.filter(
_converse.connection.IQ_stanzas, _converse.connection.IQ_stanzas,
iq => sizzle(`iq[to="coven@chat.shakespeare.lit"][type="set"] query[xmlns="jabber:iq:register"]`, iq.nodeTree).length iq => sizzle(`iq[to="coven@chat.shakespeare.lit"][type="set"] query[xmlns="jabber:iq:register"]`, iq.nodeTree).length
).pop(), 'nodeTree')); ).pop());
}).then(stanza => { }).then(node => {
expect(stanza.outerHTML).toBe( const stanza = node.nodeTree;
`<iq to="coven@chat.shakespeare.lit" from="dummy@localhost/resource" type="set" xmlns="jabber:client" id="${stanza.getAttribute('id')}">`+ expect(node.toLocaleString()).toBe(
`<iq from="dummy@localhost/resource" id="${stanza.getAttribute('id')}" to="coven@chat.shakespeare.lit" type="set" xmlns="jabber:client">`+
`<query xmlns="jabber:iq:register">`+ `<query xmlns="jabber:iq:register">`+
`<x xmlns="jabber:x:data" type="submit">`+ `<x type="submit" xmlns="jabber:x:data">`+
`<field var="FORM_TYPE"><value>http://jabber.org/protocol/muc#register</value></field>`+ `<field var="FORM_TYPE"><value>http://jabber.org/protocol/muc#register</value></field>`+
`<field var="muc#register_roomnick"><value>romeo</value></field>`+ `<field var="muc#register_roomnick"><value>romeo</value></field>`+
`</x>`+ `</x>`+
......
...@@ -40,21 +40,14 @@ ...@@ -40,21 +40,14 @@
null, ['rosterGroupsFetched'], {}, null, ['rosterGroupsFetched'], {},
function (done, _converse) { function (done, _converse) {
var IQ_stanzas = _converse.connection.IQ_stanzas; const IQ_stanzas = _converse.connection.IQ_stanzas;
var stanza; test_utils.waitUntil(
() => _.filter(IQ_stanzas, iq => iq.nodeTree.querySelector('iq query[xmlns="jabber:iq:roster"]')).pop()
test_utils.waitUntil(() => { ).then(node => {
const node = _.filter(IQ_stanzas, function (iq) { let stanza = node.nodeTree;
return iq.nodeTree.querySelector('iq query[xmlns="jabber:iq:roster"]');
}).pop();
if (node) {
stanza = node.nodeTree;
return true;
}
}).then(() => {
expect(_converse.roster.data.get('version')).toBeUndefined(); expect(_converse.roster.data.get('version')).toBeUndefined();
expect(stanza.outerHTML).toBe( expect(node.toLocaleString()).toBe(
`<iq type="get" id="${stanza.getAttribute('id')}" xmlns="jabber:client">`+ `<iq id="${stanza.getAttribute('id')}" type="get" xmlns="jabber:client">`+
`<query xmlns="jabber:iq:roster"/>`+ `<query xmlns="jabber:iq:roster"/>`+
`</iq>`); `</iq>`);
let result = $iq({ let result = $iq({
...@@ -71,10 +64,11 @@ ...@@ -71,10 +64,11 @@
expect(_converse.roster.models.length).toBe(2); expect(_converse.roster.models.length).toBe(2);
_converse.roster.fetchFromServer(); _converse.roster.fetchFromServer();
stanza = _converse.connection.IQ_stanzas.pop().nodeTree; node = _converse.connection.IQ_stanzas.pop();
expect(stanza.outerHTML).toBe( stanza = node.nodeTree;
`<iq type="get" id="${stanza.getAttribute('id')}" xmlns="jabber:client">`+ expect(node.toLocaleString()).toBe(
`<query xmlns="jabber:iq:roster" ver="ver7"/>`+ `<iq id="${stanza.getAttribute('id')}" type="get" xmlns="jabber:client">`+
`<query ver="ver7" xmlns="jabber:iq:roster"/>`+
`</iq>`); `</iq>`);
result = $iq({ result = $iq({
...@@ -656,11 +650,11 @@ ...@@ -656,11 +650,11 @@
expect(window.confirm).toHaveBeenCalled(); expect(window.confirm).toHaveBeenCalled();
expect(contact.removeFromRoster).toHaveBeenCalled(); expect(contact.removeFromRoster).toHaveBeenCalled();
expect(sent_IQ.toLocaleString()).toBe( expect(sent_IQ.toLocaleString()).toBe(
"<iq type='set' xmlns='jabber:client'>"+ `<iq type="set" xmlns="jabber:client">`+
"<query xmlns='jabber:iq:roster'>"+ `<query xmlns="jabber:iq:roster">`+
"<item jid='suleyman.van.beusichem@localhost' subscription='remove'/>"+ `<item jid="suleyman.van.beusichem@localhost" subscription="remove"/>`+
"</query>"+ `</query>`+
"</iq>"); `</iq>`);
done(); done();
}); });
})); }));
...@@ -851,9 +845,9 @@ ...@@ -851,9 +845,9 @@
expect(window.confirm).toHaveBeenCalled(); expect(window.confirm).toHaveBeenCalled();
expect(sent_IQ.toLocaleString()).toBe( expect(sent_IQ.toLocaleString()).toBe(
"<iq type='set' xmlns='jabber:client'>"+ `<iq type="set" xmlns="jabber:client">`+
"<query xmlns='jabber:iq:roster'><item jid='max.frankfurter@localhost' subscription='remove'/></query>"+ `<query xmlns="jabber:iq:roster"><item jid="max.frankfurter@localhost" subscription="remove"/></query>`+
"</iq>"); `</iq>`);
expect(contact.removeFromRoster).toHaveBeenCalled(); expect(contact.removeFromRoster).toHaveBeenCalled();
expect($(_converse.rosterview.el).find(".open-chat:contains('"+name+"')").length).toEqual(0); expect($(_converse.rosterview.el).find(".open-chat:contains('"+name+"')").length).toEqual(0);
done(); done();
......
...@@ -69,19 +69,9 @@ ...@@ -69,19 +69,9 @@
dependencies: ["converse-chatboxes", "converse-disco", "converse-controlbox"], dependencies: ["converse-chatboxes", "converse-disco", "converse-controlbox"],
overrides: { overrides: {
// Overrides mentioned here will be picked up by converse.js's
// plugin architecture they will replace existing methods on the
// relevant objects or classes.
//
// New functions which don't exist yet can also be added.
tearDown () { tearDown () {
const { _converse } = this.__super__, const groupchats = this.chatboxes.where({'type': this.CHATROOMS_TYPE});
groupchats = this.chatboxes.where({'type': _converse.CHATROOMS_TYPE}); _.each(groupchats, gc => u.safeSave(gc, {'connection_status': this.ROOMSTATUS.DISCONNECTED}));
_.each(groupchats, function (groupchat) {
u.safeSave(groupchat, {'connection_status': converse.ROOMSTATUS.DISCONNECTED});
});
this.__super__.tearDown.call(this, arguments); this.__super__.tearDown.call(this, arguments);
}, },
......
...@@ -106,7 +106,7 @@ const config = { ...@@ -106,7 +106,7 @@ const config = {
"snabbdom-eventlisteners": path.resolve(__dirname, "node_modules/snabbdom/dist/snabbdom-eventlisteners"), "snabbdom-eventlisteners": path.resolve(__dirname, "node_modules/snabbdom/dist/snabbdom-eventlisteners"),
"snabbdom-props": path.resolve(__dirname, "node_modules/snabbdom/dist/snabbdom-props"), "snabbdom-props": path.resolve(__dirname, "node_modules/snabbdom/dist/snabbdom-props"),
"snabbdom-style": path.resolve(__dirname, "node_modules/snabbdom/dist/snabbdom-style"), "snabbdom-style": path.resolve(__dirname, "node_modules/snabbdom/dist/snabbdom-style"),
"strophe": path.resolve(__dirname, "node_modules/strophe.js/strophe"), "strophe": path.resolve(__dirname, "node_modules/strophe.js/dist/strophe"),
"strophe.ping": path.resolve(__dirname, "node_modules/strophejs-plugin-ping/strophe.ping"), "strophe.ping": path.resolve(__dirname, "node_modules/strophejs-plugin-ping/strophe.ping"),
"strophe.rsm": path.resolve(__dirname, "node_modules/strophejs-plugin-rsm/strophe.rsm"), "strophe.rsm": path.resolve(__dirname, "node_modules/strophejs-plugin-rsm/strophe.rsm"),
"tovnode": path.resolve(__dirname, "node_modules/snabbdom/dist/tovnode"), "tovnode": path.resolve(__dirname, "node_modules/snabbdom/dist/tovnode"),
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment