Search in sources :

Example 11 with DeliveryAnnotations

use of org.apache.qpid.protonj2.test.driver.codec.messaging.DeliveryAnnotations in project qpid-protonj2 by apache.

the class MessageSendTest method doTestSendOfExternalMessage.

private void doTestSendOfExternalMessage(boolean allowAdvancedConversion, boolean trySend) throws Exception {
    try (ProtonTestServer peer = new ProtonTestServer()) {
        peer.expectSASLAnonymousConnect();
        peer.expectOpen().respond();
        peer.expectBegin().respond();
        peer.expectAttach().ofSender().respond();
        peer.remoteFlow().withLinkCredit(10).queue();
        // Open a receiver to ensure sender link has processed
        peer.expectAttach().respond();
        // the inbound flow frame we sent previously before send.
        peer.expectFlow();
        peer.start();
        URI remoteURI = peer.getServerURI();
        LOG.info("Sender test started, peer listening on: {}", remoteURI);
        Client container = Client.create();
        Connection connection = container.connect(remoteURI.getHost(), remoteURI.getPort()).openFuture().get();
        Session session = connection.openSession().openFuture().get();
        SenderOptions options = new SenderOptions().deliveryMode(DeliveryMode.AT_MOST_ONCE);
        Sender sender = session.openSender("test-qos", options);
        // Gates send on remote flow having been sent and received
        session.openReceiver("dummy").openFuture().get();
        HeaderMatcher headerMatcher = new HeaderMatcher(true);
        headerMatcher.withDurable(true);
        headerMatcher.withPriority((byte) 1);
        headerMatcher.withTtl(65535);
        headerMatcher.withFirstAcquirer(true);
        headerMatcher.withDeliveryCount(2);
        PropertiesMatcher propertiesMatcher = new PropertiesMatcher(true);
        propertiesMatcher.withMessageId("ID:12345");
        propertiesMatcher.withUserId("user".getBytes(StandardCharsets.UTF_8));
        propertiesMatcher.withTo("the-management");
        propertiesMatcher.withSubject("amqp");
        propertiesMatcher.withReplyTo("the-minions");
        propertiesMatcher.withCorrelationId("abc");
        propertiesMatcher.withContentEncoding("application/json");
        propertiesMatcher.withContentEncoding("gzip");
        propertiesMatcher.withAbsoluteExpiryTime(123);
        propertiesMatcher.withCreationTime(1);
        propertiesMatcher.withGroupId("disgruntled");
        propertiesMatcher.withGroupSequence(8192);
        propertiesMatcher.withReplyToGroupId("/dev/null");
        DeliveryAnnotationsMatcher daMatcher = new DeliveryAnnotationsMatcher(true);
        daMatcher.withEntry("da1", Matchers.equalTo(1));
        daMatcher.withEntry("da2", Matchers.equalTo(2));
        daMatcher.withEntry("da3", Matchers.equalTo(3));
        MessageAnnotationsMatcher maMatcher = new MessageAnnotationsMatcher(true);
        maMatcher.withEntry("ma1", Matchers.equalTo(1));
        maMatcher.withEntry("ma2", Matchers.equalTo(2));
        maMatcher.withEntry("ma3", Matchers.equalTo(3));
        ApplicationPropertiesMatcher apMatcher = new ApplicationPropertiesMatcher(true);
        apMatcher.withEntry("ap1", Matchers.equalTo(1));
        apMatcher.withEntry("ap2", Matchers.equalTo(2));
        apMatcher.withEntry("ap3", Matchers.equalTo(3));
        FooterMatcher footerMatcher = new FooterMatcher(false);
        footerMatcher.withEntry("f1", Matchers.equalTo(1));
        footerMatcher.withEntry("f2", Matchers.equalTo(2));
        footerMatcher.withEntry("f3", Matchers.equalTo(3));
        EncodedAmqpValueMatcher bodyMatcher = new EncodedAmqpValueMatcher("Hello World", true);
        TransferPayloadCompositeMatcher payloadMatcher = new TransferPayloadCompositeMatcher();
        payloadMatcher.setHeadersMatcher(headerMatcher);
        payloadMatcher.setDeliveryAnnotationsMatcher(daMatcher);
        payloadMatcher.setMessageAnnotationsMatcher(maMatcher);
        payloadMatcher.setPropertiesMatcher(propertiesMatcher);
        payloadMatcher.setApplicationPropertiesMatcher(apMatcher);
        payloadMatcher.setMessageContentMatcher(bodyMatcher);
        payloadMatcher.setFootersMatcher(footerMatcher);
        peer.waitForScriptToComplete(5, TimeUnit.SECONDS);
        peer.expectTransfer().withPayload(payloadMatcher).accept();
        peer.expectDetach().respond();
        peer.expectClose().respond();
        // Populate delivery annotations
        Map<String, Object> deliveryAnnotations = new HashMap<>();
        deliveryAnnotations.put("da1", 1);
        deliveryAnnotations.put("da2", 2);
        deliveryAnnotations.put("da3", 3);
        final Message<String> message = new ExternalMessage<>(allowAdvancedConversion);
        message.body("Hello World");
        // Populate all Header values
        message.durable(true);
        message.priority((byte) 1);
        message.timeToLive(65535);
        message.firstAcquirer(true);
        message.deliveryCount(2);
        // Populate message annotations
        message.annotation("ma1", 1);
        message.annotation("ma2", 2);
        message.annotation("ma3", 3);
        // Populate all Properties values
        message.messageId("ID:12345");
        message.userId("user".getBytes(StandardCharsets.UTF_8));
        message.to("the-management");
        message.subject("amqp");
        message.replyTo("the-minions");
        message.correlationId("abc");
        message.contentEncoding("application/json");
        message.contentEncoding("gzip");
        message.absoluteExpiryTime(123);
        message.creationTime(1);
        message.groupId("disgruntled");
        message.groupSequence(8192);
        message.replyToGroupId("/dev/null");
        // Populate message application properties
        message.property("ap1", 1);
        message.property("ap2", 2);
        message.property("ap3", 3);
        // Populate message footers
        message.footer("f1", 1);
        message.footer("f2", 2);
        message.footer("f3", 3);
        // Check preconditions that should affect the send operation
        if (allowAdvancedConversion) {
            assertNotNull(message.toAdvancedMessage());
        } else {
            assertThrows(UnsupportedOperationException.class, () -> message.toAdvancedMessage());
        }
        final Tracker tracker;
        if (trySend) {
            tracker = sender.trySend(message, deliveryAnnotations);
        } else {
            tracker = sender.send(message, deliveryAnnotations);
        }
        assertNotNull(tracker);
        assertNotNull(tracker.settlementFuture().isDone());
        assertNotNull(tracker.settlementFuture().get().settled());
        sender.closeAsync().get(10, TimeUnit.SECONDS);
        connection.closeAsync().get(10, TimeUnit.SECONDS);
        peer.waitForScriptToComplete(5, TimeUnit.SECONDS);
    }
}
Also used : HeaderMatcher(org.apache.qpid.protonj2.test.driver.matchers.messaging.HeaderMatcher) Tracker(org.apache.qpid.protonj2.client.Tracker) ProtonTestServer(org.apache.qpid.protonj2.test.driver.ProtonTestServer) SenderOptions(org.apache.qpid.protonj2.client.SenderOptions) DeliveryAnnotationsMatcher(org.apache.qpid.protonj2.test.driver.matchers.messaging.DeliveryAnnotationsMatcher) MessageAnnotationsMatcher(org.apache.qpid.protonj2.test.driver.matchers.messaging.MessageAnnotationsMatcher) HashMap(java.util.HashMap) Connection(org.apache.qpid.protonj2.client.Connection) EncodedAmqpValueMatcher(org.apache.qpid.protonj2.test.driver.matchers.types.EncodedAmqpValueMatcher) TransferPayloadCompositeMatcher(org.apache.qpid.protonj2.test.driver.matchers.transport.TransferPayloadCompositeMatcher) URI(java.net.URI) Sender(org.apache.qpid.protonj2.client.Sender) ApplicationPropertiesMatcher(org.apache.qpid.protonj2.test.driver.matchers.messaging.ApplicationPropertiesMatcher) ExternalMessage(org.apache.qpid.protonj2.client.util.ExternalMessage) Client(org.apache.qpid.protonj2.client.Client) PropertiesMatcher(org.apache.qpid.protonj2.test.driver.matchers.messaging.PropertiesMatcher) ApplicationPropertiesMatcher(org.apache.qpid.protonj2.test.driver.matchers.messaging.ApplicationPropertiesMatcher) Session(org.apache.qpid.protonj2.client.Session) FooterMatcher(org.apache.qpid.protonj2.test.driver.matchers.messaging.FooterMatcher)

