diff options
author | Alex Clayton <alex.clayton@isode.com> | 2016-02-02 11:26:01 (GMT) |
---|---|---|
committer | Alex Clayton <alex.clayton@isode.com> | 2016-02-04 10:09:21 (GMT) |
commit | be72c822d3cffd840e753e01fe28857b081cf6f3 (patch) | |
tree | ae3fe8fe22175f9bfee89f0688b71ca377f7f1e9 /test/com/isode/stroke/parser/payloadparsers | |
parent | 2c9305a872e4ca958bfd86472c4540cc10d11a2f (diff) | |
download | stroke-be72c822d3cffd840e753e01fe28857b081cf6f3.zip stroke-be72c822d3cffd840e753e01fe28857b081cf6f3.tar.bz2 |
Add Block Parser and Serializer
Add BlockParser and BlockSerializer for the block payload classes.
This required slightly different approach to the Swiften code as C++ templates
are different to Java generics. In short needed to add a type hierachy to the
Block payload classes and to the Parsers and Serilaizers associated with them.
Test-information:
Ran unit tests everything passed ok.
Change-Id: I3ea2d66afd7cb3b5c4c3515be3a1ef99d7dbb566
Diffstat (limited to 'test/com/isode/stroke/parser/payloadparsers')
-rw-r--r-- | test/com/isode/stroke/parser/payloadparsers/BlockParserTest.java | 83 |
1 files changed, 83 insertions, 0 deletions
diff --git a/test/com/isode/stroke/parser/payloadparsers/BlockParserTest.java b/test/com/isode/stroke/parser/payloadparsers/BlockParserTest.java new file mode 100644 index 0000000..bd2d5cf --- /dev/null +++ b/test/com/isode/stroke/parser/payloadparsers/BlockParserTest.java @@ -0,0 +1,83 @@ +/* Copyright (c) 2016, Isode Limited, London, England. + * All rights reserved. + * + * Acquisition and use of this software and related materials for any + * purpose requires a written license agreement from Isode Limited, + * or a written license from an organisation licensed by Isode Limited + * to grant such a license. + * + */ +package com.isode.stroke.parser.payloadparsers; + +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertTrue; + +import org.junit.Test; + +import com.isode.stroke.elements.BlockListPayload; +import com.isode.stroke.elements.BlockPayload; +import com.isode.stroke.elements.Payload; +import com.isode.stroke.elements.UnblockPayload; +import com.isode.stroke.eventloop.DummyEventLoop; +import com.isode.stroke.jid.JID; + +/** + * Test for {@link BlockParser} (and its subclasses) + */ +public class BlockParserTest { + + /** + * Constructor + */ + public BlockParserTest() { + + } + + @Test + public void testExample4() { + PayloadsParserTester parser = + new PayloadsParserTester(new DummyEventLoop()); + boolean success = parser.parse("<blocklist xmlns='urn:xmpp:blocking'>" + + "<item jid='romeo@montague.net'/>" + + "<item jid='iago@shakespeare.lit'/>" + + "</blocklist>"); + assertTrue(success); + Payload payload = parser.getPayload(); + assertTrue(payload instanceof BlockListPayload); + BlockListPayload blockListPayload = (BlockListPayload) payload; + assertEquals(2,blockListPayload.getItems().size()); + assertEquals(new JID("romeo@montague.net"),blockListPayload.getItems().get(0)); + assertEquals(new JID("iago@shakespeare.lit"),blockListPayload.getItems().get(1)); + } + + @Test + public void testExample6() { + PayloadsParserTester parser = + new PayloadsParserTester(new DummyEventLoop()); + boolean success = parser.parse("<block xmlns='urn:xmpp:blocking'>" + +"<item jid='romeo@montague.net'/>" + +"</block>"); + assertTrue(success); + Payload payload = parser.getPayload(); + assertTrue(payload instanceof BlockPayload); + BlockPayload blockPayload = (BlockPayload) payload; + assertEquals(1,blockPayload.getItems().size()); + assertEquals(new JID("romeo@montague.net"),blockPayload.getItems().get(0)); + } + + @Test + public void testExample10() { + PayloadsParserTester parser = + new PayloadsParserTester(new DummyEventLoop()); + boolean success = parser.parse("<unblock xmlns='urn:xmpp:blocking'>" + +"<item jid='romeo@montague.net'/>" + +"</unblock>"); + assertTrue(success); + Payload payload = parser.getPayload(); + assertTrue(payload instanceof UnblockPayload); + UnblockPayload unblockPayload = (UnblockPayload) payload; + assertEquals(1,unblockPayload.getItems().size()); + assertEquals(new JID("romeo@montague.net"),unblockPayload.getItems().get(0)); + } + +} |