mirror of
https://codeberg.org/Mercury-IM/Smack
synced 2024-11-12 19:02:06 +01:00
33e2094fe4
This new souce directory and artifact initially contains message carbons (XEP-0280) code provided by George Lukas. git-svn-id: http://svn.igniterealtime.org/svn/repos/smack/branches/smack_3_4_0@13882 b35dd754-fafc-0310-a699-88a17e54d16e
89 lines
3.8 KiB
Java
89 lines
3.8 KiB
Java
package org.jivesoftware.smack.packet;
|
|
|
|
import static org.junit.Assert.*;
|
|
|
|
import org.jivesoftware.smack.packet.StreamError;
|
|
import org.jivesoftware.smack.test.util.TestUtils;
|
|
import org.jivesoftware.smack.util.PacketParserUtils;
|
|
import org.junit.Test;
|
|
import org.xmlpull.v1.XmlPullParser;
|
|
|
|
public class StreamErrorTest {
|
|
|
|
@Test
|
|
public void testParsingOfSimpleStreamError() {
|
|
StreamError error = null;
|
|
final String xml =
|
|
// Usually the stream:stream element has more attributes (to, version, ...)
|
|
// We omit those, since they are not relevant for testing
|
|
"<stream:stream from='im.example.com' id='++TR84Sm6A3hnt3Q065SnAbbk3Y=' xmlns:stream='http://etherx.jabber.org/streams'>" +
|
|
"<stream:error>" +
|
|
"<conflict xmlns='urn:ietf:params:xml:ns:xmpp-streams' /> +" +
|
|
"</stream:error>" +
|
|
"</stream:stream>";
|
|
try {
|
|
XmlPullParser parser = TestUtils.getParser(xml, "error");
|
|
error = PacketParserUtils.parseStreamError(parser);
|
|
} catch (Exception e) {
|
|
fail(e.getMessage());
|
|
}
|
|
assertNotNull(error);
|
|
assertEquals("conflict", error.getCode());
|
|
}
|
|
|
|
@Test
|
|
public void testParsingOfStreamErrorWithText() {
|
|
StreamError error = null;
|
|
final String xml =
|
|
// Usually the stream:stream element has more attributes (to, version, ...)
|
|
// We omit those, since they are not relevant for testing
|
|
"<stream:stream from='im.example.com' id='++TR84Sm6A3hnt3Q065SnAbbk3Y=' xmlns:stream='http://etherx.jabber.org/streams'>" +
|
|
"<stream:error>" +
|
|
"<conflict xmlns='urn:ietf:params:xml:ns:xmpp-streams' />" +
|
|
"<text xml:lang='' xmlns='urn:ietf:params:xml:ns:xmpp-streams'>" +
|
|
"Replaced by new connection" +
|
|
"</text>" +
|
|
"</stream:error>" +
|
|
"</stream:stream>";
|
|
try {
|
|
XmlPullParser parser = TestUtils.getParser(xml, "error");
|
|
error = PacketParserUtils.parseStreamError(parser);
|
|
} catch (Exception e) {
|
|
fail(e.getMessage());
|
|
}
|
|
assertNotNull(error);
|
|
assertEquals("conflict", error.getCode());
|
|
assertEquals("Replaced by new connection", error.getText());
|
|
}
|
|
|
|
@Test
|
|
public void testParsingOfStreamErrorWithTextAndOptionalElement() {
|
|
StreamError error = null;
|
|
final String xml =
|
|
// Usually the stream:stream element has more attributes (to, version, ...)
|
|
// We omit those, since they are not relevant for testing
|
|
"<stream:stream from='im.example.com' id='++TR84Sm6A3hnt3Q065SnAbbk3Y=' xmlns:stream='http://etherx.jabber.org/streams'>" +
|
|
"<stream:error>" +
|
|
"<conflict xmlns='urn:ietf:params:xml:ns:xmpp-streams' />" +
|
|
"<text xml:lang='' xmlns='urn:ietf:params:xml:ns:xmpp-streams'>" +
|
|
"Replaced by new connection" +
|
|
"</text>" +
|
|
"<appSpecificElement>" +
|
|
"Text contents of application-specific condition element: Foo Bar" +
|
|
"</appSpecificElement>" +
|
|
"</stream:error>" +
|
|
"</stream:stream>";
|
|
try {
|
|
XmlPullParser parser = TestUtils.getParser(xml, "error");
|
|
error = PacketParserUtils.parseStreamError(parser);
|
|
} catch (Exception e) {
|
|
fail(e.getMessage());
|
|
}
|
|
assertNotNull(error);
|
|
assertEquals("conflict", error.getCode());
|
|
assertEquals("Replaced by new connection", error.getText());
|
|
// As of now, Smack ignores application-specific condition elements, so we don't
|
|
// test them.
|
|
}
|
|
|
|
}
|