Example 12 with DeliveryAnnotations

use of org.apache.qpid.protonj2.test.driver.codec.messaging.DeliveryAnnotations in project qpid-protonj2 by apache.

the class MessageSendTest method testSendMessageWithMultipleSectionsPopulated.

@Test
public void testSendMessageWithMultipleSectionsPopulated() throws Exception {
    try (ProtonTestServer peer = new ProtonTestServer()) {
        peer.expectSASLAnonymousConnect();
        peer.expectOpen().respond();
        peer.expectBegin().respond();
        peer.expectAttach().ofSender().respond();
        peer.remoteFlow().withLinkCredit(10).queue();
        // Open a receiver to ensure sender link has processed
        peer.expectAttach().respond();
        // the inbound flow frame we sent previously before send.
        peer.expectFlow();
        peer.start();
        URI remoteURI = peer.getServerURI();
        LOG.info("Sender test started, peer listening on: {}", remoteURI);
        Client container = Client.create();
        Connection connection = container.connect(remoteURI.getHost(), remoteURI.getPort()).openFuture().get();
        Session session = connection.openSession().openFuture().get();
        SenderOptions options = new SenderOptions().deliveryMode(DeliveryMode.AT_MOST_ONCE);
        Sender sender = session.openSender("test-qos", options);
        // Gates send on remote flow having been sent and received
        session.openReceiver("dummy").openFuture().get();
        HeaderMatcher headerMatcher = new HeaderMatcher(true);
        headerMatcher.withDurable(true);
        headerMatcher.withPriority((byte) 1);
        headerMatcher.withTtl(65535);
        headerMatcher.withFirstAcquirer(true);
        headerMatcher.withDeliveryCount(2);
        PropertiesMatcher propertiesMatcher = new PropertiesMatcher(true);
        propertiesMatcher.withMessageId("ID:12345");
        propertiesMatcher.withUserId("user".getBytes(StandardCharsets.UTF_8));
        propertiesMatcher.withTo("the-management");
        propertiesMatcher.withSubject("amqp");
        propertiesMatcher.withReplyTo("the-minions");
        propertiesMatcher.withCorrelationId("abc");
        propertiesMatcher.withContentEncoding("application/json");
        propertiesMatcher.withContentEncoding("gzip");
        propertiesMatcher.withAbsoluteExpiryTime(123);
        propertiesMatcher.withCreationTime(1);
        propertiesMatcher.withGroupId("disgruntled");
        propertiesMatcher.withGroupSequence(8192);
        propertiesMatcher.withReplyToGroupId("/dev/null");
        DeliveryAnnotationsMatcher daMatcher = new DeliveryAnnotationsMatcher(true);
        daMatcher.withEntry("da1", Matchers.equalTo(1));
        daMatcher.withEntry("da2", Matchers.equalTo(2));
        daMatcher.withEntry("da3", Matchers.equalTo(3));
        MessageAnnotationsMatcher maMatcher = new MessageAnnotationsMatcher(true);
        maMatcher.withEntry("ma1", Matchers.equalTo(1));
        maMatcher.withEntry("ma2", Matchers.equalTo(2));
        maMatcher.withEntry("ma3", Matchers.equalTo(3));
        ApplicationPropertiesMatcher apMatcher = new ApplicationPropertiesMatcher(true);
        apMatcher.withEntry("ap1", Matchers.equalTo(1));
        apMatcher.withEntry("ap2", Matchers.equalTo(2));
        apMatcher.withEntry("ap3", Matchers.equalTo(3));
        EncodedAmqpValueMatcher bodyMatcher = new EncodedAmqpValueMatcher("Hello World", true);
        FooterMatcher footerMatcher = new FooterMatcher(false);
        footerMatcher.withEntry("f1", Matchers.equalTo(1));
        footerMatcher.withEntry("f2", Matchers.equalTo(2));
        footerMatcher.withEntry("f3", Matchers.equalTo(3));
        TransferPayloadCompositeMatcher payloadMatcher = new TransferPayloadCompositeMatcher();
        payloadMatcher.setHeadersMatcher(headerMatcher);
        payloadMatcher.setDeliveryAnnotationsMatcher(daMatcher);
        payloadMatcher.setMessageAnnotationsMatcher(maMatcher);
        payloadMatcher.setPropertiesMatcher(propertiesMatcher);
        payloadMatcher.setApplicationPropertiesMatcher(apMatcher);
        payloadMatcher.setMessageContentMatcher(bodyMatcher);
        payloadMatcher.setFootersMatcher(footerMatcher);
        peer.waitForScriptToComplete(5, TimeUnit.SECONDS);
        peer.expectTransfer().withPayload(payloadMatcher).accept();
        peer.expectDetach().respond();
        peer.expectClose().respond();
        // Populate delivery annotations
        Map<String, Object> deliveryAnnotations = new HashMap<>();
        deliveryAnnotations.put("da1", 1);
        deliveryAnnotations.put("da2", 2);
        deliveryAnnotations.put("da3", 3);
        final Message<String> message = Message.create("Hello World");
        // Populate all Header values
        message.durable(true);
        message.priority((byte) 1);
        message.timeToLive(65535);
        message.firstAcquirer(true);
        message.deliveryCount(2);
        // Populate message annotations
        message.annotation("ma1", 1);
        message.annotation("ma2", 2);
        message.annotation("ma3", 3);
        // Populate all Properties values
        message.messageId("ID:12345");
        message.userId("user".getBytes(StandardCharsets.UTF_8));
        message.to("the-management");
        message.subject("amqp");
        message.replyTo("the-minions");
        message.correlationId("abc");
        message.contentEncoding("application/json");
        message.contentEncoding("gzip");
        message.absoluteExpiryTime(123);
        message.creationTime(1);
        message.groupId("disgruntled");
        message.groupSequence(8192);
        message.replyToGroupId("/dev/null");
        // Populate message application properties
        message.property("ap1", 1);
        message.property("ap2", 2);
        message.property("ap3", 3);
        // Populate message footers
        message.footer("f1", 1);
        message.footer("f2", 2);
        message.footer("f3", 3);
        final Tracker tracker = sender.send(message, deliveryAnnotations);
        assertNotNull(tracker);
        assertNotNull(tracker.settlementFuture().isDone());
        assertNotNull(tracker.settlementFuture().get().settled());
        sender.closeAsync().get(10, TimeUnit.SECONDS);
        connection.closeAsync().get(10, TimeUnit.SECONDS);
        peer.waitForScriptToComplete(5, TimeUnit.SECONDS);
    }
}
Also used : HeaderMatcher(org.apache.qpid.protonj2.test.driver.matchers.messaging.HeaderMatcher) Tracker(org.apache.qpid.protonj2.client.Tracker) ProtonTestServer(org.apache.qpid.protonj2.test.driver.ProtonTestServer) SenderOptions(org.apache.qpid.protonj2.client.SenderOptions) DeliveryAnnotationsMatcher(org.apache.qpid.protonj2.test.driver.matchers.messaging.DeliveryAnnotationsMatcher) MessageAnnotationsMatcher(org.apache.qpid.protonj2.test.driver.matchers.messaging.MessageAnnotationsMatcher) HashMap(java.util.HashMap) Connection(org.apache.qpid.protonj2.client.Connection) EncodedAmqpValueMatcher(org.apache.qpid.protonj2.test.driver.matchers.types.EncodedAmqpValueMatcher) TransferPayloadCompositeMatcher(org.apache.qpid.protonj2.test.driver.matchers.transport.TransferPayloadCompositeMatcher) URI(java.net.URI) Sender(org.apache.qpid.protonj2.client.Sender) ApplicationPropertiesMatcher(org.apache.qpid.protonj2.test.driver.matchers.messaging.ApplicationPropertiesMatcher) Client(org.apache.qpid.protonj2.client.Client) PropertiesMatcher(org.apache.qpid.protonj2.test.driver.matchers.messaging.PropertiesMatcher) ApplicationPropertiesMatcher(org.apache.qpid.protonj2.test.driver.matchers.messaging.ApplicationPropertiesMatcher) Session(org.apache.qpid.protonj2.client.Session) FooterMatcher(org.apache.qpid.protonj2.test.driver.matchers.messaging.FooterMatcher) Test(org.junit.jupiter.api.Test)

