mirror of
https://github.com/vanitasvitae/Smack.git
synced 2024-11-23 20:42:06 +01:00
Add JingleContentDescriptionFileTransfer and tests
This commit is contained in:
parent
7319998bb9
commit
f0e6521360
12 changed files with 375 additions and 13 deletions
|
@ -1,3 +1,19 @@
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* Copyright © 2017 Paul Schaub
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
package org.jivesoftware.smackx.hash;
|
package org.jivesoftware.smackx.hash;
|
||||||
|
|
||||||
import org.bouncycastle.jcajce.provider.digest.Blake2b;
|
import org.bouncycastle.jcajce.provider.digest.Blake2b;
|
||||||
|
@ -122,7 +138,7 @@ public final class HashManager extends Manager {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Compensational method for static 'valueOf' function
|
* Compensational method for static 'valueOf' function.
|
||||||
* @param s
|
* @param s
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -114,4 +114,17 @@ public class HashElement implements ExtensionElement {
|
||||||
public String getNamespace() {
|
public String getNamespace() {
|
||||||
return HashManager.NAMESPACE_V2;
|
return HashManager.NAMESPACE_V2;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object other) {
|
||||||
|
if (other == null || !(other instanceof HashElement)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return this.hashCode() == other.hashCode();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return toXML().toString().hashCode();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,7 +22,7 @@ import org.jivesoftware.smackx.hash.element.HashElement;
|
||||||
import org.xmlpull.v1.XmlPullParser;
|
import org.xmlpull.v1.XmlPullParser;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Provider for HashElements
|
* Provider for HashElements.
|
||||||
*/
|
*/
|
||||||
public class HashElementProvider extends ExtensionElementProvider<HashElement> {
|
public class HashElementProvider extends ExtensionElementProvider<HashElement> {
|
||||||
|
|
||||||
|
|
|
@ -16,16 +16,16 @@
|
||||||
*/
|
*/
|
||||||
package org.jivesoftware.smackx.jingle_filetransfer.element;
|
package org.jivesoftware.smackx.jingle_filetransfer.element;
|
||||||
|
|
||||||
import org.jivesoftware.smack.packet.NamedElement;
|
|
||||||
import org.jivesoftware.smack.util.XmlStringBuilder;
|
import org.jivesoftware.smack.util.XmlStringBuilder;
|
||||||
import org.jivesoftware.smackx.hash.element.HashElement;
|
import org.jivesoftware.smackx.hash.element.HashElement;
|
||||||
|
import org.jivesoftware.smackx.jingle.element.JingleContentDescriptionPayloadType;
|
||||||
|
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Content of type File.
|
* Content of type File.
|
||||||
*/
|
*/
|
||||||
public class FileTransfer implements NamedElement {
|
public class FileTransferPayload extends JingleContentDescriptionPayloadType {
|
||||||
public static final String ELEMENT = "file";
|
public static final String ELEMENT = "file";
|
||||||
public static final String ELEM_DATE = "date";
|
public static final String ELEM_DATE = "date";
|
||||||
public static final String ELEM_DESC = "desc";
|
public static final String ELEM_DESC = "desc";
|
||||||
|
@ -41,7 +41,7 @@ public class FileTransfer implements NamedElement {
|
||||||
private final int size;
|
private final int size;
|
||||||
private final Range range;
|
private final Range range;
|
||||||
|
|
||||||
public FileTransfer(Date date, String desc, HashElement hash, String mediaType, String name, int size, Range range) {
|
public FileTransferPayload(Date date, String desc, HashElement hash, String mediaType, String name, int size, Range range) {
|
||||||
this.date = date;
|
this.date = date;
|
||||||
this.desc = desc;
|
this.desc = desc;
|
||||||
this.hash = hash;
|
this.hash = hash;
|
||||||
|
@ -51,6 +51,34 @@ public class FileTransfer implements NamedElement {
|
||||||
this.range = range;
|
this.range = range;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Date getDate() {
|
||||||
|
return date;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getDescription() {
|
||||||
|
return desc;
|
||||||
|
}
|
||||||
|
|
||||||
|
public HashElement getHash() {
|
||||||
|
return hash;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getMediaType() {
|
||||||
|
return mediaType;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getSize() {
|
||||||
|
return size;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Range getRange() {
|
||||||
|
return range;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getElementName() {
|
public String getElementName() {
|
||||||
return ELEMENT;
|
return ELEMENT;
|
|
@ -27,11 +27,8 @@ import java.util.List;
|
||||||
*/
|
*/
|
||||||
public class JingleContentDescriptionFileTransfer extends JingleContentDescription {
|
public class JingleContentDescriptionFileTransfer extends JingleContentDescription {
|
||||||
|
|
||||||
private FileTransfer fileTransfer;
|
public JingleContentDescriptionFileTransfer(List<JingleContentDescriptionPayloadType> payloadTypes) {
|
||||||
|
|
||||||
protected JingleContentDescriptionFileTransfer(List<JingleContentDescriptionPayloadType> payloadTypes, FileTransfer fileTransfer) {
|
|
||||||
super(payloadTypes);
|
super(payloadTypes);
|
||||||
this.fileTransfer = fileTransfer;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -1,3 +1,19 @@
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* Copyright © 2017 Paul Schaub
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
package org.jivesoftware.smackx.jingle_filetransfer.element;
|
package org.jivesoftware.smackx.jingle_filetransfer.element;
|
||||||
|
|
||||||
import org.jivesoftware.smack.packet.NamedElement;
|
import org.jivesoftware.smack.packet.NamedElement;
|
||||||
|
@ -102,4 +118,18 @@ public class Range implements NamedElement {
|
||||||
}
|
}
|
||||||
return sb;
|
return sb;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object other) {
|
||||||
|
if (other == null || !(other instanceof Range)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return this.hashCode() == other.hashCode();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return toXML().toString().hashCode();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,138 @@
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* Copyright 2017 Paul Schaub
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
package org.jivesoftware.smackx.jingle_filetransfer.provider;
|
||||||
|
|
||||||
|
import org.jivesoftware.smackx.hash.element.HashElement;
|
||||||
|
import org.jivesoftware.smackx.hash.provider.HashElementProvider;
|
||||||
|
import org.jivesoftware.smackx.jingle.element.JingleContentDescriptionPayloadType;
|
||||||
|
import org.jivesoftware.smackx.jingle.provider.JingleContentDescriptionProvider;
|
||||||
|
import org.jivesoftware.smackx.jingle_filetransfer.element.FileTransferPayload;
|
||||||
|
import org.jivesoftware.smackx.jingle_filetransfer.element.JingleContentDescriptionFileTransfer;
|
||||||
|
import org.jivesoftware.smackx.jingle_filetransfer.element.Range;
|
||||||
|
import org.jxmpp.util.XmppDateTime;
|
||||||
|
import org.xmlpull.v1.XmlPullParser;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
|
import static org.xmlpull.v1.XmlPullParser.END_TAG;
|
||||||
|
import static org.xmlpull.v1.XmlPullParser.START_TAG;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Provider for JingleContentDescriptionFileTransfer elements.
|
||||||
|
*/
|
||||||
|
public class JingleContentDescriptionFileTransferProvider
|
||||||
|
extends JingleContentDescriptionProvider<JingleContentDescriptionFileTransfer> {
|
||||||
|
@Override
|
||||||
|
public JingleContentDescriptionFileTransfer parse(XmlPullParser parser, int initialDepth) throws Exception {
|
||||||
|
|
||||||
|
boolean inRange = false;
|
||||||
|
|
||||||
|
Date date = null;
|
||||||
|
String desc = null;
|
||||||
|
String mediaType = null;
|
||||||
|
String name = null;
|
||||||
|
int size = -1;
|
||||||
|
Range range = null;
|
||||||
|
HashElement inRangeHash = null;
|
||||||
|
HashElement hash = null;
|
||||||
|
|
||||||
|
ArrayList<JingleContentDescriptionPayloadType> payloads = new ArrayList<>();
|
||||||
|
|
||||||
|
int offset = 0;
|
||||||
|
int length = -1;
|
||||||
|
|
||||||
|
while (true) {
|
||||||
|
|
||||||
|
int tag = parser.nextTag();
|
||||||
|
String elem = parser.getName();
|
||||||
|
|
||||||
|
if (tag == START_TAG) {
|
||||||
|
switch (elem) {
|
||||||
|
|
||||||
|
case FileTransferPayload.ELEMENT:
|
||||||
|
date = null;
|
||||||
|
desc = null;
|
||||||
|
mediaType = null;
|
||||||
|
name = null;
|
||||||
|
size = -1;
|
||||||
|
range = null;
|
||||||
|
inRangeHash = null;
|
||||||
|
hash = null;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case FileTransferPayload.ELEM_DATE:
|
||||||
|
date = XmppDateTime.parseXEP0082Date(parser.nextText());
|
||||||
|
break;
|
||||||
|
|
||||||
|
case FileTransferPayload.ELEM_DESC:
|
||||||
|
desc = parser.nextText();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case FileTransferPayload.ELEM_MEDIA_TYPE:
|
||||||
|
mediaType = parser.nextText();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case FileTransferPayload.ELEM_NAME:
|
||||||
|
name = parser.nextText();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case FileTransferPayload.ELEM_SIZE:
|
||||||
|
size = Integer.parseInt(parser.nextText());
|
||||||
|
break;
|
||||||
|
|
||||||
|
case Range.ELEMENT:
|
||||||
|
inRange = true;
|
||||||
|
String offsetString = parser.getAttributeValue(null, Range.ATTR_OFFSET);
|
||||||
|
String lengthString = parser.getAttributeValue(null, Range.ATTR_LENGTH);
|
||||||
|
offset = (offsetString != null ? Integer.parseInt(offsetString) : 0);
|
||||||
|
length = (lengthString != null ? Integer.parseInt(lengthString) : -1);
|
||||||
|
|
||||||
|
if (parser.isEmptyElementTag()) {
|
||||||
|
range = new Range(offset, length);
|
||||||
|
inRange = false;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case HashElement.ELEMENT:
|
||||||
|
if (inRange) {
|
||||||
|
inRangeHash = new HashElementProvider().parse(parser);
|
||||||
|
} else {
|
||||||
|
hash = new HashElementProvider().parse(parser);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
} else if (tag == END_TAG) {
|
||||||
|
switch (elem) {
|
||||||
|
|
||||||
|
case Range.ELEMENT:
|
||||||
|
inRange = false;
|
||||||
|
range = new Range(offset, length, inRangeHash);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case FileTransferPayload.ELEMENT:
|
||||||
|
payloads.add(new FileTransferPayload(date, desc, hash, mediaType, name, size, range));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case JingleContentDescriptionFileTransfer.ELEMENT:
|
||||||
|
return new JingleContentDescriptionFileTransfer(payloads);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -26,6 +26,8 @@ import org.junit.Test;
|
||||||
import static junit.framework.TestCase.assertEquals;
|
import static junit.framework.TestCase.assertEquals;
|
||||||
import static org.jivesoftware.smackx.hash.HashManager.ALGORITHM.SHA_256;
|
import static org.jivesoftware.smackx.hash.HashManager.ALGORITHM.SHA_256;
|
||||||
import static org.junit.Assert.assertArrayEquals;
|
import static org.junit.Assert.assertArrayEquals;
|
||||||
|
import static org.junit.Assert.assertFalse;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test toXML and parse of HashElement and HashElementProvider.
|
* Test toXML and parse of HashElement and HashElementProvider.
|
||||||
|
@ -44,6 +46,11 @@ public class HashElementTest extends SmackTestSuite {
|
||||||
assertEquals(SHA_256, parsed.getAlgorithm());
|
assertEquals(SHA_256, parsed.getAlgorithm());
|
||||||
assertEquals("f4OxZX/x/FO5LcGBSKHWXfwtSx+j1ncoSt3SABJtkGk=", parsed.getHashB64());
|
assertEquals("f4OxZX/x/FO5LcGBSKHWXfwtSx+j1ncoSt3SABJtkGk=", parsed.getHashB64());
|
||||||
assertArrayEquals(HashManager.sha_256(message.getBytes(StringUtils.UTF8)), parsed.getHash());
|
assertArrayEquals(HashManager.sha_256(message.getBytes(StringUtils.UTF8)), parsed.getHash());
|
||||||
|
|
||||||
|
assertFalse(parsed.equals(expected));
|
||||||
|
assertFalse(parsed.equals(null));
|
||||||
|
assertEquals(element, parsed);
|
||||||
|
assertTrue(element.equals(parsed));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,3 +1,19 @@
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* Copyright © 2017 Paul Schaub
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
package org.jivesoftware.smackx.jingle_filetransfer;
|
package org.jivesoftware.smackx.jingle_filetransfer;
|
||||||
|
|
||||||
import org.jivesoftware.smack.test.util.SmackTestSuite;
|
import org.jivesoftware.smack.test.util.SmackTestSuite;
|
||||||
|
@ -13,7 +29,7 @@ import static junit.framework.TestCase.assertNull;
|
||||||
/**
|
/**
|
||||||
* Test the JingleContentFile class.
|
* Test the JingleContentFile class.
|
||||||
*/
|
*/
|
||||||
public class FileTransferTest extends SmackTestSuite {
|
public class FileTransferPayloadTest extends SmackTestSuite {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void rangeTest() throws Exception {
|
public void rangeTest() throws Exception {
|
|
@ -0,0 +1,116 @@
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* Copyright © 2017 Paul Schaub
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
package org.jivesoftware.smackx.jingle_filetransfer;
|
||||||
|
|
||||||
|
import org.jivesoftware.smack.test.util.SmackTestSuite;
|
||||||
|
import org.jivesoftware.smack.test.util.TestUtils;
|
||||||
|
import org.jivesoftware.smackx.hash.HashManager;
|
||||||
|
import org.jivesoftware.smackx.hash.element.HashElement;
|
||||||
|
import org.jivesoftware.smackx.jingle.element.JingleContentDescription;
|
||||||
|
import org.jivesoftware.smackx.jingle.element.JingleContentDescriptionPayloadType;
|
||||||
|
import org.jivesoftware.smackx.jingle_filetransfer.element.FileTransferPayload;
|
||||||
|
import org.jivesoftware.smackx.jingle_filetransfer.element.JingleContentDescriptionFileTransfer;
|
||||||
|
import org.jivesoftware.smackx.jingle_filetransfer.element.Range;
|
||||||
|
import org.jivesoftware.smackx.jingle_filetransfer.provider.JingleContentDescriptionFileTransferProvider;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.jxmpp.util.XmppDateTime;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test the JingleContentDescriptionFileTransfer element and provider.
|
||||||
|
*/
|
||||||
|
public class JingleContentDescriptionFileTransferTest extends SmackTestSuite {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void parserTest() throws Exception {
|
||||||
|
String dateString = "2012-01-02T03:04:05.000+00:00";
|
||||||
|
String descriptionString = "The Description";
|
||||||
|
String mediaTypeString = "text/plain";
|
||||||
|
String nameString = "the-file.txt";
|
||||||
|
int sizeInt = 4096;
|
||||||
|
HashManager.ALGORITHM algorithm = HashManager.ALGORITHM.SHA_256;
|
||||||
|
String hashB64 = "f4OxZX/x/FO5LcGBSKHWXfwtSx+j1ncoSt3SABJtkGk=";
|
||||||
|
String xml =
|
||||||
|
"<description xmlns='urn:xmpp:jingle:apps:file-transfer:5'>" +
|
||||||
|
"<file>" +
|
||||||
|
"<date>" + dateString + "</date>" +
|
||||||
|
"<desc>" + descriptionString + "</desc>" +
|
||||||
|
"<media-type>" + mediaTypeString + "</media-type>" +
|
||||||
|
"<name>" + nameString + "</name>" +
|
||||||
|
"<range/>" +
|
||||||
|
"<size>" + sizeInt + "</size>" +
|
||||||
|
"<hash xmlns='urn:xmpp:hashes:2' algo='" + algorithm + "'>" +
|
||||||
|
hashB64 +
|
||||||
|
"</hash>" +
|
||||||
|
"</file>" +
|
||||||
|
"</description>";
|
||||||
|
HashElement hashElement = new HashElement(algorithm, hashB64);
|
||||||
|
Range range = new Range();
|
||||||
|
Date date = XmppDateTime.parseDate(dateString);
|
||||||
|
FileTransferPayload fileTransferPayload = new FileTransferPayload(date, descriptionString, hashElement, mediaTypeString, nameString, sizeInt, range);
|
||||||
|
ArrayList<JingleContentDescriptionPayloadType> payloads = new ArrayList<>();
|
||||||
|
payloads.add(fileTransferPayload);
|
||||||
|
|
||||||
|
JingleContentDescriptionFileTransfer descriptionFileTransfer =
|
||||||
|
new JingleContentDescriptionFileTransfer(payloads);
|
||||||
|
|
||||||
|
assertEquals(xml, descriptionFileTransfer.toXML().toString());
|
||||||
|
|
||||||
|
JingleContentDescription parsed = new JingleContentDescriptionFileTransferProvider()
|
||||||
|
.parse(TestUtils.getParser(xml));
|
||||||
|
assertEquals(xml, parsed.toXML().toString());
|
||||||
|
|
||||||
|
FileTransferPayload payload = (FileTransferPayload) parsed.getJinglePayloadTypes().get(0);
|
||||||
|
assertEquals(date, payload.getDate());
|
||||||
|
assertEquals(descriptionString, payload.getDescription());
|
||||||
|
assertEquals(mediaTypeString, payload.getMediaType());
|
||||||
|
assertEquals(nameString, payload.getName());
|
||||||
|
assertEquals(sizeInt, payload.getSize());
|
||||||
|
assertEquals(range, payload.getRange());
|
||||||
|
assertEquals(hashElement, payload.getHash());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void parserTest2() throws Exception {
|
||||||
|
HashManager.ALGORITHM algorithm = HashManager.ALGORITHM.SHA_256;
|
||||||
|
String hashB64 = "f4OxZX/x/FO5LcGBSKHWXfwtSx+j1ncoSt3SABJtkGk=";
|
||||||
|
HashElement hashElement = new HashElement(algorithm, hashB64);
|
||||||
|
Range range = new Range(2048, 1024, hashElement);
|
||||||
|
String xml =
|
||||||
|
"<description xmlns='urn:xmpp:jingle:apps:file-transfer:5'>" +
|
||||||
|
"<file>" +
|
||||||
|
"<range offset='2048' length='1024'>" +
|
||||||
|
"<hash xmlns='urn:xmpp:hashes:2' algo='" + algorithm + "'>" +
|
||||||
|
hashB64 +
|
||||||
|
"</hash>" +
|
||||||
|
"</range>" +
|
||||||
|
"</file>" +
|
||||||
|
"</description>";
|
||||||
|
FileTransferPayload payload = new FileTransferPayload(null, null, null, null, null, -1, range);
|
||||||
|
ArrayList<JingleContentDescriptionPayloadType> list = new ArrayList<>();
|
||||||
|
list.add(payload);
|
||||||
|
JingleContentDescriptionFileTransfer fileTransfer = new JingleContentDescriptionFileTransfer(list);
|
||||||
|
assertEquals(xml, fileTransfer.toXML().toString());
|
||||||
|
JingleContentDescriptionFileTransfer parsed = new JingleContentDescriptionFileTransferProvider()
|
||||||
|
.parse(TestUtils.getParser(xml));
|
||||||
|
assertEquals(xml, parsed.toXML().toString());
|
||||||
|
}
|
||||||
|
}
|
|
@ -62,6 +62,7 @@ public abstract class JingleContentDescription implements ExtensionElement {
|
||||||
|
|
||||||
xml.append(payloads);
|
xml.append(payloads);
|
||||||
|
|
||||||
|
xml.closeElement(this);
|
||||||
return xml;
|
return xml;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue