|
@@ -268,224 +268,210 @@
|
|
|
|
|
|
describe("when clicked and a file chosen", function () {
|
|
|
|
|
|
- it("is uploaded and sent out", mock.initConverseWithAsync(function (done, _converse) {
|
|
|
- test_utils.waitUntilDiscoConfirmed(
|
|
|
+ it("is uploaded and sent out", mock.initConverseWithAsync(
|
|
|
+ async function (done, _converse) {
|
|
|
+
|
|
|
+ await test_utils.waitUntilDiscoConfirmed(
|
|
|
_converse, _converse.domain,
|
|
|
[{'category': 'server', 'type':'IM'}],
|
|
|
- ['http://jabber.org/protocol/disco#items'], [], 'info').then(function () {
|
|
|
+ ['http://jabber.org/protocol/disco#items'], [], 'info');
|
|
|
|
|
|
- var send_backup = XMLHttpRequest.prototype.send;
|
|
|
- var IQ_stanzas = _converse.connection.IQ_stanzas;
|
|
|
- let contact_jid;
|
|
|
+ const send_backup = XMLHttpRequest.prototype.send;
|
|
|
+ const IQ_stanzas = _converse.connection.IQ_stanzas;
|
|
|
+
|
|
|
+ await test_utils.waitUntilDiscoConfirmed(_converse, _converse.domain, [], [], ['upload.montague.tld'], 'items');
|
|
|
+ await test_utils.waitUntilDiscoConfirmed(_converse, 'upload.montague.tld', [], [Strophe.NS.HTTPUPLOAD], []);
|
|
|
+ test_utils.createContacts(_converse, 'current');
|
|
|
+ _converse.emit('rosterContactsFetched');
|
|
|
+ const contact_jid = mock.cur_names[2].replace(/ /g,'.').toLowerCase() + '@localhost';
|
|
|
+ await test_utils.openChatBoxFor(_converse, contact_jid);
|
|
|
+ const view = _converse.chatboxviews.get(contact_jid);
|
|
|
+ const file = {
|
|
|
+ 'type': 'image/jpeg',
|
|
|
+ 'size': '23456' ,
|
|
|
+ 'lastModifiedDate': "",
|
|
|
+ 'name': "my-juliet.jpg"
|
|
|
+ };
|
|
|
+ view.model.sendFiles([file]);
|
|
|
+ await new Promise((resolve, reject) => view.once('messageInserted', resolve));
|
|
|
+
|
|
|
+ await test_utils.waitUntil(() => _.filter(IQ_stanzas, iq => iq.nodeTree.querySelector('iq[to="upload.montague.tld"] request')).length);
|
|
|
+ var iq = IQ_stanzas.pop();
|
|
|
+ expect(iq.toLocaleString()).toBe(
|
|
|
+ `<iq from="dummy@localhost/resource" `+
|
|
|
+ `id="${iq.nodeTree.getAttribute("id")}" `+
|
|
|
+ `to="upload.montague.tld" `+
|
|
|
+ `type="get" `+
|
|
|
+ `xmlns="jabber:client">`+
|
|
|
+ `<request `+
|
|
|
+ `content-type="image/jpeg" `+
|
|
|
+ `filename="my-juliet.jpg" `+
|
|
|
+ `size="23456" `+
|
|
|
+ `xmlns="urn:xmpp:http:upload:0"/>`+
|
|
|
+ `</iq>`);
|
|
|
|
|
|
- test_utils.waitUntilDiscoConfirmed(_converse, _converse.domain, [], [], ['upload.montague.tld'], 'items')
|
|
|
- .then(() => test_utils.waitUntilDiscoConfirmed(_converse, 'upload.montague.tld', [], [Strophe.NS.HTTPUPLOAD], []))
|
|
|
+ var base_url = document.URL.split(window.location.pathname)[0];
|
|
|
+ var message = base_url+"/logo/conversejs-filled.svg";
|
|
|
+
|
|
|
+ var stanza = Strophe.xmlHtmlNode(
|
|
|
+ "<iq from='upload.montague.tld'"+
|
|
|
+ " id='"+iq.nodeTree.getAttribute('id')+"'"+
|
|
|
+ " to='dummy@localhost/resource'"+
|
|
|
+ " type='result'>"+
|
|
|
+ "<slot xmlns='urn:xmpp:http:upload:0'>"+
|
|
|
+ " <put url='https://upload.montague.tld/4a771ac1-f0b2-4a4a-9700-f2a26fa2bb67/my-juliet.jpg'>"+
|
|
|
+ " <header name='Authorization'>Basic Base64String==</header>"+
|
|
|
+ " <header name='Cookie'>foo=bar; user=romeo</header>"+
|
|
|
+ " </put>"+
|
|
|
+ " <get url='"+message+"' />"+
|
|
|
+ "</slot>"+
|
|
|
+ "</iq>").firstElementChild;
|
|
|
+
|
|
|
+ spyOn(XMLHttpRequest.prototype, 'send').and.callFake(function () {
|
|
|
+ const message = view.model.messages.at(0);
|
|
|
+ expect(view.el.querySelector('.chat-content progress').getAttribute('value')).toBe('0');
|
|
|
+ message.set('progress', 0.5);
|
|
|
+ test_utils.waitUntil(() => view.el.querySelector('.chat-content progress').getAttribute('value') === '0.5')
|
|
|
.then(() => {
|
|
|
- test_utils.createContacts(_converse, 'current');
|
|
|
- _converse.emit('rosterContactsFetched');
|
|
|
- contact_jid = mock.cur_names[2].replace(/ /g,'.').toLowerCase() + '@localhost';
|
|
|
- return test_utils.openChatBoxFor(_converse, contact_jid);
|
|
|
+ message.set('progress', 1);
|
|
|
+ test_utils.waitUntil(() => view.el.querySelector('.chat-content progress').getAttribute('value') === '1')
|
|
|
}).then(() => {
|
|
|
- var view = _converse.chatboxviews.get(contact_jid);
|
|
|
- var file = {
|
|
|
- 'type': 'image/jpeg',
|
|
|
- 'size': '23456' ,
|
|
|
- 'lastModifiedDate': "",
|
|
|
- 'name': "my-juliet.jpg"
|
|
|
- };
|
|
|
- view.model.sendFiles([file]);
|
|
|
- return test_utils.waitUntil(function () {
|
|
|
- return _.filter(IQ_stanzas, function (iq) {
|
|
|
- return iq.nodeTree.querySelector('iq[to="upload.montague.tld"] request');
|
|
|
- }).length > 0;
|
|
|
- }).then(function () {
|
|
|
- var iq = IQ_stanzas.pop();
|
|
|
- expect(iq.toLocaleString()).toBe(
|
|
|
- `<iq from="dummy@localhost/resource" `+
|
|
|
- `id="${iq.nodeTree.getAttribute("id")}" `+
|
|
|
- `to="upload.montague.tld" `+
|
|
|
- `type="get" `+
|
|
|
- `xmlns="jabber:client">`+
|
|
|
- `<request `+
|
|
|
- `content-type="image/jpeg" `+
|
|
|
- `filename="my-juliet.jpg" `+
|
|
|
- `size="23456" `+
|
|
|
- `xmlns="urn:xmpp:http:upload:0"/>`+
|
|
|
- `</iq>`);
|
|
|
-
|
|
|
- var base_url = document.URL.split(window.location.pathname)[0];
|
|
|
- var message = base_url+"/logo/conversejs-filled.svg";
|
|
|
-
|
|
|
- var stanza = Strophe.xmlHtmlNode(
|
|
|
- "<iq from='upload.montague.tld'"+
|
|
|
- " id='"+iq.nodeTree.getAttribute('id')+"'"+
|
|
|
- " to='dummy@localhost/resource'"+
|
|
|
- " type='result'>"+
|
|
|
- "<slot xmlns='urn:xmpp:http:upload:0'>"+
|
|
|
- " <put url='https://upload.montague.tld/4a771ac1-f0b2-4a4a-9700-f2a26fa2bb67/my-juliet.jpg'>"+
|
|
|
- " <header name='Authorization'>Basic Base64String==</header>"+
|
|
|
- " <header name='Cookie'>foo=bar; user=romeo</header>"+
|
|
|
- " </put>"+
|
|
|
- " <get url='"+message+"' />"+
|
|
|
- "</slot>"+
|
|
|
- "</iq>").firstElementChild;
|
|
|
-
|
|
|
- spyOn(XMLHttpRequest.prototype, 'send').and.callFake(function () {
|
|
|
- const message = view.model.messages.at(0);
|
|
|
- expect(view.el.querySelector('.chat-content progress').getAttribute('value')).toBe('0');
|
|
|
- message.set('progress', 0.5);
|
|
|
- expect(view.el.querySelector('.chat-content progress').getAttribute('value')).toBe('0.5');
|
|
|
- message.set('progress', 1);
|
|
|
- expect(view.el.querySelector('.chat-content progress').getAttribute('value')).toBe('1');
|
|
|
- message.save({
|
|
|
- 'upload': _converse.SUCCESS,
|
|
|
- 'oob_url': message.get('get'),
|
|
|
- 'message': message.get('get')
|
|
|
- });
|
|
|
- });
|
|
|
- var sent_stanza;
|
|
|
- spyOn(_converse.connection, 'send').and.callFake(function (stanza) {
|
|
|
- sent_stanza = stanza;
|
|
|
- });
|
|
|
- _converse.connection._dataRecv(test_utils.createRequest(stanza));
|
|
|
-
|
|
|
- return test_utils.waitUntil(function () {
|
|
|
- return sent_stanza;
|
|
|
- }, 1000).then(function () {
|
|
|
- expect(sent_stanza.toLocaleString()).toBe(
|
|
|
- `<message from="dummy@localhost/resource" `+
|
|
|
- `id="${sent_stanza.nodeTree.getAttribute("id")}" `+
|
|
|
- `to="irini.vlastuin@localhost" `+
|
|
|
- `type="chat" `+
|
|
|
- `xmlns="jabber:client">`+
|
|
|
- `<body>${message}</body>`+
|
|
|
- `<active xmlns="http://jabber.org/protocol/chatstates"/>`+
|
|
|
- `<x xmlns="jabber:x:oob">`+
|
|
|
- `<url>${message}</url>`+
|
|
|
- `</x>`+
|
|
|
- `</message>`);
|
|
|
- return test_utils.waitUntil(() => view.el.querySelector('.chat-image'), 1000);
|
|
|
- }).then(function () {
|
|
|
- // Check that the image renders
|
|
|
- expect(view.el.querySelector('.chat-msg .chat-msg__media').innerHTML.trim()).toEqual(
|
|
|
- `<!-- src/templates/image.html -->\n`+
|
|
|
- `<a href="${window.location.origin}/logo/conversejs-filled.svg" target="_blank" rel="noopener">`+
|
|
|
- `<img class="chat-image img-thumbnail" src="${window.location.origin}/logo/conversejs-filled.svg">`+
|
|
|
- `</a>`);
|
|
|
- XMLHttpRequest.prototype.send = send_backup;
|
|
|
- done();
|
|
|
- });
|
|
|
+ message.save({
|
|
|
+ 'upload': _converse.SUCCESS,
|
|
|
+ 'oob_url': message.get('get'),
|
|
|
+ 'message': message.get('get')
|
|
|
});
|
|
|
+ return new Promise((resolve, reject) => view.model.messages.once('rendered', resolve));
|
|
|
});
|
|
|
});
|
|
|
+ let sent_stanza;
|
|
|
+ spyOn(_converse.connection, 'send').and.callFake(stanza => (sent_stanza = stanza));
|
|
|
+ _converse.connection._dataRecv(test_utils.createRequest(stanza));
|
|
|
+
|
|
|
+ await test_utils.waitUntil(() => sent_stanza, 1000);
|
|
|
+ expect(sent_stanza.toLocaleString()).toBe(
|
|
|
+ `<message from="dummy@localhost/resource" `+
|
|
|
+ `id="${sent_stanza.nodeTree.getAttribute("id")}" `+
|
|
|
+ `to="irini.vlastuin@localhost" `+
|
|
|
+ `type="chat" `+
|
|
|
+ `xmlns="jabber:client">`+
|
|
|
+ `<body>${message}</body>`+
|
|
|
+ `<active xmlns="http://jabber.org/protocol/chatstates"/>`+
|
|
|
+ `<x xmlns="jabber:x:oob">`+
|
|
|
+ `<url>${message}</url>`+
|
|
|
+ `</x>`+
|
|
|
+ `</message>`);
|
|
|
+ await test_utils.waitUntil(() => view.el.querySelector('.chat-image'), 1000);
|
|
|
+ // Check that the image renders
|
|
|
+ expect(view.el.querySelector('.chat-msg .chat-msg__media').innerHTML.trim()).toEqual(
|
|
|
+ `<!-- src/templates/image.html -->\n`+
|
|
|
+ `<a href="${window.location.origin}/logo/conversejs-filled.svg" target="_blank" rel="noopener">`+
|
|
|
+ `<img class="chat-image img-thumbnail" src="${window.location.origin}/logo/conversejs-filled.svg">`+
|
|
|
+ `</a>`);
|
|
|
+ XMLHttpRequest.prototype.send = send_backup;
|
|
|
+ done();
|
|
|
}));
|
|
|
|
|
|
- it("is uploaded and sent out from a groupchat", mock.initConverseWithAsync(function (done, _converse) {
|
|
|
- test_utils.waitUntilDiscoConfirmed(
|
|
|
+ it("is uploaded and sent out from a groupchat", mock.initConverseWithAsync(
|
|
|
+ async function (done, _converse) {
|
|
|
+
|
|
|
+ await test_utils.waitUntilDiscoConfirmed(
|
|
|
_converse, _converse.domain,
|
|
|
[{'category': 'server', 'type':'IM'}],
|
|
|
- ['http://jabber.org/protocol/disco#items'], [], 'info').then(function () {
|
|
|
+ ['http://jabber.org/protocol/disco#items'], [], 'info');
|
|
|
+
|
|
|
+ const send_backup = XMLHttpRequest.prototype.send;
|
|
|
+ const IQ_stanzas = _converse.connection.IQ_stanzas;
|
|
|
|
|
|
- var send_backup = XMLHttpRequest.prototype.send;
|
|
|
- var IQ_stanzas = _converse.connection.IQ_stanzas;
|
|
|
-
|
|
|
- test_utils.waitUntilDiscoConfirmed(_converse, _converse.domain, [], [], ['upload.montague.tld'], 'items').then(function () {
|
|
|
- test_utils.waitUntilDiscoConfirmed(_converse, 'upload.montague.tld', [], [Strophe.NS.HTTPUPLOAD], []).then(function () {
|
|
|
- test_utils.openAndEnterChatRoom(_converse, 'lounge', 'localhost', 'dummy').then(function () {
|
|
|
- var view = _converse.chatboxviews.get('lounge@localhost');
|
|
|
- var file = {
|
|
|
- 'type': 'image/jpeg',
|
|
|
- 'size': '23456' ,
|
|
|
- 'lastModifiedDate': "",
|
|
|
- 'name': "my-juliet.jpg"
|
|
|
- };
|
|
|
- view.model.sendFiles([file]);
|
|
|
-
|
|
|
- return test_utils.waitUntil(function () {
|
|
|
- return _.filter(IQ_stanzas, function (iq) {
|
|
|
- return iq.nodeTree.querySelector('iq[to="upload.montague.tld"] request');
|
|
|
- }).length > 0;
|
|
|
- }).then(function () {
|
|
|
- var iq = IQ_stanzas.pop();
|
|
|
- expect(iq.toLocaleString()).toBe(
|
|
|
- `<iq from="dummy@localhost/resource" `+
|
|
|
- `id="${iq.nodeTree.getAttribute("id")}" `+
|
|
|
- `to="upload.montague.tld" `+
|
|
|
- `type="get" `+
|
|
|
- `xmlns="jabber:client">`+
|
|
|
- `<request `+
|
|
|
- `content-type="image/jpeg" `+
|
|
|
- `filename="my-juliet.jpg" `+
|
|
|
- `size="23456" `+
|
|
|
- `xmlns="urn:xmpp:http:upload:0"/>`+
|
|
|
- `</iq>`);
|
|
|
-
|
|
|
- var base_url = document.URL.split(window.location.pathname)[0];
|
|
|
- var message = base_url+"/logo/conversejs-filled.svg";
|
|
|
-
|
|
|
- var stanza = Strophe.xmlHtmlNode(
|
|
|
- "<iq from='upload.montague.tld'"+
|
|
|
- " id='"+iq.nodeTree.getAttribute('id')+"'"+
|
|
|
- " to='dummy@localhost/resource'"+
|
|
|
- " type='result'>"+
|
|
|
- "<slot xmlns='urn:xmpp:http:upload:0'>"+
|
|
|
- " <put url='https://upload.montague.tld/4a771ac1-f0b2-4a4a-9700-f2a26fa2bb67/my-juliet.jpg'>"+
|
|
|
- " <header name='Authorization'>Basic Base64String==</header>"+
|
|
|
- " <header name='Cookie'>foo=bar; user=romeo</header>"+
|
|
|
- " </put>"+
|
|
|
- " <get url='"+message+"' />"+
|
|
|
- "</slot>"+
|
|
|
- "</iq>").firstElementChild;
|
|
|
-
|
|
|
- spyOn(XMLHttpRequest.prototype, 'send').and.callFake(function () {
|
|
|
- const message = view.model.messages.at(0);
|
|
|
- expect(view.el.querySelector('.chat-content progress').getAttribute('value')).toBe('0');
|
|
|
- message.set('progress', 0.5);
|
|
|
- expect(view.el.querySelector('.chat-content progress').getAttribute('value')).toBe('0.5');
|
|
|
- message.set('progress', 1);
|
|
|
- expect(view.el.querySelector('.chat-content progress').getAttribute('value')).toBe('1');
|
|
|
- message.save({
|
|
|
- 'upload': _converse.SUCCESS,
|
|
|
- 'oob_url': message.get('get'),
|
|
|
- 'message': message.get('get')
|
|
|
- });
|
|
|
- });
|
|
|
- var sent_stanza;
|
|
|
- spyOn(_converse.connection, 'send').and.callFake(function (stanza) {
|
|
|
- sent_stanza = stanza;
|
|
|
- });
|
|
|
- _converse.connection._dataRecv(test_utils.createRequest(stanza));
|
|
|
-
|
|
|
- return test_utils.waitUntil(() => sent_stanza, 1000).then(function () {
|
|
|
- expect(sent_stanza.toLocaleString()).toBe(
|
|
|
- `<message `+
|
|
|
- `from="dummy@localhost/resource" `+
|
|
|
- `id="${sent_stanza.nodeTree.getAttribute("id")}" `+
|
|
|
- `to="lounge@localhost" `+
|
|
|
- `type="groupchat" `+
|
|
|
- `xmlns="jabber:client">`+
|
|
|
- `<body>${message}</body>`+
|
|
|
- `<active xmlns="http://jabber.org/protocol/chatstates"/>`+
|
|
|
- `<x xmlns="jabber:x:oob">`+
|
|
|
- `<url>${message}</url>`+
|
|
|
- `</x>`+
|
|
|
- `</message>`);
|
|
|
- return test_utils.waitUntil(() => view.el.querySelector('.chat-image'), 1000);
|
|
|
- }).then(function () {
|
|
|
- // Check that the image renders
|
|
|
- expect(view.el.querySelector('.chat-msg .chat-msg__media').innerHTML.trim()).toEqual(
|
|
|
- `<!-- src/templates/image.html -->\n`+
|
|
|
- `<a href="${window.location.origin}/logo/conversejs-filled.svg" target="_blank" rel="noopener">`+
|
|
|
- `<img class="chat-image img-thumbnail" src="${window.location.origin}/logo/conversejs-filled.svg">`+
|
|
|
- `</a>`);
|
|
|
- XMLHttpRequest.prototype.send = send_backup;
|
|
|
- done();
|
|
|
- });
|
|
|
- });
|
|
|
- });
|
|
|
+ await test_utils.waitUntilDiscoConfirmed(_converse, _converse.domain, [], [], ['upload.montague.tld'], 'items');
|
|
|
+ await test_utils.waitUntilDiscoConfirmed(_converse, 'upload.montague.tld', [], [Strophe.NS.HTTPUPLOAD], []);
|
|
|
+ await test_utils.openAndEnterChatRoom(_converse, 'lounge', 'localhost', 'dummy');
|
|
|
+ const view = _converse.chatboxviews.get('lounge@localhost');
|
|
|
+ const file = {
|
|
|
+ 'type': 'image/jpeg',
|
|
|
+ 'size': '23456' ,
|
|
|
+ 'lastModifiedDate': "",
|
|
|
+ 'name': "my-juliet.jpg"
|
|
|
+ };
|
|
|
+ view.model.sendFiles([file]);
|
|
|
+ await new Promise((resolve, reject) => view.once('messageInserted', resolve));
|
|
|
+
|
|
|
+ await test_utils.waitUntil(() => _.filter(IQ_stanzas, iq => iq.nodeTree.querySelector('iq[to="upload.montague.tld"] request')).length);
|
|
|
+ var iq = IQ_stanzas.pop();
|
|
|
+ expect(iq.toLocaleString()).toBe(
|
|
|
+ `<iq from="dummy@localhost/resource" `+
|
|
|
+ `id="${iq.nodeTree.getAttribute("id")}" `+
|
|
|
+ `to="upload.montague.tld" `+
|
|
|
+ `type="get" `+
|
|
|
+ `xmlns="jabber:client">`+
|
|
|
+ `<request `+
|
|
|
+ `content-type="image/jpeg" `+
|
|
|
+ `filename="my-juliet.jpg" `+
|
|
|
+ `size="23456" `+
|
|
|
+ `xmlns="urn:xmpp:http:upload:0"/>`+
|
|
|
+ `</iq>`);
|
|
|
+
|
|
|
+ var base_url = document.URL.split(window.location.pathname)[0];
|
|
|
+ var message = base_url+"/logo/conversejs-filled.svg";
|
|
|
+
|
|
|
+ var stanza = Strophe.xmlHtmlNode(
|
|
|
+ "<iq from='upload.montague.tld'"+
|
|
|
+ " id='"+iq.nodeTree.getAttribute('id')+"'"+
|
|
|
+ " to='dummy@localhost/resource'"+
|
|
|
+ " type='result'>"+
|
|
|
+ "<slot xmlns='urn:xmpp:http:upload:0'>"+
|
|
|
+ " <put url='https://upload.montague.tld/4a771ac1-f0b2-4a4a-9700-f2a26fa2bb67/my-juliet.jpg'>"+
|
|
|
+ " <header name='Authorization'>Basic Base64String==</header>"+
|
|
|
+ " <header name='Cookie'>foo=bar; user=romeo</header>"+
|
|
|
+ " </put>"+
|
|
|
+ " <get url='"+message+"' />"+
|
|
|
+ "</slot>"+
|
|
|
+ "</iq>").firstElementChild;
|
|
|
+
|
|
|
+ spyOn(XMLHttpRequest.prototype, 'send').and.callFake(function () {
|
|
|
+ const message = view.model.messages.at(0);
|
|
|
+ expect(view.el.querySelector('.chat-content progress').getAttribute('value')).toBe('0');
|
|
|
+ message.set('progress', 0.5);
|
|
|
+ test_utils.waitUntil(() => view.el.querySelector('.chat-content progress').getAttribute('value') === '0.5')
|
|
|
+ .then(() => {
|
|
|
+ message.set('progress', 1);
|
|
|
+ test_utils.waitUntil(() => view.el.querySelector('.chat-content progress').getAttribute('value') === '1')
|
|
|
+ }).then(() => {
|
|
|
+ message.save({
|
|
|
+ 'upload': _converse.SUCCESS,
|
|
|
+ 'oob_url': message.get('get'),
|
|
|
+ 'message': message.get('get')
|
|
|
});
|
|
|
+ return new Promise((resolve, reject) => view.model.messages.once('rendered', resolve));
|
|
|
});
|
|
|
});
|
|
|
+ let sent_stanza;
|
|
|
+ spyOn(_converse.connection, 'send').and.callFake(stanza => (sent_stanza = stanza));
|
|
|
+ _converse.connection._dataRecv(test_utils.createRequest(stanza));
|
|
|
+
|
|
|
+ await test_utils.waitUntil(() => sent_stanza, 1000);
|
|
|
+ expect(sent_stanza.toLocaleString()).toBe(
|
|
|
+ `<message `+
|
|
|
+ `from="dummy@localhost/resource" `+
|
|
|
+ `id="${sent_stanza.nodeTree.getAttribute("id")}" `+
|
|
|
+ `to="lounge@localhost" `+
|
|
|
+ `type="groupchat" `+
|
|
|
+ `xmlns="jabber:client">`+
|
|
|
+ `<body>${message}</body>`+
|
|
|
+ `<active xmlns="http://jabber.org/protocol/chatstates"/>`+
|
|
|
+ `<x xmlns="jabber:x:oob">`+
|
|
|
+ `<url>${message}</url>`+
|
|
|
+ `</x>`+
|
|
|
+ `</message>`);
|
|
|
+ await test_utils.waitUntil(() => view.el.querySelector('.chat-image'), 1000);
|
|
|
+ // Check that the image renders
|
|
|
+ expect(view.el.querySelector('.chat-msg .chat-msg__media').innerHTML.trim()).toEqual(
|
|
|
+ `<!-- src/templates/image.html -->\n`+
|
|
|
+ `<a href="${window.location.origin}/logo/conversejs-filled.svg" target="_blank" rel="noopener">`+
|
|
|
+ `<img class="chat-image img-thumbnail" src="${window.location.origin}/logo/conversejs-filled.svg">`+
|
|
|
+ `</a>`);
|
|
|
+ XMLHttpRequest.prototype.send = send_backup;
|
|
|
+ done();
|
|
|
}));
|
|
|
|
|
|
it("shows an error message if the file is too large", mock.initConverseWithAsync(function (done, _converse) {
|
|
@@ -617,82 +603,78 @@
|
|
|
describe("While a file is being uploaded", function () {
|
|
|
|
|
|
it("shows a progress bar", mock.initConverseWithPromises(
|
|
|
- null, ['rosterGroupsFetched', 'chatBoxesFetched'], {}, function (done, _converse) {
|
|
|
+ null, ['rosterGroupsFetched', 'chatBoxesFetched'], {},
|
|
|
+ async function (done, _converse) {
|
|
|
|
|
|
- test_utils.waitUntilDiscoConfirmed(
|
|
|
+ await test_utils.waitUntilDiscoConfirmed(
|
|
|
_converse, _converse.domain,
|
|
|
[{'category': 'server', 'type':'IM'}],
|
|
|
- ['http://jabber.org/protocol/disco#items'], [], 'info').then(function () {
|
|
|
+ ['http://jabber.org/protocol/disco#items'], [], 'info');
|
|
|
|
|
|
- var send_backup = XMLHttpRequest.prototype.send;
|
|
|
- var IQ_stanzas = _converse.connection.IQ_stanzas;
|
|
|
- let view, contact_jid;
|
|
|
+ const send_backup = XMLHttpRequest.prototype.send;
|
|
|
+ const IQ_stanzas = _converse.connection.IQ_stanzas;
|
|
|
|
|
|
- test_utils.waitUntilDiscoConfirmed(_converse, _converse.domain, [], [], ['upload.montague.tld'], 'items')
|
|
|
- .then(() => test_utils.waitUntilDiscoConfirmed(_converse, 'upload.montague.tld', [], [Strophe.NS.HTTPUPLOAD], []))
|
|
|
+ await test_utils.waitUntilDiscoConfirmed(_converse, _converse.domain, [], [], ['upload.montague.tld'], 'items');
|
|
|
+ await test_utils.waitUntilDiscoConfirmed(_converse, 'upload.montague.tld', [], [Strophe.NS.HTTPUPLOAD], []);
|
|
|
+ test_utils.createContacts(_converse, 'current');
|
|
|
+ _converse.emit('rosterContactsFetched');
|
|
|
+ const contact_jid = mock.cur_names[2].replace(/ /g,'.').toLowerCase() + '@localhost';
|
|
|
+ await test_utils.openChatBoxFor(_converse, contact_jid);
|
|
|
+ const view = _converse.chatboxviews.get(contact_jid);
|
|
|
+ const file = {
|
|
|
+ 'type': 'image/jpeg',
|
|
|
+ 'size': '23456' ,
|
|
|
+ 'lastModifiedDate': "",
|
|
|
+ 'name': "my-juliet.jpg"
|
|
|
+ };
|
|
|
+ view.model.sendFiles([file]);
|
|
|
+ await new Promise((resolve, reject) => view.once('messageInserted', resolve));
|
|
|
+ await test_utils.waitUntil(() => _.filter(IQ_stanzas, (iq) => iq.nodeTree.querySelector('iq[to="upload.montague.tld"] request')).length)
|
|
|
+ const iq = IQ_stanzas.pop();
|
|
|
+ expect(iq.toLocaleString()).toBe(
|
|
|
+ `<iq from="dummy@localhost/resource" `+
|
|
|
+ `id="${iq.nodeTree.getAttribute("id")}" `+
|
|
|
+ `to="upload.montague.tld" `+
|
|
|
+ `type="get" `+
|
|
|
+ `xmlns="jabber:client">`+
|
|
|
+ `<request `+
|
|
|
+ `content-type="image/jpeg" `+
|
|
|
+ `filename="my-juliet.jpg" `+
|
|
|
+ `size="23456" `+
|
|
|
+ `xmlns="urn:xmpp:http:upload:0"/>`+
|
|
|
+ `</iq>`);
|
|
|
+
|
|
|
+ const base_url = document.URL.split(window.location.pathname)[0];
|
|
|
+ const message = base_url+"/logo/conversejs-filled.svg";
|
|
|
+ const stanza = Strophe.xmlHtmlNode(
|
|
|
+ "<iq from='upload.montague.tld'"+
|
|
|
+ " id='"+iq.nodeTree.getAttribute('id')+"'"+
|
|
|
+ " to='dummy@localhost/resource'"+
|
|
|
+ " type='result'>"+
|
|
|
+ "<slot xmlns='urn:xmpp:http:upload:0'>"+
|
|
|
+ " <put url='https://upload.montague.tld/4a771ac1-f0b2-4a4a-9700-f2a26fa2bb67/my-juliet.jpg'>"+
|
|
|
+ " <header name='Authorization'>Basic Base64String==</header>"+
|
|
|
+ " <header name='Cookie'>foo=bar; user=romeo</header>"+
|
|
|
+ " </put>"+
|
|
|
+ " <get url='"+message+"' />"+
|
|
|
+ "</slot>"+
|
|
|
+ "</iq>").firstElementChild;
|
|
|
+ spyOn(XMLHttpRequest.prototype, 'send').and.callFake(function () {
|
|
|
+ const message = view.model.messages.at(0);
|
|
|
+ expect(view.el.querySelector('.chat-content progress').getAttribute('value')).toBe('0');
|
|
|
+ message.set('progress', 0.5);
|
|
|
+ test_utils.waitUntil(() => view.el.querySelector('.chat-content progress').getAttribute('value') === '0.5')
|
|
|
.then(() => {
|
|
|
- test_utils.createContacts(_converse, 'current');
|
|
|
- _converse.emit('rosterContactsFetched');
|
|
|
-
|
|
|
- contact_jid = mock.cur_names[2].replace(/ /g,'.').toLowerCase() + '@localhost';
|
|
|
- return test_utils.openChatBoxFor(_converse, contact_jid);
|
|
|
+ message.set('progress', 1);
|
|
|
+ test_utils.waitUntil(() => view.el.querySelector('.chat-content progress').getAttribute('value') === '1')
|
|
|
}).then(() => {
|
|
|
- view = _converse.chatboxviews.get(contact_jid);
|
|
|
- const file = {
|
|
|
- 'type': 'image/jpeg',
|
|
|
- 'size': '23456' ,
|
|
|
- 'lastModifiedDate': "",
|
|
|
- 'name': "my-juliet.jpg"
|
|
|
- };
|
|
|
- view.model.sendFiles([file]);
|
|
|
- return test_utils.waitUntil(() => _.filter(IQ_stanzas, (iq) => iq.nodeTree.querySelector('iq[to="upload.montague.tld"] request')).length)
|
|
|
- }).then(function () {
|
|
|
- const iq = IQ_stanzas.pop();
|
|
|
- expect(iq.toLocaleString()).toBe(
|
|
|
- `<iq from="dummy@localhost/resource" `+
|
|
|
- `id="${iq.nodeTree.getAttribute("id")}" `+
|
|
|
- `to="upload.montague.tld" `+
|
|
|
- `type="get" `+
|
|
|
- `xmlns="jabber:client">`+
|
|
|
- `<request `+
|
|
|
- `content-type="image/jpeg" `+
|
|
|
- `filename="my-juliet.jpg" `+
|
|
|
- `size="23456" `+
|
|
|
- `xmlns="urn:xmpp:http:upload:0"/>`+
|
|
|
- `</iq>`);
|
|
|
-
|
|
|
- const base_url = document.URL.split(window.location.pathname)[0];
|
|
|
- const message = base_url+"/logo/conversejs-filled.svg";
|
|
|
- const stanza = Strophe.xmlHtmlNode(
|
|
|
- "<iq from='upload.montague.tld'"+
|
|
|
- " id='"+iq.nodeTree.getAttribute('id')+"'"+
|
|
|
- " to='dummy@localhost/resource'"+
|
|
|
- " type='result'>"+
|
|
|
- "<slot xmlns='urn:xmpp:http:upload:0'>"+
|
|
|
- " <put url='https://upload.montague.tld/4a771ac1-f0b2-4a4a-9700-f2a26fa2bb67/my-juliet.jpg'>"+
|
|
|
- " <header name='Authorization'>Basic Base64String==</header>"+
|
|
|
- " <header name='Cookie'>foo=bar; user=romeo</header>"+
|
|
|
- " </put>"+
|
|
|
- " <get url='"+message+"' />"+
|
|
|
- "</slot>"+
|
|
|
- "</iq>").firstElementChild;
|
|
|
- spyOn(XMLHttpRequest.prototype, 'send').and.callFake(function () {
|
|
|
- const message = view.model.messages.at(0);
|
|
|
- expect(view.el.querySelector('.chat-content progress').getAttribute('value')).toBe('0');
|
|
|
- message.set('progress', 0.5);
|
|
|
- expect(view.el.querySelector('.chat-content progress').getAttribute('value')).toBe('0.5');
|
|
|
- message.set('progress', 1);
|
|
|
- expect(view.el.querySelector('.chat-content progress').getAttribute('value')).toBe('1');
|
|
|
- expect(view.el.querySelector('.chat-content .chat-msg__text').textContent).toBe('Uploading file: my-juliet.jpg, 22.91 KB');
|
|
|
- done();
|
|
|
- });
|
|
|
- var sent_stanza;
|
|
|
- spyOn(_converse.connection, 'send').and.callFake(function (stanza) {
|
|
|
- sent_stanza = stanza;
|
|
|
- });
|
|
|
- _converse.connection._dataRecv(test_utils.createRequest(stanza));
|
|
|
+ expect(view.el.querySelector('.chat-content .chat-msg__text').textContent).toBe('Uploading file: my-juliet.jpg, 22.91 KB');
|
|
|
+ done();
|
|
|
});
|
|
|
});
|
|
|
+ let sent_stanza;
|
|
|
+ spyOn(_converse.connection, 'send').and.callFake(stanza => (sent_stanza = stanza));
|
|
|
+ _converse.connection._dataRecv(test_utils.createRequest(stanza));
|
|
|
}));
|
|
|
});
|
|
|
});
|