Example 13 with DeliveryAnnotations

use of org.apache.qpid.protonj2.test.driver.codec.messaging.DeliveryAnnotations in project qpid-protonj2 by apache.

the class DeliveryAnnotationsTypeCodecTest method doTestEncodeDecodeDeliveryAnnotationsArray.

private void doTestEncodeDecodeDeliveryAnnotationsArray(boolean fromStream) throws IOException {
    final Symbol SYMBOL_1 = Symbol.valueOf("test1");
    final Symbol SYMBOL_2 = Symbol.valueOf("test2");
    final Symbol SYMBOL_3 = Symbol.valueOf("test3");
    DeliveryAnnotations[] array = new DeliveryAnnotations[3];
    DeliveryAnnotations annotations = new DeliveryAnnotations(new HashMap<>());
    annotations.getValue().put(SYMBOL_1, UnsignedByte.valueOf((byte) 128));
    annotations.getValue().put(SYMBOL_2, UnsignedShort.valueOf((short) 128));
    annotations.getValue().put(SYMBOL_3, UnsignedInteger.valueOf(128));
    array[0] = annotations;
    array[1] = annotations;
    array[2] = annotations;
    ProtonBuffer buffer = ProtonByteBufferAllocator.DEFAULT.allocate();
    InputStream stream = new ProtonBufferInputStream(buffer);
    encoder.writeObject(buffer, encoderState, array);
    final Object result;
    if (fromStream) {
        result = streamDecoder.readObject(stream, streamDecoderState);
    } else {
        result = decoder.readObject(buffer, decoderState);
    }
    assertTrue(result.getClass().isArray());
    assertEquals(DeliveryAnnotations.class, result.getClass().getComponentType());
    DeliveryAnnotations[] resultArray = (DeliveryAnnotations[]) result;
    for (int i = 0; i < resultArray.length; ++i) {
        DeliveryAnnotations readAnnotations = resultArray[i];
        Map<Symbol, Object> resultMap = readAnnotations.getValue();
        assertEquals(annotations.getValue().size(), resultMap.size());
        assertEquals(resultMap.get(SYMBOL_1), UnsignedByte.valueOf((byte) 128));
        assertEquals(resultMap.get(SYMBOL_2), UnsignedShort.valueOf((short) 128));
        assertEquals(resultMap.get(SYMBOL_3), UnsignedInteger.valueOf(128));
    }
}
Also used : ProtonBuffer(org.apache.qpid.protonj2.buffer.ProtonBuffer) Symbol(org.apache.qpid.protonj2.types.Symbol) ProtonBufferInputStream(org.apache.qpid.protonj2.buffer.ProtonBufferInputStream) InputStream(java.io.InputStream) DeliveryAnnotations(org.apache.qpid.protonj2.types.messaging.DeliveryAnnotations) ProtonBufferInputStream(org.apache.qpid.protonj2.buffer.ProtonBufferInputStream)

