summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTarun Gupta <tarun1995gupta@gmail.com>2015-06-22 20:29:55 (GMT)
committerKevin Smith <kevin.smith@isode.com>2015-07-07 07:09:25 (GMT)
commitae1f4d65b253fa1a263556be7419836a37683dd2 (patch)
tree7628bd7b894e0dee72e61f7aba197ffb7bf28716 /src/com/isode/stroke/serializer/payloadserializers
parentac54c7b41a869d5c8762ce57fb8e918f1ba557f0 (diff)
downloadstroke-ae1f4d65b253fa1a263556be7419836a37683dd2.zip
stroke-ae1f4d65b253fa1a263556be7419836a37683dd2.tar.bz2
Adds tests for Parser and Serializers.
Adds PubSubEvent Element. Adds StreamFeaturesSerializer. Adds ParserTester, ElementParserTester, StanzaParserTester, PayloadParserTester, PayloadsSerializer and EnumParser. Updates Error Payload, JingleFIleTransferHash Elements/ Updates StreamFeaturesParser, ParserElement. Updates Delay Serializer, Error Serializer. Updates AuthChallenge and AuthRequest Element. License: This patch is BSD-licensed, see Documentation/Licenses/BSD-simplified.txt for details. Test-Information: Test are added for: AuthChallenge Serializer, AuthRequest Serializer, AuthResponse Serializer, AuthSuccess Serializer. GenericPayloadTreeParserTest. IQ Parser. Message Parser. Presence Parser. StanzaAck Parser. Stanza Parser. StreamFeatures Parser and Serializer. StreamManagementEnabled Parser. Private Storage Parser and Serializer. RawXMLPayload Parser. Storage Parser and Serializer. Error Serializer. Jingle Serializer. PubSubItem Serializer and PubSubItems Serializer. Serializing Parser. All tests passes. Change-Id: I79e00dc5b5c4f85e659bf88b1547dd7c17825805
Diffstat (limited to 'src/com/isode/stroke/serializer/payloadserializers')
-rw-r--r--src/com/isode/stroke/serializer/payloadserializers/DelaySerializer.java3
-rw-r--r--src/com/isode/stroke/serializer/payloadserializers/ErrorSerializer.java14
-rw-r--r--src/com/isode/stroke/serializer/payloadserializers/FullPayloadSerializerCollection.java2
3 files changed, 16 insertions, 3 deletions
diff --git a/src/com/isode/stroke/serializer/payloadserializers/DelaySerializer.java b/src/com/isode/stroke/serializer/payloadserializers/DelaySerializer.java
index f54f38f..38e1eba 100644
--- a/src/com/isode/stroke/serializer/payloadserializers/DelaySerializer.java
+++ b/src/com/isode/stroke/serializer/payloadserializers/DelaySerializer.java
@@ -25,7 +25,8 @@ public class DelaySerializer extends GenericPayloadSerializer<Delay> {
if (delay.getFrom() != null && delay.getFrom().isValid()) {
delayElement.setAttribute("from", delay.getFrom().toString());
}
- delayElement.setAttribute("stamp", DateTime.dateToString(delay.getStamp()));
+ if(delay.getStamp() != null)
+ delayElement.setAttribute("stamp", DateTime.dateToString(delay.getStamp()));
return delayElement.serialize();
}
}
diff --git a/src/com/isode/stroke/serializer/payloadserializers/ErrorSerializer.java b/src/com/isode/stroke/serializer/payloadserializers/ErrorSerializer.java
index 33d064d..47373f8 100644
--- a/src/com/isode/stroke/serializer/payloadserializers/ErrorSerializer.java
+++ b/src/com/isode/stroke/serializer/payloadserializers/ErrorSerializer.java
@@ -12,11 +12,16 @@ package com.isode.stroke.serializer.payloadserializers;
import com.isode.stroke.elements.ErrorPayload;
import com.isode.stroke.serializer.GenericPayloadSerializer;
import com.isode.stroke.serializer.xml.XMLTextNode;
+import com.isode.stroke.serializer.PayloadSerializerCollection;
+import com.isode.stroke.serializer.PayloadSerializer;
class ErrorSerializer extends GenericPayloadSerializer<ErrorPayload> {
- public ErrorSerializer() {
+ private PayloadSerializerCollection serializers;
+
+ public ErrorSerializer(PayloadSerializerCollection serializers) {
super(ErrorPayload.class);
+ this.serializers = serializers;
}
@Override
@@ -63,6 +68,13 @@ class ErrorSerializer extends GenericPayloadSerializer<ErrorPayload> {
result += "<text xmlns=\"urn:ietf:params:xml:ns:xmpp-stanzas\">" + textNode.serialize() + "</text>";
}
+ if (error.getPayload() != null) {
+ PayloadSerializer serializer = serializers.getPayloadSerializer(error.getPayload());
+ if (serializer != null) {
+ result += serializer.serialize(error.getPayload());
+ }
+ }
+
result += "</error>";
return result;
}
diff --git a/src/com/isode/stroke/serializer/payloadserializers/FullPayloadSerializerCollection.java b/src/com/isode/stroke/serializer/payloadserializers/FullPayloadSerializerCollection.java
index 001d126..ac093c0 100644
--- a/src/com/isode/stroke/serializer/payloadserializers/FullPayloadSerializerCollection.java
+++ b/src/com/isode/stroke/serializer/payloadserializers/FullPayloadSerializerCollection.java
@@ -26,7 +26,7 @@ public class FullPayloadSerializerCollection extends PayloadSerializerCollection
addSerializer(new CarbonsReceivedSerializer(this));
addSerializer(new CarbonsSentSerializer(this));
addSerializer(new PrioritySerializer());
- addSerializer(new ErrorSerializer());
+ addSerializer(new ErrorSerializer(this));
addSerializer(new InBandRegistrationPayloadSerializer());
addSerializer(new IBBSerializer());
addSerializer(new JingleIBBTransportPayloadSerializer());