Example 14 with DeliveryAnnotations

use of org.apache.qpid.protonj2.test.driver.codec.messaging.DeliveryAnnotations in project qpid-protonj2 by apache.

the class DeliveryAnnotationsTypeCodecTest method testReadTypeWithNullEncoding.

private void testReadTypeWithNullEncoding(boolean fromStream) throws IOException {
    ProtonBuffer buffer = ProtonByteBufferAllocator.DEFAULT.allocate();
    InputStream stream = new ProtonBufferInputStream(buffer);
    // Described Type Indicator
    buffer.writeByte((byte) 0);
    buffer.writeByte(EncodingCodes.SMALLULONG);
    buffer.writeByte(DeliveryAnnotations.DESCRIPTOR_CODE.byteValue());
    buffer.writeByte(EncodingCodes.NULL);
    final Object result;
    if (fromStream) {
        result = streamDecoder.readObject(stream, streamDecoderState);
    } else {
        result = decoder.readObject(buffer, decoderState);
    }
    assertNotNull(result);
    assertTrue(result instanceof DeliveryAnnotations);
    DeliveryAnnotations decoded = (DeliveryAnnotations) result;
    assertNull(decoded.getValue());
}
Also used : ProtonBuffer(org.apache.qpid.protonj2.buffer.ProtonBuffer) ProtonBufferInputStream(org.apache.qpid.protonj2.buffer.ProtonBufferInputStream) InputStream(java.io.InputStream) DeliveryAnnotations(org.apache.qpid.protonj2.types.messaging.DeliveryAnnotations) ProtonBufferInputStream(org.apache.qpid.protonj2.buffer.ProtonBufferInputStream)

Example 15 with DeliveryAnnotations

use of org.apache.qpid.protonj2.test.driver.codec.messaging.DeliveryAnnotations in project qpid-protonj2 by apache.

the class DeliveryAnnotationsTypeCodecTest method doTestEncodeDecodeMessageAnnotationsWithEmptyValue.

private void doTestEncodeDecodeMessageAnnotationsWithEmptyValue(boolean fromStream) throws IOException {
    ProtonBuffer buffer = ProtonByteBufferAllocator.DEFAULT.allocate();
    InputStream stream = new ProtonBufferInputStream(buffer);
    encoder.writeObject(buffer, encoderState, new DeliveryAnnotations(null));
    final Object result;
    if (fromStream) {
        result = streamDecoder.readObject(stream, streamDecoderState);
    } else {
        result = decoder.readObject(buffer, decoderState);
    }
    assertNotNull(result);
    assertTrue(result instanceof DeliveryAnnotations);
    DeliveryAnnotations readAnnotations = (DeliveryAnnotations) result;
    assertNull(readAnnotations.getValue());
}
Also used : ProtonBuffer(org.apache.qpid.protonj2.buffer.ProtonBuffer) ProtonBufferInputStream(org.apache.qpid.protonj2.buffer.ProtonBufferInputStream) InputStream(java.io.InputStream) DeliveryAnnotations(org.apache.qpid.protonj2.types.messaging.DeliveryAnnotations) ProtonBufferInputStream(org.apache.qpid.protonj2.buffer.ProtonBufferInputStream)

Aggregations

DeliveryAnnotations (org.apache.qpid.protonj2.types.messaging.DeliveryAnnotations)11 ProtonBuffer (org.apache.qpid.protonj2.buffer.ProtonBuffer)10 HashMap (java.util.HashMap)9 InputStream (java.io.InputStream)7 ProtonBufferInputStream (org.apache.qpid.protonj2.buffer.ProtonBufferInputStream)7 URI (java.net.URI)6 Client (org.apache.qpid.protonj2.client.Client)6 Connection (org.apache.qpid.protonj2.client.Connection)6 ProtonTestServer (org.apache.qpid.protonj2.test.driver.ProtonTestServer)6 DeliveryAnnotationsMatcher (org.apache.qpid.protonj2.test.driver.matchers.messaging.DeliveryAnnotationsMatcher)6 TransferPayloadCompositeMatcher (org.apache.qpid.protonj2.test.driver.matchers.transport.TransferPayloadCompositeMatcher)6 Tracker (org.apache.qpid.protonj2.client.Tracker)5 EncodedAmqpValueMatcher (org.apache.qpid.protonj2.test.driver.matchers.types.EncodedAmqpValueMatcher)5 Symbol (org.apache.qpid.protonj2.types.Symbol)5 Sender (org.apache.qpid.protonj2.client.Sender)4 Session (org.apache.qpid.protonj2.client.Session)4 SenderOptions (org.apache.qpid.protonj2.client.SenderOptions)3 ApplicationPropertiesMatcher (org.apache.qpid.protonj2.test.driver.matchers.messaging.ApplicationPropertiesMatcher)3 HeaderMatcher (org.apache.qpid.protonj2.test.driver.matchers.messaging.HeaderMatcher)3 MessageAnnotationsMatcher (org.apache.qpid.protonj2.test.driver.matchers.messaging.MessageAnnotationsMatcher)3